1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-04 12:52:15 +00:00

Introduce a new potientially cleaner interface for accessing per-cpu

variables from i386 assembly language.  The syntax is PCPU(member)
where member is the capitalized name of the per-cpu variable, without
the gd_ prefix.  Example: movl %eax,PCPU(CURPROC).  The capitalization
is due to using the offsets generated by genassym rather than the symbols
provided by linking with globals.o.  asmacros.h is the wrong place for
this but it seemed as good a place as any for now.  The old implementation
in asnames.h has not been removed because it is still used to de-mangle
the symbols used by the C variables for the UP case.
This commit is contained in:
Jake Burkholder 2000-12-13 09:23:53 +00:00
parent 6cd8749dbf
commit 6d43764a10
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=69971
22 changed files with 292 additions and 275 deletions

View File

@ -48,7 +48,7 @@ IDTVEC(vec_name) ; \
movl $KPSEL,%eax ; \
mov %ax,%fs ; \
FAKE_MCOUNT(13*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
addl $4, %esp ; \
@ -136,7 +136,7 @@ log_intr_event:
addl $4, %esp
movl CNAME(apic_itrace_debugbuffer_idx), %ecx
andl $32767, %ecx
movl _cpuid, %eax
movl PCPU(CPUID), %eax
shll $8, %eax
orl 8(%esp), %eax
movw %ax, CNAME(apic_itrace_debugbuffer)(,%ecx,2)
@ -218,7 +218,7 @@ IDTVEC(vec_name) ; \
MASK_LEVEL_IRQ(irq_num) ; \
EOI_IRQ(irq_num) ; \
0: ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
; \
/* entry point used by doreti_unpend for HWIs. */ \
__CONCAT(Xresume,irq_num): ; \
@ -263,7 +263,7 @@ _Xinvltlb:
pushl %fs
movl $KPSEL, %eax
mov %ax, %fs
movl _cpuid, %eax
movl PCPU(CPUID), %eax
popl %fs
ss
incl _xhits(,%eax,4)
@ -321,10 +321,11 @@ _Xcpucheckstate:
jne 1f
incl %ebx /* system or interrupt */
1:
movl _cpuid, %eax
movl PCPU(CPUID), %eax
movl %ebx, _checkstate_cpustate(,%eax,4)
movl _curproc, %ebx
movl PCPU(CURPROC), %ebx
movl %ebx, _checkstate_curproc(,%eax,4)
movl 16(%esp), %ebx
movl %ebx, _checkstate_pc(,%eax,4)
@ -358,7 +359,7 @@ _Xcpuast:
movl $KPSEL, %eax
mov %ax, %fs
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock /* checkstate_need_ast &= ~(1<<id) */
btrl %eax, _checkstate_need_ast
movl $0, lapic_eoi /* End Of Interrupt to APIC */
@ -369,17 +370,17 @@ _Xcpuast:
FAKE_MCOUNT(13*4(%esp))
orl $AST_PENDING, _astpending /* XXX */
incb _intr_nesting_level
orl $AST_PENDING, PCPU(ASTPENDING) /* XXX */
incb PCPU(INTR_NESTING_LEVEL)
sti
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock
btrl %eax, _checkstate_pending_ast
lock
btrl %eax, CNAME(resched_cpus)
jnc 2f
orl $AST_PENDING+AST_RESCHED, _astpending
orl $AST_PENDING+AST_RESCHED, PCPU(ASTPENDING)
lock
incl CNAME(want_resched_cnt)
2:
@ -414,10 +415,10 @@ _Xforward_irq:
lock
incl CNAME(forward_irq_hitcnt)
cmpb $4, _intr_nesting_level
cmpb $4, PCPU(INTR_NESTING_LEVEL)
jae 1f
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
sti
MEXITCOUNT
@ -499,7 +500,7 @@ _Xcpustop:
movl $0, lapic_eoi /* End Of Interrupt to APIC */
movl _cpuid, %eax
movl PCPU(CPUID), %eax
imull $PCB_SIZE, %eax
leal CNAME(stoppcbs)(%eax), %eax
pushl %eax
@ -507,7 +508,7 @@ _Xcpustop:
addl $4, %esp
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock
btsl %eax, _stopped_cpus /* stopped_cpus |= (1<<id) */

View File

@ -82,7 +82,7 @@ ENTRY(cpu_throw)
ENTRY(cpu_switch)
/* switch to new process. first, save context as needed */
movl _curproc,%ecx
movl PCPU(CURPROC),%ecx
/* if no process to save, don't bother */
testl %ecx,%ecx
@ -95,7 +95,7 @@ ENTRY(cpu_switch)
#endif /* SMP */
movl P_VMSPACE(%ecx), %edx
#ifdef SMP
movl _cpuid, %eax
movl PCPU(CPUID), %eax
#else
xorl %eax, %eax
#endif /* SMP */
@ -142,7 +142,7 @@ ENTRY(cpu_switch)
#if NNPX > 0
/* have we used fp, and need a save? */
cmpl %ecx,_npxproc
cmpl %ecx,PCPU(NPXPROC)
jne 1f
addl $PCB_SAVEFPU,%edx /* h/w bugs make saving complicated */
pushl %edx
@ -158,10 +158,10 @@ sw1:
/* Stop scheduling if smp_active goes zero and we are not BSP */
cmpl $0,_smp_active
jne 1f
cmpl $0,_cpuid
cmpl $0,PCPU(CPUID)
je 1f
movl _idleproc, %eax
movl PCPU(IDLEPROC), %eax
jmp sw1b
1:
#endif
@ -181,7 +181,7 @@ sw1b:
movl %eax,%ecx
xorl %eax,%eax
andl $~AST_RESCHED,_astpending
andl $~AST_RESCHED,PCPU(ASTPENDING)
#ifdef INVARIANTS
cmpb $SRUN,P_STAT(%ecx)
@ -206,7 +206,7 @@ sw1b:
4:
#ifdef SMP
movl _cpuid, %esi
movl PCPU(CPUID), %esi
#else
xorl %esi, %esi
#endif
@ -220,19 +220,19 @@ sw1b:
/* update common_tss.tss_esp0 pointer */
movl %edx, %ebx /* pcb */
addl $(UPAGES * PAGE_SIZE - 16), %ebx
movl %ebx, _common_tss + TSS_ESP0
movl %ebx, PCPU(COMMON_TSS) + TSS_ESP0
btrl %esi, _private_tss
jae 3f
#ifdef SMP
movl $gd_common_tssd, %edi
movl $GD_COMMON_TSSD, %edi
addl %fs:0, %edi
#else
movl $_common_tssd, %edi
movl $PCPU(COMMON_TSSD), %edi
#endif
2:
/* move correct tss descriptor into GDT slot, then reload tr */
movl _tss_gdt, %ebx /* entry in GDT */
movl PCPU(TSS_GDT), %ebx /* entry in GDT */
movl 0(%edi), %eax
movl %eax, 0(%ebx)
movl 4(%edi), %eax
@ -242,7 +242,7 @@ sw1b:
3:
movl P_VMSPACE(%ecx), %ebx
#ifdef SMP
movl _cpuid, %eax
movl PCPU(CPUID), %eax
#else
xorl %eax, %eax
#endif
@ -265,11 +265,11 @@ sw1b:
andl $~APIC_TPR_PRIO, lapic_tpr
#endif /** CHEAP_TPR */
#endif /** GRAB_LOPRIO */
movl _cpuid,%eax
movl PCPU(CPUID),%eax
movb %al, P_ONCPU(%ecx)
#endif /* SMP */
movl %edx, _curpcb
movl %ecx, _curproc /* into next process */
movl %edx, PCPU(CURPCB)
movl %ecx, PCPU(CURPROC) /* into next process */
#ifdef SMP
/* XXX FIXME: we should be restoring the local APIC TPR */
@ -279,10 +279,10 @@ sw1b:
cmpl $0, PCB_USERLDT(%edx)
jnz 1f
movl __default_ldt,%eax
cmpl _currentldt,%eax
cmpl PCPU(CURRENTLDT),%eax
je 2f
lldt __default_ldt
movl %eax,_currentldt
movl %eax,PCPU(CURRENTLDT)
jmp 2f
1: pushl %edx
call _set_user_ldt
@ -320,7 +320,7 @@ cpu_switch_load_gs:
movl PCB_SCHEDNEST(%edx),%eax
movl %eax,_sched_lock+MTX_RECURSE
movl _curproc,%eax
movl PCPU(CURPROC),%eax
movl %eax,_sched_lock+MTX_LOCK
ret
@ -376,7 +376,7 @@ ENTRY(savectx)
* have to handle h/w bugs for reloading. We used to lose the
* parent's npx state for forks by forgetting to reload.
*/
movl _npxproc,%eax
movl PCPU(NPXPROC),%eax
testl %eax,%eax
je 1f

View File

@ -184,7 +184,7 @@ IDTVEC(fpu)
call __mtx_exit_giant_def
addl $4,%esp
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
#else /* NNPX > 0 */
@ -223,7 +223,7 @@ calltrap:
/*
* Return via _doreti to handle ASTs.
*/
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
@ -262,9 +262,9 @@ IDTVEC(syscall)
call _syscall2
MEXITCOUNT
cli /* atomic astpending access */
cmpl $0,_astpending /* AST pending? */
cmpl $0,PCPU(ASTPENDING) /* AST pending? */
je doreti_syscall_ret /* no, get out of here */
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
jmp _doreti
/*
@ -294,9 +294,9 @@ IDTVEC(int0x80_syscall)
call _syscall2
MEXITCOUNT
cli /* atomic astpending access */
cmpl $0,_astpending /* AST pending? */
cmpl $0,PCPU(ASTPENDING) /* AST pending? */
je doreti_syscall_ret /* no, get out of here */
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
jmp _doreti
ENTRY(fork_trampoline)
@ -306,15 +306,15 @@ ENTRY(fork_trampoline)
are enabled */
#ifdef SMP
cmpl $0,_switchtime
cmpl $0,PCPU(SWITCHTIME)
jne 1f
movl $gd_switchtime,%eax
movl $GD_SWITCHTIME,%eax
addl %fs:0,%eax
pushl %eax
call _microuptime
popl %edx
movl _ticks,%eax
movl %eax,_switchticks
movl %eax,PCPU(SWITCHTICKS)
1:
#endif
@ -331,7 +331,7 @@ ENTRY(fork_trampoline)
/*
* Return via _doreti to handle ASTs.
*/
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti

View File

@ -184,7 +184,7 @@ IDTVEC(fpu)
call __mtx_exit_giant_def
addl $4,%esp
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
#else /* NNPX > 0 */
@ -223,7 +223,7 @@ calltrap:
/*
* Return via _doreti to handle ASTs.
*/
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
@ -262,9 +262,9 @@ IDTVEC(syscall)
call _syscall2
MEXITCOUNT
cli /* atomic astpending access */
cmpl $0,_astpending /* AST pending? */
cmpl $0,PCPU(ASTPENDING) /* AST pending? */
je doreti_syscall_ret /* no, get out of here */
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
jmp _doreti
/*
@ -294,9 +294,9 @@ IDTVEC(int0x80_syscall)
call _syscall2
MEXITCOUNT
cli /* atomic astpending access */
cmpl $0,_astpending /* AST pending? */
cmpl $0,PCPU(ASTPENDING) /* AST pending? */
je doreti_syscall_ret /* no, get out of here */
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
jmp _doreti
ENTRY(fork_trampoline)
@ -306,15 +306,15 @@ ENTRY(fork_trampoline)
are enabled */
#ifdef SMP
cmpl $0,_switchtime
cmpl $0,PCPU(SWITCHTIME)
jne 1f
movl $gd_switchtime,%eax
movl $GD_SWITCHTIME,%eax
addl %fs:0,%eax
pushl %eax
call _microuptime
popl %edx
movl _ticks,%eax
movl %eax,_switchticks
movl %eax,PCPU(SWITCHTICKS)
1:
#endif
@ -331,7 +331,7 @@ ENTRY(fork_trampoline)
/*
* Return via _doreti to handle ASTs.
*/
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti

View File

@ -241,7 +241,7 @@ ENTRY(i586_bzero)
* method. CR0_TS must be preserved although it is very likely to
* always end up as clear.
*/
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bz1
cmpl $256+184,%ecx /* empirical; not quite 2*108 more */
jb intreg_i586_bzero
@ -293,7 +293,7 @@ fpureg_i586_bzero_loop:
cmpl $8,%ecx
jae fpureg_i586_bzero_loop
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bz3
frstor 0(%esp)
addl $108,%esp
@ -501,7 +501,7 @@ ENTRY(i586_bcopy)
sarb $1,kernel_fpu_lock
jc small_i586_bcopy
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bc1
smsw %dx
clts
@ -572,7 +572,7 @@ large_i586_bcopy_loop:
cmpl $64,%ecx
jae 4b
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bc2
frstor 0(%esp)
addl $108,%esp
@ -670,7 +670,7 @@ ENTRY(copyout)
jmp *_copyout_vector
ENTRY(generic_copyout)
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyout_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -781,7 +781,7 @@ done_copyout:
popl %edi
popl %esi
xorl %eax,%eax
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl %eax,PCB_ONFAULT(%edx)
ret
@ -790,7 +790,7 @@ copyout_fault:
popl %ebx
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -800,7 +800,7 @@ ENTRY(i586_copyout)
/*
* Duplicated from generic_copyout. Could be done a bit better.
*/
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyout_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -857,7 +857,7 @@ ENTRY(copyin)
jmp *_copyin_vector
ENTRY(generic_copyin)
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyin_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -895,7 +895,7 @@ done_copyin:
popl %edi
popl %esi
xorl %eax,%eax
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl %eax,PCB_ONFAULT(%edx)
ret
@ -903,7 +903,7 @@ done_copyin:
copyin_fault:
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -913,7 +913,7 @@ ENTRY(i586_copyin)
/*
* Duplicated from generic_copyin. Could be done a bit better.
*/
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyin_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -967,13 +967,13 @@ ENTRY(fastmove)
jnz fastmove_tail
/* if (npxproc != NULL) { */
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je 6f
/* fnsave(&curpcb->pcb_savefpu); */
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
fnsave PCB_SAVEFPU(%eax)
/* npxproc = NULL; */
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
/* } */
6:
/* now we own the FPU. */
@ -990,7 +990,7 @@ ENTRY(fastmove)
movl %esi,-8(%ebp)
movl %edi,-4(%ebp)
movl %esp,%edi
movl _curpcb,%esi
movl PCPU(CURPCB),%esi
addl $PCB_SAVEFPU,%esi
cld
movl $PCB_SAVEFPU_SIZE>>2,%ecx
@ -1002,9 +1002,9 @@ ENTRY(fastmove)
/* stop_emulating(); */
clts
/* npxproc = curproc; */
movl _curproc,%eax
movl %eax,_npxproc
movl _curpcb,%eax
movl PCPU(CURPROC),%eax
movl %eax,PCPU(NPXPROC)
movl PCPU(CURPCB),%eax
movl $fastmove_fault,PCB_ONFAULT(%eax)
4:
movl %ecx,-12(%ebp)
@ -1066,7 +1066,7 @@ fastmove_loop:
movl %ecx,-12(%ebp)
movl %esi,-8(%ebp)
movl %edi,-4(%ebp)
movl _curpcb,%edi
movl PCPU(CURPCB),%edi
addl $PCB_SAVEFPU,%edi
movl %esp,%esi
cld
@ -1082,11 +1082,11 @@ fastmove_loop:
orb $CR0_TS,%al
lmsw %ax
/* npxproc = NULL; */
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
ALIGN_TEXT
fastmove_tail:
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $fastmove_tail_fault,PCB_ONFAULT(%eax)
movb %cl,%al
@ -1105,7 +1105,7 @@ fastmove_tail:
ALIGN_TEXT
fastmove_fault:
movl _curpcb,%edi
movl PCPU(CURPCB),%edi
addl $PCB_SAVEFPU,%edi
movl %esp,%esi
cld
@ -1116,7 +1116,7 @@ fastmove_fault:
smsw %ax
orb $CR0_TS,%al
lmsw %ax
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
fastmove_tail_fault:
movl %ebp,%esp
@ -1125,7 +1125,7 @@ fastmove_tail_fault:
popl %ebx
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -1137,7 +1137,7 @@ fastmove_tail_fault:
* Fetch a byte (sword, word) from user memory
*/
ENTRY(fuword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx /* from */
@ -1163,7 +1163,7 @@ ENTRY(fuswintr)
* fusword - MP SAFE
*/
ENTRY(fusword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1178,7 +1178,7 @@ ENTRY(fusword)
* fubyte - MP SAFE
*/
ENTRY(fubyte)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1191,7 +1191,7 @@ ENTRY(fubyte)
ALIGN_TEXT
fusufault:
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
xorl %eax,%eax
movl %eax,PCB_ONFAULT(%ecx)
decl %eax
@ -1203,7 +1203,7 @@ fusufault:
* Write a byte (word, longword) to user memory
*/
ENTRY(suword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1247,7 +1247,7 @@ ENTRY(suword)
movl 8(%esp),%eax
movl %eax,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1255,7 +1255,7 @@ ENTRY(suword)
* susword - MP SAFE (if not I386_CPU)
*/
ENTRY(susword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1299,7 +1299,7 @@ ENTRY(susword)
movw 8(%esp),%ax
movw %ax,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx /* restore trashed register */
movl PCPU(CURPCB),%ecx /* restore trashed register */
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1308,7 +1308,7 @@ ENTRY(susword)
*/
ALTENTRY(suibyte)
ENTRY(subyte)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1351,7 +1351,7 @@ ENTRY(subyte)
movb 8(%esp),%al
movb %al,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx /* restore trashed register */
movl PCPU(CURPCB),%ecx /* restore trashed register */
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1366,7 +1366,7 @@ ENTRY(subyte)
ENTRY(copyinstr)
pushl %esi
pushl %edi
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $cpystrflt,PCB_ONFAULT(%ecx)
movl 12(%esp),%esi /* %esi = from */
@ -1414,7 +1414,7 @@ cpystrflt:
cpystrflt_x:
/* set *lencopied and return %eax */
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $0,PCB_ONFAULT(%ecx)
movl 20(%esp),%ecx
subl %edx,%ecx

View File

@ -241,7 +241,7 @@ ENTRY(i586_bzero)
* method. CR0_TS must be preserved although it is very likely to
* always end up as clear.
*/
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bz1
cmpl $256+184,%ecx /* empirical; not quite 2*108 more */
jb intreg_i586_bzero
@ -293,7 +293,7 @@ fpureg_i586_bzero_loop:
cmpl $8,%ecx
jae fpureg_i586_bzero_loop
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bz3
frstor 0(%esp)
addl $108,%esp
@ -501,7 +501,7 @@ ENTRY(i586_bcopy)
sarb $1,kernel_fpu_lock
jc small_i586_bcopy
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bc1
smsw %dx
clts
@ -572,7 +572,7 @@ large_i586_bcopy_loop:
cmpl $64,%ecx
jae 4b
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bc2
frstor 0(%esp)
addl $108,%esp
@ -670,7 +670,7 @@ ENTRY(copyout)
jmp *_copyout_vector
ENTRY(generic_copyout)
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyout_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -781,7 +781,7 @@ done_copyout:
popl %edi
popl %esi
xorl %eax,%eax
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl %eax,PCB_ONFAULT(%edx)
ret
@ -790,7 +790,7 @@ copyout_fault:
popl %ebx
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -800,7 +800,7 @@ ENTRY(i586_copyout)
/*
* Duplicated from generic_copyout. Could be done a bit better.
*/
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyout_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -857,7 +857,7 @@ ENTRY(copyin)
jmp *_copyin_vector
ENTRY(generic_copyin)
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyin_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -895,7 +895,7 @@ done_copyin:
popl %edi
popl %esi
xorl %eax,%eax
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl %eax,PCB_ONFAULT(%edx)
ret
@ -903,7 +903,7 @@ done_copyin:
copyin_fault:
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -913,7 +913,7 @@ ENTRY(i586_copyin)
/*
* Duplicated from generic_copyin. Could be done a bit better.
*/
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyin_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -967,13 +967,13 @@ ENTRY(fastmove)
jnz fastmove_tail
/* if (npxproc != NULL) { */
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je 6f
/* fnsave(&curpcb->pcb_savefpu); */
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
fnsave PCB_SAVEFPU(%eax)
/* npxproc = NULL; */
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
/* } */
6:
/* now we own the FPU. */
@ -990,7 +990,7 @@ ENTRY(fastmove)
movl %esi,-8(%ebp)
movl %edi,-4(%ebp)
movl %esp,%edi
movl _curpcb,%esi
movl PCPU(CURPCB),%esi
addl $PCB_SAVEFPU,%esi
cld
movl $PCB_SAVEFPU_SIZE>>2,%ecx
@ -1002,9 +1002,9 @@ ENTRY(fastmove)
/* stop_emulating(); */
clts
/* npxproc = curproc; */
movl _curproc,%eax
movl %eax,_npxproc
movl _curpcb,%eax
movl PCPU(CURPROC),%eax
movl %eax,PCPU(NPXPROC)
movl PCPU(CURPCB),%eax
movl $fastmove_fault,PCB_ONFAULT(%eax)
4:
movl %ecx,-12(%ebp)
@ -1066,7 +1066,7 @@ fastmove_loop:
movl %ecx,-12(%ebp)
movl %esi,-8(%ebp)
movl %edi,-4(%ebp)
movl _curpcb,%edi
movl PCPU(CURPCB),%edi
addl $PCB_SAVEFPU,%edi
movl %esp,%esi
cld
@ -1082,11 +1082,11 @@ fastmove_loop:
orb $CR0_TS,%al
lmsw %ax
/* npxproc = NULL; */
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
ALIGN_TEXT
fastmove_tail:
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $fastmove_tail_fault,PCB_ONFAULT(%eax)
movb %cl,%al
@ -1105,7 +1105,7 @@ fastmove_tail:
ALIGN_TEXT
fastmove_fault:
movl _curpcb,%edi
movl PCPU(CURPCB),%edi
addl $PCB_SAVEFPU,%edi
movl %esp,%esi
cld
@ -1116,7 +1116,7 @@ fastmove_fault:
smsw %ax
orb $CR0_TS,%al
lmsw %ax
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
fastmove_tail_fault:
movl %ebp,%esp
@ -1125,7 +1125,7 @@ fastmove_tail_fault:
popl %ebx
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -1137,7 +1137,7 @@ fastmove_tail_fault:
* Fetch a byte (sword, word) from user memory
*/
ENTRY(fuword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx /* from */
@ -1163,7 +1163,7 @@ ENTRY(fuswintr)
* fusword - MP SAFE
*/
ENTRY(fusword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1178,7 +1178,7 @@ ENTRY(fusword)
* fubyte - MP SAFE
*/
ENTRY(fubyte)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1191,7 +1191,7 @@ ENTRY(fubyte)
ALIGN_TEXT
fusufault:
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
xorl %eax,%eax
movl %eax,PCB_ONFAULT(%ecx)
decl %eax
@ -1203,7 +1203,7 @@ fusufault:
* Write a byte (word, longword) to user memory
*/
ENTRY(suword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1247,7 +1247,7 @@ ENTRY(suword)
movl 8(%esp),%eax
movl %eax,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1255,7 +1255,7 @@ ENTRY(suword)
* susword - MP SAFE (if not I386_CPU)
*/
ENTRY(susword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1299,7 +1299,7 @@ ENTRY(susword)
movw 8(%esp),%ax
movw %ax,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx /* restore trashed register */
movl PCPU(CURPCB),%ecx /* restore trashed register */
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1308,7 +1308,7 @@ ENTRY(susword)
*/
ALTENTRY(suibyte)
ENTRY(subyte)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1351,7 +1351,7 @@ ENTRY(subyte)
movb 8(%esp),%al
movb %al,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx /* restore trashed register */
movl PCPU(CURPCB),%ecx /* restore trashed register */
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1366,7 +1366,7 @@ ENTRY(subyte)
ENTRY(copyinstr)
pushl %esi
pushl %edi
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $cpystrflt,PCB_ONFAULT(%ecx)
movl 12(%esp),%esi /* %esi = from */
@ -1414,7 +1414,7 @@ cpystrflt:
cpystrflt_x:
/* set *lencopied and return %eax */
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $0,PCB_ONFAULT(%ecx)
movl 20(%esp),%ecx
subl %edx,%ecx

View File

@ -82,7 +82,7 @@ ENTRY(cpu_throw)
ENTRY(cpu_switch)
/* switch to new process. first, save context as needed */
movl _curproc,%ecx
movl PCPU(CURPROC),%ecx
/* if no process to save, don't bother */
testl %ecx,%ecx
@ -95,7 +95,7 @@ ENTRY(cpu_switch)
#endif /* SMP */
movl P_VMSPACE(%ecx), %edx
#ifdef SMP
movl _cpuid, %eax
movl PCPU(CPUID), %eax
#else
xorl %eax, %eax
#endif /* SMP */
@ -142,7 +142,7 @@ ENTRY(cpu_switch)
#if NNPX > 0
/* have we used fp, and need a save? */
cmpl %ecx,_npxproc
cmpl %ecx,PCPU(NPXPROC)
jne 1f
addl $PCB_SAVEFPU,%edx /* h/w bugs make saving complicated */
pushl %edx
@ -158,10 +158,10 @@ sw1:
/* Stop scheduling if smp_active goes zero and we are not BSP */
cmpl $0,_smp_active
jne 1f
cmpl $0,_cpuid
cmpl $0,PCPU(CPUID)
je 1f
movl _idleproc, %eax
movl PCPU(IDLEPROC), %eax
jmp sw1b
1:
#endif
@ -181,7 +181,7 @@ sw1b:
movl %eax,%ecx
xorl %eax,%eax
andl $~AST_RESCHED,_astpending
andl $~AST_RESCHED,PCPU(ASTPENDING)
#ifdef INVARIANTS
cmpb $SRUN,P_STAT(%ecx)
@ -206,7 +206,7 @@ sw1b:
4:
#ifdef SMP
movl _cpuid, %esi
movl PCPU(CPUID), %esi
#else
xorl %esi, %esi
#endif
@ -220,19 +220,19 @@ sw1b:
/* update common_tss.tss_esp0 pointer */
movl %edx, %ebx /* pcb */
addl $(UPAGES * PAGE_SIZE - 16), %ebx
movl %ebx, _common_tss + TSS_ESP0
movl %ebx, PCPU(COMMON_TSS) + TSS_ESP0
btrl %esi, _private_tss
jae 3f
#ifdef SMP
movl $gd_common_tssd, %edi
movl $GD_COMMON_TSSD, %edi
addl %fs:0, %edi
#else
movl $_common_tssd, %edi
movl $PCPU(COMMON_TSSD), %edi
#endif
2:
/* move correct tss descriptor into GDT slot, then reload tr */
movl _tss_gdt, %ebx /* entry in GDT */
movl PCPU(TSS_GDT), %ebx /* entry in GDT */
movl 0(%edi), %eax
movl %eax, 0(%ebx)
movl 4(%edi), %eax
@ -242,7 +242,7 @@ sw1b:
3:
movl P_VMSPACE(%ecx), %ebx
#ifdef SMP
movl _cpuid, %eax
movl PCPU(CPUID), %eax
#else
xorl %eax, %eax
#endif
@ -265,11 +265,11 @@ sw1b:
andl $~APIC_TPR_PRIO, lapic_tpr
#endif /** CHEAP_TPR */
#endif /** GRAB_LOPRIO */
movl _cpuid,%eax
movl PCPU(CPUID),%eax
movb %al, P_ONCPU(%ecx)
#endif /* SMP */
movl %edx, _curpcb
movl %ecx, _curproc /* into next process */
movl %edx, PCPU(CURPCB)
movl %ecx, PCPU(CURPROC) /* into next process */
#ifdef SMP
/* XXX FIXME: we should be restoring the local APIC TPR */
@ -279,10 +279,10 @@ sw1b:
cmpl $0, PCB_USERLDT(%edx)
jnz 1f
movl __default_ldt,%eax
cmpl _currentldt,%eax
cmpl PCPU(CURRENTLDT),%eax
je 2f
lldt __default_ldt
movl %eax,_currentldt
movl %eax,PCPU(CURRENTLDT)
jmp 2f
1: pushl %edx
call _set_user_ldt
@ -320,7 +320,7 @@ cpu_switch_load_gs:
movl PCB_SCHEDNEST(%edx),%eax
movl %eax,_sched_lock+MTX_RECURSE
movl _curproc,%eax
movl PCPU(CURPROC),%eax
movl %eax,_sched_lock+MTX_LOCK
ret
@ -376,7 +376,7 @@ ENTRY(savectx)
* have to handle h/w bugs for reloading. We used to lose the
* parent's npx state for forks by forgetting to reload.
*/
movl _npxproc,%eax
movl PCPU(NPXPROC),%eax
testl %eax,%eax
je 1f

View File

@ -69,6 +69,12 @@
#define NON_GPROF_ENTRY(name) GEN_ENTRY(name)
#define NON_GPROF_RET .byte 0xc3 /* opcode for `ret' */
#ifdef SMP
#define PCPU(member) %fs:GD_ ## member
#else
#define PCPU(member) CNAME(globaldata) + GD_ ## member
#endif
#ifdef GPROF
/*
* __mcount is like [.]mcount except that doesn't require its caller to set

View File

@ -60,7 +60,7 @@ IDTVEC(vec_name) ; \
mov %ax,%es ; \
mov %ax,%fs ; \
FAKE_MCOUNT((12+ACTUALLY_PUSHED)*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
enable_icus ; /* (re)enable ASAP (helps edge trigger?) */ \
@ -100,7 +100,7 @@ IDTVEC(vec_name) ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \
outb %al,$icu+ICU_IMR_OFFSET ; \
enable_icus ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
__CONCAT(Xresume,irq_num): ; \
FAKE_MCOUNT(13*4(%esp)) ; /* XXX late to avoid double count */ \
pushl $irq_num; /* pass the IRQ */ \

View File

@ -60,7 +60,7 @@ IDTVEC(vec_name) ; \
mov %ax,%es ; \
mov %ax,%fs ; \
FAKE_MCOUNT((12+ACTUALLY_PUSHED)*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
enable_icus ; /* (re)enable ASAP (helps edge trigger?) */ \
@ -100,7 +100,7 @@ IDTVEC(vec_name) ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \
outb %al,$icu+ICU_IMR_OFFSET ; \
enable_icus ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
__CONCAT(Xresume,irq_num): ; \
FAKE_MCOUNT(13*4(%esp)) ; /* XXX late to avoid double count */ \
pushl $irq_num; /* pass the IRQ */ \

View File

@ -60,7 +60,7 @@ IDTVEC(vec_name) ; \
mov %ax,%es ; \
mov %ax,%fs ; \
FAKE_MCOUNT((12+ACTUALLY_PUSHED)*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
enable_icus ; /* (re)enable ASAP (helps edge trigger?) */ \
@ -100,7 +100,7 @@ IDTVEC(vec_name) ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \
outb %al,$icu+ICU_IMR_OFFSET ; \
enable_icus ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
__CONCAT(Xresume,irq_num): ; \
FAKE_MCOUNT(13*4(%esp)) ; /* XXX late to avoid double count */ \
pushl $irq_num; /* pass the IRQ */ \

View File

@ -48,7 +48,7 @@ IDTVEC(vec_name) ; \
movl $KPSEL,%eax ; \
mov %ax,%fs ; \
FAKE_MCOUNT(13*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
addl $4, %esp ; \
@ -136,7 +136,7 @@ log_intr_event:
addl $4, %esp
movl CNAME(apic_itrace_debugbuffer_idx), %ecx
andl $32767, %ecx
movl _cpuid, %eax
movl PCPU(CPUID), %eax
shll $8, %eax
orl 8(%esp), %eax
movw %ax, CNAME(apic_itrace_debugbuffer)(,%ecx,2)
@ -218,7 +218,7 @@ IDTVEC(vec_name) ; \
MASK_LEVEL_IRQ(irq_num) ; \
EOI_IRQ(irq_num) ; \
0: ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
; \
/* entry point used by doreti_unpend for HWIs. */ \
__CONCAT(Xresume,irq_num): ; \
@ -263,7 +263,7 @@ _Xinvltlb:
pushl %fs
movl $KPSEL, %eax
mov %ax, %fs
movl _cpuid, %eax
movl PCPU(CPUID), %eax
popl %fs
ss
incl _xhits(,%eax,4)
@ -321,10 +321,11 @@ _Xcpucheckstate:
jne 1f
incl %ebx /* system or interrupt */
1:
movl _cpuid, %eax
movl PCPU(CPUID), %eax
movl %ebx, _checkstate_cpustate(,%eax,4)
movl _curproc, %ebx
movl PCPU(CURPROC), %ebx
movl %ebx, _checkstate_curproc(,%eax,4)
movl 16(%esp), %ebx
movl %ebx, _checkstate_pc(,%eax,4)
@ -358,7 +359,7 @@ _Xcpuast:
movl $KPSEL, %eax
mov %ax, %fs
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock /* checkstate_need_ast &= ~(1<<id) */
btrl %eax, _checkstate_need_ast
movl $0, lapic_eoi /* End Of Interrupt to APIC */
@ -369,17 +370,17 @@ _Xcpuast:
FAKE_MCOUNT(13*4(%esp))
orl $AST_PENDING, _astpending /* XXX */
incb _intr_nesting_level
orl $AST_PENDING, PCPU(ASTPENDING) /* XXX */
incb PCPU(INTR_NESTING_LEVEL)
sti
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock
btrl %eax, _checkstate_pending_ast
lock
btrl %eax, CNAME(resched_cpus)
jnc 2f
orl $AST_PENDING+AST_RESCHED, _astpending
orl $AST_PENDING+AST_RESCHED, PCPU(ASTPENDING)
lock
incl CNAME(want_resched_cnt)
2:
@ -414,10 +415,10 @@ _Xforward_irq:
lock
incl CNAME(forward_irq_hitcnt)
cmpb $4, _intr_nesting_level
cmpb $4, PCPU(INTR_NESTING_LEVEL)
jae 1f
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
sti
MEXITCOUNT
@ -499,7 +500,7 @@ _Xcpustop:
movl $0, lapic_eoi /* End Of Interrupt to APIC */
movl _cpuid, %eax
movl PCPU(CPUID), %eax
imull $PCB_SIZE, %eax
leal CNAME(stoppcbs)(%eax), %eax
pushl %eax
@ -507,7 +508,7 @@ _Xcpustop:
addl $4, %esp
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock
btsl %eax, _stopped_cpus /* stopped_cpus |= (1<<id) */

View File

@ -184,7 +184,7 @@ IDTVEC(fpu)
call __mtx_exit_giant_def
addl $4,%esp
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
#else /* NNPX > 0 */
@ -223,7 +223,7 @@ calltrap:
/*
* Return via _doreti to handle ASTs.
*/
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
@ -262,9 +262,9 @@ IDTVEC(syscall)
call _syscall2
MEXITCOUNT
cli /* atomic astpending access */
cmpl $0,_astpending /* AST pending? */
cmpl $0,PCPU(ASTPENDING) /* AST pending? */
je doreti_syscall_ret /* no, get out of here */
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
jmp _doreti
/*
@ -294,9 +294,9 @@ IDTVEC(int0x80_syscall)
call _syscall2
MEXITCOUNT
cli /* atomic astpending access */
cmpl $0,_astpending /* AST pending? */
cmpl $0,PCPU(ASTPENDING) /* AST pending? */
je doreti_syscall_ret /* no, get out of here */
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
jmp _doreti
ENTRY(fork_trampoline)
@ -306,15 +306,15 @@ ENTRY(fork_trampoline)
are enabled */
#ifdef SMP
cmpl $0,_switchtime
cmpl $0,PCPU(SWITCHTIME)
jne 1f
movl $gd_switchtime,%eax
movl $GD_SWITCHTIME,%eax
addl %fs:0,%eax
pushl %eax
call _microuptime
popl %edx
movl _ticks,%eax
movl %eax,_switchticks
movl %eax,PCPU(SWITCHTICKS)
1:
#endif
@ -331,7 +331,7 @@ ENTRY(fork_trampoline)
/*
* Return via _doreti to handle ASTs.
*/
movb $1,_intr_nesting_level
movb $1,PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti

View File

@ -35,6 +35,8 @@
#include <machine/smptests.h> /** FAST_HI */
#include "assym.s"
/*
* The following impliments the primitives described in i386/i386/param.h
* necessary for the Lite2 lock manager system.
@ -105,7 +107,7 @@ gotit:
ENTRY(s_lock)
movl 4(%esp), %edx /* get the address of the lock */
setlock:
movl _cpu_lockid, %ecx /* add cpu id portion */
movl PCPU(CPU_LOCKID), %ecx /* add cpu id portion */
incl %ecx /* add lock portion */
movl $0, %eax
lock
@ -113,7 +115,7 @@ setlock:
jz gotit /* it was clear, return */
pushl %eax /* save what we xchanged */
decl %eax /* remove lock portion */
cmpl _cpu_lockid, %eax /* do we hold it? */
cmpl PCPU(CPU_LOCKID), %eax /* do we hold it? */
je bad_slock /* yes, thats not good... */
addl $4, %esp /* clear the stack */
wait:
@ -127,7 +129,7 @@ gotit:
bad_slock:
/* %eax (current lock) is already on the stack */
pushl %edx
pushl _cpuid
pushl PCPU(CPUID)
pushl $bsl1
call _panic
@ -160,7 +162,7 @@ ENTRY(s_lock_try)
ENTRY(s_lock_try)
movl 4(%esp), %edx /* get the address of the lock */
movl _cpu_lockid, %ecx /* add cpu id portion */
movl PCPU(CPU_LOCKID), %ecx /* add cpu id portion */
incl %ecx /* add lock portion */
xorl %eax, %eax
@ -227,7 +229,7 @@ swait:
jne swait /* still set... */
jmp ssetlock /* empty again, try once more */
sgotit:
popl _ss_eflags /* save the old eflags */
popl PCPU(SS_EFLAGS) /* save the old eflags */
ret
#else /* SL_DEBUG */
@ -235,7 +237,7 @@ sgotit:
ENTRY(ss_lock)
movl 4(%esp), %edx /* get the address of the lock */
ssetlock:
movl _cpu_lockid, %ecx /* add cpu id portion */
movl PCPU(CPU_LOCKID), %ecx /* add cpu id portion */
incl %ecx /* add lock portion */
pushfl
cli
@ -245,7 +247,7 @@ ssetlock:
jz sgotit /* it was clear, return */
pushl %eax /* save what we xchanged */
decl %eax /* remove lock portion */
cmpl _cpu_lockid, %eax /* do we hold it? */
cmpl PCPU(CPU_LOCKID), %eax /* do we hold it? */
je sbad_slock /* yes, thats not good... */
addl $4, %esp /* clear the stack */
popfl
@ -254,7 +256,7 @@ swait:
jne swait /* still set... */
jmp ssetlock /* empty again, try once more */
sgotit:
popl _ss_eflags /* save the old task priority */
popl PCPU(SS_EFLAGS) /* save the old task priority */
sgotit2:
ret
@ -262,7 +264,7 @@ sgotit2:
sbad_slock:
/* %eax (current lock) is already on the stack */
pushl %edx
pushl _cpuid
pushl PCPU(CPUID)
pushl $sbsl1
call _panic
@ -276,7 +278,7 @@ sbsl1: .asciz "rsslock: cpu: %d, addr: 0x%08x, lock: 0x%08x"
ENTRY(ss_unlock)
movl 4(%esp), %eax /* get the address of the lock */
movl $0, (%eax) /* clear the simple lock */
testl $PSL_I, _ss_eflags
testl $PSL_I, PCPU(SS_EFLAGS)
jz ss_unlock2
sti
ss_unlock2:

View File

@ -241,7 +241,7 @@ ENTRY(i586_bzero)
* method. CR0_TS must be preserved although it is very likely to
* always end up as clear.
*/
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bz1
cmpl $256+184,%ecx /* empirical; not quite 2*108 more */
jb intreg_i586_bzero
@ -293,7 +293,7 @@ fpureg_i586_bzero_loop:
cmpl $8,%ecx
jae fpureg_i586_bzero_loop
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bz3
frstor 0(%esp)
addl $108,%esp
@ -501,7 +501,7 @@ ENTRY(i586_bcopy)
sarb $1,kernel_fpu_lock
jc small_i586_bcopy
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bc1
smsw %dx
clts
@ -572,7 +572,7 @@ large_i586_bcopy_loop:
cmpl $64,%ecx
jae 4b
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je i586_bc2
frstor 0(%esp)
addl $108,%esp
@ -670,7 +670,7 @@ ENTRY(copyout)
jmp *_copyout_vector
ENTRY(generic_copyout)
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyout_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -781,7 +781,7 @@ done_copyout:
popl %edi
popl %esi
xorl %eax,%eax
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl %eax,PCB_ONFAULT(%edx)
ret
@ -790,7 +790,7 @@ copyout_fault:
popl %ebx
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -800,7 +800,7 @@ ENTRY(i586_copyout)
/*
* Duplicated from generic_copyout. Could be done a bit better.
*/
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyout_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -857,7 +857,7 @@ ENTRY(copyin)
jmp *_copyin_vector
ENTRY(generic_copyin)
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyin_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -895,7 +895,7 @@ done_copyin:
popl %edi
popl %esi
xorl %eax,%eax
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl %eax,PCB_ONFAULT(%edx)
ret
@ -903,7 +903,7 @@ done_copyin:
copyin_fault:
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -913,7 +913,7 @@ ENTRY(i586_copyin)
/*
* Duplicated from generic_copyin. Could be done a bit better.
*/
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $copyin_fault,PCB_ONFAULT(%eax)
pushl %esi
pushl %edi
@ -967,13 +967,13 @@ ENTRY(fastmove)
jnz fastmove_tail
/* if (npxproc != NULL) { */
cmpl $0,_npxproc
cmpl $0,PCPU(NPXPROC)
je 6f
/* fnsave(&curpcb->pcb_savefpu); */
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
fnsave PCB_SAVEFPU(%eax)
/* npxproc = NULL; */
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
/* } */
6:
/* now we own the FPU. */
@ -990,7 +990,7 @@ ENTRY(fastmove)
movl %esi,-8(%ebp)
movl %edi,-4(%ebp)
movl %esp,%edi
movl _curpcb,%esi
movl PCPU(CURPCB),%esi
addl $PCB_SAVEFPU,%esi
cld
movl $PCB_SAVEFPU_SIZE>>2,%ecx
@ -1002,9 +1002,9 @@ ENTRY(fastmove)
/* stop_emulating(); */
clts
/* npxproc = curproc; */
movl _curproc,%eax
movl %eax,_npxproc
movl _curpcb,%eax
movl PCPU(CURPROC),%eax
movl %eax,PCPU(NPXPROC)
movl PCPU(CURPCB),%eax
movl $fastmove_fault,PCB_ONFAULT(%eax)
4:
movl %ecx,-12(%ebp)
@ -1066,7 +1066,7 @@ fastmove_loop:
movl %ecx,-12(%ebp)
movl %esi,-8(%ebp)
movl %edi,-4(%ebp)
movl _curpcb,%edi
movl PCPU(CURPCB),%edi
addl $PCB_SAVEFPU,%edi
movl %esp,%esi
cld
@ -1082,11 +1082,11 @@ fastmove_loop:
orb $CR0_TS,%al
lmsw %ax
/* npxproc = NULL; */
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
ALIGN_TEXT
fastmove_tail:
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
movl $fastmove_tail_fault,PCB_ONFAULT(%eax)
movb %cl,%al
@ -1105,7 +1105,7 @@ fastmove_tail:
ALIGN_TEXT
fastmove_fault:
movl _curpcb,%edi
movl PCPU(CURPCB),%edi
addl $PCB_SAVEFPU,%edi
movl %esp,%esi
cld
@ -1116,7 +1116,7 @@ fastmove_fault:
smsw %ax
orb $CR0_TS,%al
lmsw %ax
movl $0,_npxproc
movl $0,PCPU(NPXPROC)
fastmove_tail_fault:
movl %ebp,%esp
@ -1125,7 +1125,7 @@ fastmove_tail_fault:
popl %ebx
popl %edi
popl %esi
movl _curpcb,%edx
movl PCPU(CURPCB),%edx
movl $0,PCB_ONFAULT(%edx)
movl $EFAULT,%eax
ret
@ -1137,7 +1137,7 @@ fastmove_tail_fault:
* Fetch a byte (sword, word) from user memory
*/
ENTRY(fuword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx /* from */
@ -1163,7 +1163,7 @@ ENTRY(fuswintr)
* fusword - MP SAFE
*/
ENTRY(fusword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1178,7 +1178,7 @@ ENTRY(fusword)
* fubyte - MP SAFE
*/
ENTRY(fubyte)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1191,7 +1191,7 @@ ENTRY(fubyte)
ALIGN_TEXT
fusufault:
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
xorl %eax,%eax
movl %eax,PCB_ONFAULT(%ecx)
decl %eax
@ -1203,7 +1203,7 @@ fusufault:
* Write a byte (word, longword) to user memory
*/
ENTRY(suword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1247,7 +1247,7 @@ ENTRY(suword)
movl 8(%esp),%eax
movl %eax,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1255,7 +1255,7 @@ ENTRY(suword)
* susword - MP SAFE (if not I386_CPU)
*/
ENTRY(susword)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1299,7 +1299,7 @@ ENTRY(susword)
movw 8(%esp),%ax
movw %ax,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx /* restore trashed register */
movl PCPU(CURPCB),%ecx /* restore trashed register */
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1308,7 +1308,7 @@ ENTRY(susword)
*/
ALTENTRY(suibyte)
ENTRY(subyte)
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $fusufault,PCB_ONFAULT(%ecx)
movl 4(%esp),%edx
@ -1351,7 +1351,7 @@ ENTRY(subyte)
movb 8(%esp),%al
movb %al,(%edx)
xorl %eax,%eax
movl _curpcb,%ecx /* restore trashed register */
movl PCPU(CURPCB),%ecx /* restore trashed register */
movl %eax,PCB_ONFAULT(%ecx)
ret
@ -1366,7 +1366,7 @@ ENTRY(subyte)
ENTRY(copyinstr)
pushl %esi
pushl %edi
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $cpystrflt,PCB_ONFAULT(%ecx)
movl 12(%esp),%esi /* %esi = from */
@ -1414,7 +1414,7 @@ cpystrflt:
cpystrflt_x:
/* set *lencopied and return %eax */
movl _curpcb,%ecx
movl PCPU(CURPCB),%ecx
movl $0,PCB_ONFAULT(%ecx)
movl 20(%esp),%ecx
subl %edx,%ecx

View File

@ -82,7 +82,7 @@ ENTRY(cpu_throw)
ENTRY(cpu_switch)
/* switch to new process. first, save context as needed */
movl _curproc,%ecx
movl PCPU(CURPROC),%ecx
/* if no process to save, don't bother */
testl %ecx,%ecx
@ -95,7 +95,7 @@ ENTRY(cpu_switch)
#endif /* SMP */
movl P_VMSPACE(%ecx), %edx
#ifdef SMP
movl _cpuid, %eax
movl PCPU(CPUID), %eax
#else
xorl %eax, %eax
#endif /* SMP */
@ -142,7 +142,7 @@ ENTRY(cpu_switch)
#if NNPX > 0
/* have we used fp, and need a save? */
cmpl %ecx,_npxproc
cmpl %ecx,PCPU(NPXPROC)
jne 1f
addl $PCB_SAVEFPU,%edx /* h/w bugs make saving complicated */
pushl %edx
@ -158,10 +158,10 @@ sw1:
/* Stop scheduling if smp_active goes zero and we are not BSP */
cmpl $0,_smp_active
jne 1f
cmpl $0,_cpuid
cmpl $0,PCPU(CPUID)
je 1f
movl _idleproc, %eax
movl PCPU(IDLEPROC), %eax
jmp sw1b
1:
#endif
@ -181,7 +181,7 @@ sw1b:
movl %eax,%ecx
xorl %eax,%eax
andl $~AST_RESCHED,_astpending
andl $~AST_RESCHED,PCPU(ASTPENDING)
#ifdef INVARIANTS
cmpb $SRUN,P_STAT(%ecx)
@ -206,7 +206,7 @@ sw1b:
4:
#ifdef SMP
movl _cpuid, %esi
movl PCPU(CPUID), %esi
#else
xorl %esi, %esi
#endif
@ -220,19 +220,19 @@ sw1b:
/* update common_tss.tss_esp0 pointer */
movl %edx, %ebx /* pcb */
addl $(UPAGES * PAGE_SIZE - 16), %ebx
movl %ebx, _common_tss + TSS_ESP0
movl %ebx, PCPU(COMMON_TSS) + TSS_ESP0
btrl %esi, _private_tss
jae 3f
#ifdef SMP
movl $gd_common_tssd, %edi
movl $GD_COMMON_TSSD, %edi
addl %fs:0, %edi
#else
movl $_common_tssd, %edi
movl $PCPU(COMMON_TSSD), %edi
#endif
2:
/* move correct tss descriptor into GDT slot, then reload tr */
movl _tss_gdt, %ebx /* entry in GDT */
movl PCPU(TSS_GDT), %ebx /* entry in GDT */
movl 0(%edi), %eax
movl %eax, 0(%ebx)
movl 4(%edi), %eax
@ -242,7 +242,7 @@ sw1b:
3:
movl P_VMSPACE(%ecx), %ebx
#ifdef SMP
movl _cpuid, %eax
movl PCPU(CPUID), %eax
#else
xorl %eax, %eax
#endif
@ -265,11 +265,11 @@ sw1b:
andl $~APIC_TPR_PRIO, lapic_tpr
#endif /** CHEAP_TPR */
#endif /** GRAB_LOPRIO */
movl _cpuid,%eax
movl PCPU(CPUID),%eax
movb %al, P_ONCPU(%ecx)
#endif /* SMP */
movl %edx, _curpcb
movl %ecx, _curproc /* into next process */
movl %edx, PCPU(CURPCB)
movl %ecx, PCPU(CURPROC) /* into next process */
#ifdef SMP
/* XXX FIXME: we should be restoring the local APIC TPR */
@ -279,10 +279,10 @@ sw1b:
cmpl $0, PCB_USERLDT(%edx)
jnz 1f
movl __default_ldt,%eax
cmpl _currentldt,%eax
cmpl PCPU(CURRENTLDT),%eax
je 2f
lldt __default_ldt
movl %eax,_currentldt
movl %eax,PCPU(CURRENTLDT)
jmp 2f
1: pushl %edx
call _set_user_ldt
@ -320,7 +320,7 @@ cpu_switch_load_gs:
movl PCB_SCHEDNEST(%edx),%eax
movl %eax,_sched_lock+MTX_RECURSE
movl _curproc,%eax
movl PCPU(CURPROC),%eax
movl %eax,_sched_lock+MTX_LOCK
ret
@ -376,7 +376,7 @@ ENTRY(savectx)
* have to handle h/w bugs for reloading. We used to lose the
* parent's npx state for forks by forgetting to reload.
*/
movl _npxproc,%eax
movl PCPU(NPXPROC),%eax
testl %eax,%eax
je 1f

View File

@ -63,8 +63,8 @@ ENTRY(vm86_bioscall)
pushl %gs
#if NNPX > 0
movl _curproc,%ecx
cmpl %ecx,_npxproc /* do we need to save fp? */
movl PCPU(CURPROC),%ecx
cmpl %ecx,PCPU(NPXPROC) /* do we need to save fp? */
jne 1f
testl %ecx,%ecx
je 1f /* no curproc/npxproc */
@ -86,11 +86,11 @@ ENTRY(vm86_bioscall)
rep
movsl /* copy frame to new stack */
movl _curpcb,%eax
movl PCPU(CURPCB),%eax
pushl %eax /* save curpcb */
movl %edx,_curpcb /* set curpcb to vm86pcb */
movl %edx,PCPU(CURPCB) /* set curpcb to vm86pcb */
movl _tss_gdt,%ebx /* entry in GDT */
movl PCPU(TSS_GDT),%ebx /* entry in GDT */
movl 0(%ebx),%eax
movl %eax,SCR_TSS0(%edx) /* save first word */
movl 4(%ebx),%eax
@ -129,7 +129,7 @@ ENTRY(vm86_bioscall)
/*
* Return via _doreti
*/
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
MEXITCOUNT
jmp _doreti
@ -156,7 +156,7 @@ ENTRY(vm86_biosret)
movl $0,_in_vm86call /* reset trapflag */
movl _tss_gdt,%ebx /* entry in GDT */
movl PCPU(TSS_GDT),%ebx /* entry in GDT */
movl SCR_TSS0(%edx),%eax
movl %eax,0(%ebx) /* restore first word */
movl SCR_TSS1(%edx),%eax
@ -164,7 +164,7 @@ ENTRY(vm86_biosret)
movl $GPROC0_SEL*8,%esi /* GSEL(entry, SEL_KPL) */
ltr %si
popl _curpcb /* restore curpcb/curproc */
popl PCPU(CURPCB) /* restore curpcb/curproc */
movl SCR_ARGFRAME(%edx),%edx /* original stack frame */
movl TF_TRAPNO(%edx),%eax /* return (trapno) */

View File

@ -69,6 +69,12 @@
#define NON_GPROF_ENTRY(name) GEN_ENTRY(name)
#define NON_GPROF_RET .byte 0xc3 /* opcode for `ret' */
#ifdef SMP
#define PCPU(member) %fs:GD_ ## member
#else
#define PCPU(member) CNAME(globaldata) + GD_ ## member
#endif
#ifdef GPROF
/*
* __mcount is like [.]mcount except that doesn't require its caller to set

View File

@ -48,7 +48,7 @@ IDTVEC(vec_name) ; \
movl $KPSEL,%eax ; \
mov %ax,%fs ; \
FAKE_MCOUNT(13*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
addl $4, %esp ; \
@ -136,7 +136,7 @@ log_intr_event:
addl $4, %esp
movl CNAME(apic_itrace_debugbuffer_idx), %ecx
andl $32767, %ecx
movl _cpuid, %eax
movl PCPU(CPUID), %eax
shll $8, %eax
orl 8(%esp), %eax
movw %ax, CNAME(apic_itrace_debugbuffer)(,%ecx,2)
@ -218,7 +218,7 @@ IDTVEC(vec_name) ; \
MASK_LEVEL_IRQ(irq_num) ; \
EOI_IRQ(irq_num) ; \
0: ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
; \
/* entry point used by doreti_unpend for HWIs. */ \
__CONCAT(Xresume,irq_num): ; \
@ -263,7 +263,7 @@ _Xinvltlb:
pushl %fs
movl $KPSEL, %eax
mov %ax, %fs
movl _cpuid, %eax
movl PCPU(CPUID), %eax
popl %fs
ss
incl _xhits(,%eax,4)
@ -321,10 +321,11 @@ _Xcpucheckstate:
jne 1f
incl %ebx /* system or interrupt */
1:
movl _cpuid, %eax
movl PCPU(CPUID), %eax
movl %ebx, _checkstate_cpustate(,%eax,4)
movl _curproc, %ebx
movl PCPU(CURPROC), %ebx
movl %ebx, _checkstate_curproc(,%eax,4)
movl 16(%esp), %ebx
movl %ebx, _checkstate_pc(,%eax,4)
@ -358,7 +359,7 @@ _Xcpuast:
movl $KPSEL, %eax
mov %ax, %fs
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock /* checkstate_need_ast &= ~(1<<id) */
btrl %eax, _checkstate_need_ast
movl $0, lapic_eoi /* End Of Interrupt to APIC */
@ -369,17 +370,17 @@ _Xcpuast:
FAKE_MCOUNT(13*4(%esp))
orl $AST_PENDING, _astpending /* XXX */
incb _intr_nesting_level
orl $AST_PENDING, PCPU(ASTPENDING) /* XXX */
incb PCPU(INTR_NESTING_LEVEL)
sti
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock
btrl %eax, _checkstate_pending_ast
lock
btrl %eax, CNAME(resched_cpus)
jnc 2f
orl $AST_PENDING+AST_RESCHED, _astpending
orl $AST_PENDING+AST_RESCHED, PCPU(ASTPENDING)
lock
incl CNAME(want_resched_cnt)
2:
@ -414,10 +415,10 @@ _Xforward_irq:
lock
incl CNAME(forward_irq_hitcnt)
cmpb $4, _intr_nesting_level
cmpb $4, PCPU(INTR_NESTING_LEVEL)
jae 1f
incb _intr_nesting_level
incb PCPU(INTR_NESTING_LEVEL)
sti
MEXITCOUNT
@ -499,7 +500,7 @@ _Xcpustop:
movl $0, lapic_eoi /* End Of Interrupt to APIC */
movl _cpuid, %eax
movl PCPU(CPUID), %eax
imull $PCB_SIZE, %eax
leal CNAME(stoppcbs)(%eax), %eax
pushl %eax
@ -507,7 +508,7 @@ _Xcpustop:
addl $4, %esp
movl _cpuid, %eax
movl PCPU(CPUID), %eax
lock
btsl %eax, _stopped_cpus /* stopped_cpus |= (1<<id) */

View File

@ -60,7 +60,7 @@ IDTVEC(vec_name) ; \
mov %ax,%es ; \
mov %ax,%fs ; \
FAKE_MCOUNT((12+ACTUALLY_PUSHED)*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
enable_icus ; /* (re)enable ASAP (helps edge trigger?) */ \
@ -100,7 +100,7 @@ IDTVEC(vec_name) ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \
outb %al,$icu+ICU_IMR_OFFSET ; \
enable_icus ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
__CONCAT(Xresume,irq_num): ; \
FAKE_MCOUNT(13*4(%esp)) ; /* XXX late to avoid double count */ \
pushl $irq_num; /* pass the IRQ */ \

View File

@ -60,7 +60,7 @@ IDTVEC(vec_name) ; \
mov %ax,%es ; \
mov %ax,%fs ; \
FAKE_MCOUNT((12+ACTUALLY_PUSHED)*4(%esp)) ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
pushl _intr_unit + (irq_num) * 4 ; \
call *_intr_handler + (irq_num) * 4 ; /* do the work ASAP */ \
enable_icus ; /* (re)enable ASAP (helps edge trigger?) */ \
@ -100,7 +100,7 @@ IDTVEC(vec_name) ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \
outb %al,$icu+ICU_IMR_OFFSET ; \
enable_icus ; \
incb _intr_nesting_level ; \
incb PCPU(INTR_NESTING_LEVEL) ; \
__CONCAT(Xresume,irq_num): ; \
FAKE_MCOUNT(13*4(%esp)) ; /* XXX late to avoid double count */ \
pushl $irq_num; /* pass the IRQ */ \

View File

@ -80,10 +80,10 @@ _softtty_imask: .long 0
_doreti:
FAKE_MCOUNT(_bintr) /* init "from" _bintr -> _doreti */
doreti_next:
decb _intr_nesting_level
decb PCPU(INTR_NESTING_LEVEL)
/* Check for ASTs that can be handled now. */
testl $AST_PENDING,_astpending
testl $AST_PENDING,PCPU(ASTPENDING)
je doreti_exit /* no AST, exit */
testb $SEL_RPL_MASK,TF_CS(%esp) /* are we in user mode? */
jne doreti_ast /* yes, do it now. */
@ -147,11 +147,11 @@ doreti_popl_fs_fault:
ALIGN_TEXT
doreti_ast:
andl $~AST_PENDING,_astpending
andl $~AST_PENDING,PCPU(ASTPENDING)
sti
movl $T_ASTFLT,TF_TRAPNO(%esp)
call _ast
movb $1,_intr_nesting_level /* for doreti_next to decrement */
movb $1,PCPU(INTR_NESTING_LEVEL) /* for doreti_next to decrement */
jmp doreti_next
#ifdef APIC_IO