mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-16 10:20:30 +00:00
Add an implementation of cpu_throw() and make restorectx() simply branch
to the tail of cpu_switch.
This commit is contained in:
parent
f0ec35cae4
commit
a914a17e1d
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=92020
@ -105,56 +105,16 @@ ENTRY(savectx, 1)
|
||||
|
||||
ENTRY(restorectx, 1)
|
||||
|
||||
add r3=PCB_UNAT,in0 // point at NaT for r4..r7
|
||||
mov ar.rsc=0 ;; // switch off the RSE
|
||||
ld8 r16=[r3] // load NaT for r4..r7
|
||||
;;
|
||||
mov ar.unat=r16
|
||||
;;
|
||||
ld8.fill r4=[in0],8 ;; // restore r4
|
||||
ld8.fill r5=[in0],8 ;; // restore r5
|
||||
ld8.fill r6=[in0],8 ;; // restore r6
|
||||
ld8.fill r7=[in0],8 ;; // restore r7
|
||||
mov r15=in0
|
||||
br.cond.sptk.many 4f
|
||||
|
||||
ldf.fill f2=[in0],16 ;; // restore f2
|
||||
ldf.fill f3=[in0],16 ;; // restore f3
|
||||
ldf.fill f4=[in0],16 ;; // restore f4
|
||||
ldf.fill f5=[in0],16 ;; // restore f5
|
||||
END(restorectx)
|
||||
|
||||
ld8 r16=[in0],8 ;; // restore b0
|
||||
ld8 r17=[in0],8 ;; // restore b1
|
||||
ld8 r18=[in0],8 ;; // restore b2
|
||||
ld8 r19=[in0],8 ;; // restore b3
|
||||
ld8 r20=[in0],8 ;; // restore b4
|
||||
ld8 r21=[in0],8 ;; // restore b5
|
||||
ENTRY(cpu_throw, 0)
|
||||
|
||||
mov b0=r16
|
||||
mov b1=r17
|
||||
mov b2=r18
|
||||
mov b3=r19
|
||||
mov b4=r20
|
||||
mov b5=r21
|
||||
br.sptk.few 2f
|
||||
|
||||
ld8 r16=[in0],8 ;; // caller's ar.unat
|
||||
ld8 sp=[in0],8 ;; // stack pointer
|
||||
ld8 r17=[in0],8 ;; // ar.pfs
|
||||
ld8 r18=[in0],16 ;; // ar.bspstore, skip ar.unat
|
||||
ld8 r19=[in0],8 ;; // ar.rnat
|
||||
ld8 r20=[in0],8 ;; // pr
|
||||
|
||||
mov ar.unat=r16
|
||||
mov ar.pfs=r17
|
||||
mov ar.bspstore=r18 ;;
|
||||
mov ar.rnat=r19
|
||||
mov pr=r20,0x1ffff
|
||||
mov ret0=r18 // non-zero return
|
||||
;;
|
||||
loadrs
|
||||
mov ar.rsc=3 // restart RSE
|
||||
invala
|
||||
;;
|
||||
br.ret.sptk.few rp
|
||||
END(restorectx)
|
||||
END(cpu_throw)
|
||||
|
||||
ENTRY(cpu_switch, 0)
|
||||
|
||||
@ -225,35 +185,29 @@ ENTRY(cpu_switch, 0)
|
||||
add r16 = PC_IDLETHREAD, r13
|
||||
;;
|
||||
ld8 ret0 = [r16]
|
||||
br.sptk 2f
|
||||
br.sptk 3f
|
||||
1:
|
||||
#endif
|
||||
br.call.sptk.few rp=choosethread
|
||||
|
||||
2:
|
||||
srlz.i
|
||||
mf
|
||||
;;
|
||||
br.call.sptk.few rp=choosethread
|
||||
|
||||
3:
|
||||
add r14=PC_CURTHREAD,r13 ;;
|
||||
|
||||
#if 0
|
||||
ld8 r15 = [r14]
|
||||
;;
|
||||
cmp.ne p6,p0=r15,ret0 // chooseproc() == curthread ?
|
||||
(p6) br.dptk.few 1f
|
||||
;;
|
||||
add r17=TD_PCB,r15 ;; // restore b0
|
||||
ld8 r17=[r17] ;;
|
||||
add r17=PCB_B0,r17 ;;
|
||||
ld8 r17=[r17] ;;
|
||||
mov b0=r17
|
||||
|
||||
br.sptk.few 9f // don't bother to restore
|
||||
#endif
|
||||
|
||||
1:
|
||||
st8 [r14]=ret0 // set r13->pc_curthread
|
||||
mov ar.k7=ret0
|
||||
mov r4=ret0 // save from call
|
||||
;;
|
||||
alloc r15=ar.pfs,0,0,1,0 // create temporary output frame
|
||||
#ifdef SMP
|
||||
;;
|
||||
mov out0=1 // clear fpcurthread
|
||||
br.call.sptk.few rp=ia64_fpstate_save
|
||||
#endif
|
||||
;;
|
||||
mov out0=r4
|
||||
br.call.sptk.few rp=pmap_activate // install RIDs etc.
|
||||
@ -264,6 +218,7 @@ ENTRY(cpu_switch, 0)
|
||||
ld8 r16=[r16] ;;
|
||||
mov ar.k5=r16
|
||||
|
||||
4:
|
||||
add r3=PCB_UNAT,r15 // point at NaT for r4..r7
|
||||
mov ar.rsc=0 ;; // switch off the RSE
|
||||
ld8 r16=[r3] // load NaT for r4..r7
|
||||
@ -301,14 +256,14 @@ ENTRY(cpu_switch, 0)
|
||||
ld8 r19=[r15],8 ;; // ar.rnat
|
||||
ld8 r20=[r15] ;; // pr
|
||||
|
||||
loadrs // invalidate register stack
|
||||
;;
|
||||
mov ar.unat=r16
|
||||
mov ar.pfs=r17
|
||||
mov ar.bspstore=r18 ;;
|
||||
mov ar.rnat=r19
|
||||
mov pr=r20,0x1ffff
|
||||
alloc r14=ar.pfs,0,0,0,0 // lose current frame
|
||||
;;
|
||||
loadrs
|
||||
mov ar.rsc=3 // restart RSE
|
||||
invala
|
||||
;;
|
||||
|
@ -300,15 +300,6 @@ cpu_wait(p)
|
||||
{
|
||||
}
|
||||
|
||||
/* Temporary helper */
|
||||
void
|
||||
cpu_throw(void)
|
||||
{
|
||||
|
||||
cpu_switch();
|
||||
panic("cpu_throw() didn't");
|
||||
}
|
||||
|
||||
/*
|
||||
* Dump the machine specific header information at the start of a core dump.
|
||||
*/
|
||||
|
Loading…
Reference in New Issue
Block a user