PERFORCE change 136413 for review

Randall R. Stewart rrs at FreeBSD.org
Fri Feb 29 19:47:43 UTC 2008


http://perforce.freebsd.org/chv.cgi?CH=136413

Change 136413 by rrs at rrs-mips2-jnpr on 2008/02/28 09:35:01

	make context use pnemonics too.

Affected files ...

.. //depot/projects/mips2-jnpr/src/sys/mips/mips/vm_machdep.c#18 edit

Differences ...

==== //depot/projects/mips2-jnpr/src/sys/mips/mips/vm_machdep.c#18 (text+ko) ====

@@ -155,14 +155,14 @@
 	if (td1 == PCPU_GET(fpcurthread))
 		MipsSaveCurFPState(td1);
 
-	pcb2->pcb_context.val[10] = (register_t)fork_trampoline;
+	pcb2->pcb_context.val[PCB_REG_RA] = (register_t)fork_trampoline;
 	/* Make sp 64-bit aligned */
-	pcb2->pcb_context.val[8] = (register_t)(((vm_offset_t)td2->td_pcb &
+	pcb2->pcb_context.val[PCB_REG_SP] = (register_t)(((vm_offset_t)td2->td_pcb &
 	    ~(sizeof(__int64_t) - 1)) - STAND_FRAME_SIZE);
-	pcb2->pcb_context.val[0] = (register_t)fork_return;
-	pcb2->pcb_context.val[1] = (register_t)td2;
-	pcb2->pcb_context.val[2] = (register_t)td2->td_frame;
-	pcb2->pcb_context.val[11] = SR_INT_MASK;   /* SR */
+	pcb2->pcb_context.val[PCB_REG_S0] = (register_t)fork_return;
+	pcb2->pcb_context.val[PCB_REG_S1] = (register_t)td2;
+	pcb2->pcb_context.val[PCB_REG_S2] = (register_t)td2->td_frame;
+	pcb2->pcb_context.val[PCB_REG_SR] = SR_INT_MASK;   /* SR */
 	/*
 	 * FREEBSD_DEVELOPERS_FIXME:
 	 * Setup any other CPU-Specific registers (Not MIPS Standard)
@@ -173,7 +173,7 @@
 	td2->td_md.md_saved_intr = 1;
 	td2->td_md.md_spinlock_count = 1;
 #ifdef TARGET_OCTEON
-	pcb2->pcb_context.val[11] |= MIPS_SR_COP_2_BIT | MIPS32_SR_PX | MIPS_SR_UX | MIPS_SR_KX | MIPS_SR_SX;
+	pcb2->pcb_context.val[PCB_REG_SR] |= MIPS_SR_COP_2_BIT | MIPS32_SR_PX | MIPS_SR_UX | MIPS_SR_KX | MIPS_SR_SX;
 #endif
 
 }
@@ -191,8 +191,8 @@
 	 * Note that the trap frame follows the args, so the function
 	 * is really called like this:	func(arg, frame);
 	 */
-	td->td_pcb->pcb_context.val[0] = (register_t) func;
-	td->td_pcb->pcb_context.val[1] = (register_t) arg;
+	td->td_pcb->pcb_context.val[PCB_REG_S0] = (register_t) func;
+	td->td_pcb->pcb_context.val[PCB_REG_S1] = (register_t) arg;
 }
 
 void
@@ -305,18 +305,18 @@
 	 * Set registers for trampoline to user mode.
 	 */
 
-	pcb2->pcb_context.val[10] = (register_t)fork_trampoline;
+	pcb2->pcb_context.val[PCB_REG_RA] = (register_t)fork_trampoline;
 	/* Make sp 64-bit aligned */
-	pcb2->pcb_context.val[8] = (register_t)(((vm_offset_t)td->td_pcb &
+	pcb2->pcb_context.val[PCB_REG_SP] = (register_t)(((vm_offset_t)td->td_pcb &
 	    ~(sizeof(__int64_t) - 1)) - STAND_FRAME_SIZE);
-	pcb2->pcb_context.val[0] = (register_t)fork_return;
-	pcb2->pcb_context.val[1] = (register_t)td;
-	pcb2->pcb_context.val[2] = (register_t)td->td_frame;
+	pcb2->pcb_context.val[PCB_REG_S0] = (register_t)fork_return;
+	pcb2->pcb_context.val[PCB_REG_S1] = (register_t)td;
+	pcb2->pcb_context.val[PCB_REG_S2] = (register_t)td->td_frame;
 	/* Dont set IE bit in SR. sched lock release will take care of it */
 /* idle_mask is jmips pcb2->pcb_context.val[11] = (ALL_INT_MASK & idle_mask); */
-	pcb2->pcb_context.val[11] = 0;
+	pcb2->pcb_context.val[PCB_REG_SR] = 0;
 #ifdef TARGET_OCTEON
-	pcb2->pcb_context.val[11] |= MIPS_SR_COP_2_BIT | MIPS_SR_COP_0_BIT |
+	pcb2->pcb_context.val[PCB_REG_SR] |= MIPS_SR_COP_2_BIT | MIPS_SR_COP_0_BIT |
 	  MIPS32_SR_PX | MIPS_SR_UX | MIPS_SR_KX | MIPS_SR_SX;
 #endif
 


More information about the p4-projects mailing list