diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2007-10-13 12:46:19 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2007-10-13 12:46:19 +0000 |
commit | 77f0ca66bb7937375fe67517f138e94df14f0cb1 (patch) | |
tree | fd1fa5c90a4526c96bad0d05f5a40500320fdbdc /sys | |
parent | d91ba7861afd6d6adc7164fd3c2b174b506c797d (diff) |
There is no need to fiddle with spl in cpu_idle_{enter,leave}, actually.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/arm/arm/cpuswitch.S | 28 | ||||
-rw-r--r-- | sys/arch/mips64/mips64/context.S | 37 |
2 files changed, 11 insertions, 54 deletions
diff --git a/sys/arch/arm/arm/cpuswitch.S b/sys/arch/arm/arm/cpuswitch.S index 544f7c27243..c167c3c5de9 100644 --- a/sys/arch/arm/arm/cpuswitch.S +++ b/sys/arch/arm/arm/cpuswitch.S @@ -1,4 +1,4 @@ -/* $OpenBSD: cpuswitch.S,v 1.8 2007/10/10 15:53:51 art Exp $ */ +/* $OpenBSD: cpuswitch.S,v 1.9 2007/10/13 12:46:17 miod Exp $ */ /* $NetBSD: cpuswitch.S,v 1.41 2003/11/15 08:44:18 scw Exp $ */ /* @@ -160,15 +160,7 @@ _C_LABEL(curpcb): * Idle loop, exercised while waiting for a process to wake up. */ ENTRY(cpu_idle_enter) - stmfd sp!, {lr} - - IRQenable /* Enable interrupts */ - - /* Drop to spl0 (returns the current spl level in r0). */ - mov r0, #(IPL_NONE) - bl _C_LABEL(_spllower) - - ldmfd sp!, {pc} + mov pc, lr ENTRY(cpu_idle_cycle) stmfd sp!, {r6, lr} @@ -181,7 +173,7 @@ ENTRY(cpu_idle_cycle) ldrne r6, [r6, #(CF_SLEEP)] teq r6, #0 /* Powersave idle? */ - beq 1f /* Nope. Just continue. */ + beq .Lidle_return /* Nope. Just continue. */ /* * Before going into powersave idle mode, disable interrupts. @@ -191,15 +183,11 @@ ENTRY(cpu_idle_cycle) mov pc, r6 /* If so, do powersave idle */ IRQenableALL -1: ldmfd sp!, {r6, pc} +.Lidle_return: + ldmfd sp!, {r6, pc} ENTRY(cpu_idle_leave) - stmfd sp!, {lr} - - mov r0, #(IPL_SCHED) - bl _C_LABEL(_splraise) - - ldmfd sp!, {pc} + mov pc, lr /* @@ -252,7 +240,7 @@ ENTRY(cpu_switchto) teq r0, #0x00000000 beq .Lswitch_exited - /* Stage two : Save old context */ + /* Stage two: Save old context */ /* Save all the registers in the old proc's pcb */ #ifndef __XSCALE__ @@ -304,7 +292,7 @@ ENTRY(cpu_switchto) /* What else needs to be saved Only FPA stuff when that is supported */ - /* Third phase : restore saved context */ + /* Third phase: restore saved context */ /* * Get the new L1 table pointer into r11. If we're switching to diff --git a/sys/arch/mips64/mips64/context.S b/sys/arch/mips64/mips64/context.S index 24deaf3b2ec..8b5876ea6d0 100644 --- a/sys/arch/mips64/mips64/context.S +++ b/sys/arch/mips64/mips64/context.S @@ -1,4 +1,4 @@ -/* $OpenBSD: context.S,v 1.14 2007/10/10 15:53:52 art Exp $ */ +/* $OpenBSD: context.S,v 1.15 2007/10/13 12:46:18 miod Exp $ */ /* * Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -69,31 +69,7 @@ LEAF(savectx, 0) move v0, zero END(savectx) -NON_LEAF(cpu_idle_enter, FRAMESZ(CF_SZ), ra) - PTR_SUBU sp, sp, FRAMESZ(CF_SZ) - PTR_S ra, CF_RA_OFFS(sp) - .mask 0x80000000, (CF_RA_OFFS - FRAMESZ(CF_SZ)) - - sw zero, cpl # lower to spl0 - lw t0, ipending - beqz t0, 1f - nop - jal setsoftintr0 - nop -1: - mfc0 a0, COP_0_STATUS_REG # ... and enable interrupts - li a1, SR_INT_ENAB - or a0, a0, a1 - mtc0 a0, COP_0_STATUS_REG - ITLBNOPFIX - -#ifdef IMASK_EXTERNAL - jal hw_setintrmask - xor a0, a0 -#endif - jal updateimask # Make sure SR imask is updated - xor a0, a0 - +LEAF(cpu_idle_enter, 0) #if defined(TGT_CP7000) || defined(TGT_CP7000G) PTR_L t2, misc_h # if non zero, do Ocelot LEDs. beqz t2, 1f @@ -102,9 +78,8 @@ NON_LEAF(cpu_idle_enter, FRAMESZ(CF_SZ), ra) 1: #endif - PTR_L ra, CF_RA_OFFS(sp) j ra - PTR_ADDU sp, sp, FRAMESZ(CF_SZ) + nop END(cpu_idle_enter) LEAF(cpu_idle_leave, 0) @@ -116,12 +91,6 @@ LEAF(cpu_idle_leave, 0) 1: #endif - mfc0 a0, COP_0_STATUS_REG # disable interrupts - li a1, ~SR_INT_ENAB - and a0, a0, a1 - mtc0 a0, COP_0_STATUS_REG - ITLBNOPFIX - j ra nop END(cpu_idle_leave) |