003 File Manager
Current Path:
/usr/src/sys/i386/i386
usr
/
src
/
sys
/
i386
/
i386
/
📁
..
📄
apic_vector.s
(6.78 KB)
📄
atpic_vector.s
(2.63 KB)
📄
bios.c
(19.81 KB)
📄
bioscall.s
(3.97 KB)
📄
bpf_jit_machdep.c
(13.33 KB)
📄
bpf_jit_machdep.h
(11.54 KB)
📄
copyout.c
(11.91 KB)
📄
copyout_fast.s
(6.35 KB)
📄
db_disasm.c
(42.43 KB)
📄
db_interface.c
(2.84 KB)
📄
db_trace.c
(18.78 KB)
📄
elan-mmcr.c
(12.2 KB)
📄
elf_machdep.c
(7.52 KB)
📄
exception.s
(16.3 KB)
📄
gdb_machdep.c
(3.46 KB)
📄
genassym.c
(8.88 KB)
📄
geode.c
(8.86 KB)
📄
in_cksum.c
(12.03 KB)
📄
initcpu.c
(22.28 KB)
📄
io.c
(1.82 KB)
📄
k6_mem.c
(5.23 KB)
📄
locore.s
(11.27 KB)
📄
longrun.c
(8.97 KB)
📄
machdep.c
(85.6 KB)
📄
mem.c
(6.46 KB)
📄
minidump_machdep.c
(1.93 KB)
📄
minidump_machdep_base.c
(8.92 KB)
📄
minidump_machdep_nopae.c
(1.7 KB)
📄
minidump_machdep_pae.c
(1.72 KB)
📄
mp_clock.c
(3.96 KB)
📄
mp_machdep.c
(17.51 KB)
📄
mpboot.s
(6.56 KB)
📄
npx.c
(40.46 KB)
📄
perfmon.c
(8.54 KB)
📄
pmap.c
(166.3 KB)
📄
pmap_base.c
(20.83 KB)
📄
pmap_nopae.c
(1.85 KB)
📄
pmap_pae.c
(1.89 KB)
📄
prof_machdep.c
(11.04 KB)
📄
ptrace_machdep.c
(4.76 KB)
📄
sigtramp.s
(4.15 KB)
📄
support.s
(11.06 KB)
📄
swtch.s
(11.14 KB)
📄
sys_machdep.c
(20.6 KB)
📄
trap.c
(31.29 KB)
📄
uio_machdep.c
(4.01 KB)
📄
vm86.c
(20.95 KB)
📄
vm86bios.s
(4.72 KB)
📄
vm_machdep.c
(17.06 KB)
Editing: copyout_fast.s
/*- * SPDX-License-Identifier: BSD-2-Clause-FreeBSD * * Copyright (c) 2018 The FreeBSD Foundation * All rights reserved. * * This software was developed by Konstantin Belousov <kib@FreeBSD.org> * under sponsorship from the FreeBSD Foundation. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $FreeBSD$ */ #include <machine/asmacros.h> #include <machine/cputypes.h> #include <machine/pmap.h> #include <machine/specialreg.h> #include "assym.inc" .text ENTRY(copyout_fast) pushl %ebp movl %esp, %ebp pushl %esi pushl %edi pushl %ebx movl $copyout_fault,%edx movl 20(%ebp),%ebx /* KCR3 */ movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%edi cli movl PCPU(TRAMPSTK),%esi movl PCPU(COPYOUT_BUF),%eax subl $4,%esi movl %eax,(%esi) movl 12(%ebp),%eax /* udaddr */ subl $4,%esi movl %eax,(%esi) movl 16(%ebp),%eax /* len */ subl $4,%esi movl %eax,(%esi) subl $4, %esi movl %edi, (%esi) movl 8(%ebp),%eax /* kaddr */ subl $4,%esi movl %eax,(%esi) movl PCPU(COPYOUT_BUF),%eax subl $4,%esi movl %eax,(%esi) movl 16(%ebp),%eax /* len */ subl $4,%esi movl %eax,(%esi) movl %esp,%eax movl %esi,%esp /* bcopy(%esi = kaddr, %edi = PCPU(copyout_buf), %ecx = len) */ popl %ecx popl %edi popl %esi rep; movsb popl %edi movl %edi,%cr3 /* bcopy(%esi = PCPU(copyout_buf), %edi = udaddr, %ecx = len) */ popl %ecx popl %edi popl %esi rep; movsb movl %ebx,%cr3 movl %eax,%esp sti xorl %eax,%eax popl %ebx popl %edi popl %esi leave ret END(copyout_fast) ENTRY(copyin_fast) pushl %ebp movl %esp, %ebp pushl %esi pushl %edi pushl %ebx movl $copyout_fault,%edx movl 20(%ebp),%ebx /* KCR3 */ movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%edi cli movl PCPU(TRAMPSTK),%esi movl PCPU(COPYOUT_BUF),%eax subl $4,%esi movl %eax,(%esi) movl 12(%ebp),%eax /* kaddr */ subl $4,%esi movl %eax,(%esi) movl 16(%ebp),%eax /* len */ subl $4,%esi movl %eax,(%esi) movl 8(%ebp),%eax /* udaddr */ subl $4,%esi movl %eax,(%esi) movl PCPU(COPYOUT_BUF),%eax subl $4,%esi movl %eax,(%esi) movl 16(%ebp),%eax /* len */ subl $4,%esi movl %eax,(%esi) movl %esp,%eax movl %esi,%esp movl %edi,%cr3 /* bcopy(%esi = udaddr, %edi = PCPU(copyout_buf), %ecx = len) */ popl %ecx popl %edi popl %esi rep; movsb movl %ebx,%cr3 /* bcopy(%esi = PCPU(copyout_buf), %edi = kaddr, %ecx = len) */ popl %ecx popl %edi popl %esi rep; movsb movl %eax,%esp sti xorl %eax,%eax popl %ebx popl %edi popl %esi leave ret END(copyin_fast) ALIGN_TEXT copyout_fault: movl %eax,%esp sti movl $EFAULT,%eax popl %ebx popl %edi popl %esi leave ret ENTRY(fueword_fast) pushl %ebp movl %esp,%ebp pushl %ebx pushl %esi pushl %edi movl 8(%ebp),%ecx /* from */ movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%eax movl $fusufault,%edx movl 16(%ebp),%ebx movl %esp,%esi cli movl PCPU(TRAMPSTK),%esp movl %eax,%cr3 movl (%ecx),%eax movl %ebx,%cr3 movl %esi,%esp sti movl 12(%ebp),%edx movl %eax,(%edx) xorl %eax,%eax popl %edi popl %esi popl %ebx leave ret END(fueword_fast) ENTRY(fuword16_fast) pushl %ebp movl %esp,%ebp pushl %ebx pushl %esi pushl %edi movl 8(%ebp),%ecx /* from */ movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%eax movl $fusufault,%edx movl 12(%ebp),%ebx movl %esp,%esi cli movl PCPU(TRAMPSTK),%esp movl %eax,%cr3 movzwl (%ecx),%eax movl %ebx,%cr3 movl %esi,%esp sti popl %edi popl %esi popl %ebx leave ret END(fuword16_fast) ENTRY(fubyte_fast) pushl %ebp movl %esp,%ebp pushl %ebx pushl %esi pushl %edi movl 8(%ebp),%ecx /* from */ movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%eax movl $fusufault,%edx movl 12(%ebp),%ebx movl %esp,%esi cli movl PCPU(TRAMPSTK),%esp movl %eax,%cr3 movzbl (%ecx),%eax movl %ebx,%cr3 movl %esi,%esp sti popl %edi popl %esi popl %ebx leave ret END(fubyte_fast) ALIGN_TEXT fusufault: movl %esi,%esp sti xorl %eax,%eax decl %eax popl %edi popl %esi popl %ebx leave ret ENTRY(suword_fast) pushl %ebp movl %esp,%ebp pushl %ebx pushl %esi pushl %edi movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%eax movl $fusufault,%edx movl 8(%ebp),%ecx /* to */ movl 12(%ebp),%edi /* val */ movl 16(%ebp),%ebx movl %esp,%esi cli movl PCPU(TRAMPSTK),%esp movl %eax,%cr3 movl %edi,(%ecx) movl %ebx,%cr3 movl %esi,%esp sti xorl %eax,%eax popl %edi popl %esi popl %ebx leave ret END(suword_fast) ENTRY(suword16_fast) pushl %ebp movl %esp,%ebp pushl %ebx pushl %esi pushl %edi movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%eax movl $fusufault,%edx movl 8(%ebp),%ecx /* to */ movl 12(%ebp),%edi /* val */ movl 16(%ebp),%ebx movl %esp,%esi cli movl PCPU(TRAMPSTK),%esp movl %eax,%cr3 movw %di,(%ecx) movl %ebx,%cr3 movl %esi,%esp sti xorl %eax,%eax popl %edi popl %esi popl %ebx leave ret END(suword16_fast) ENTRY(subyte_fast) pushl %ebp movl %esp,%ebp pushl %ebx pushl %esi pushl %edi movl PCPU(CURPCB),%eax movl PCB_CR3(%eax),%eax movl $fusufault,%edx movl 8(%ebp),%ecx /* to */ movl 12(%ebp),%edi /* val */ movl 16(%ebp),%ebx movl %esp,%esi cli movl PCPU(TRAMPSTK),%esp movl %eax,%cr3 movl %edi,%eax movb %al,(%ecx) movl %ebx,%cr3 movl %esi,%esp sti xorl %eax,%eax popl %edi popl %esi popl %ebx leave ret END(subyte_fast)
Upload File
Create Folder