diff options
author | Tobias Klauser <tklauser@distanz.ch> | 2014-12-30 21:53:11 -0500 |
---|---|---|
committer | Ley Foon Tan <lftan@altera.com> | 2014-12-30 22:04:58 -0500 |
commit | 1b0f44923e186b2f9383b3260f6b5fbfc77b9e4a (patch) | |
tree | dfbb1e124873c802f99f81e569f28f1256cdbfbb /arch/nios2/kernel/entry.S | |
parent | 6f3d2b0075f74ab4f4aeca1622cd71f212a24c46 (diff) |
nios2: Use preempt_schedule_irq
Follow aa0d53260596 ("ia64: Use preempt_schedule_irq") and use
preempt_schedule_irq instead of enabling/disabling interrupts and
messing around with PREEMPT_ACTIVE in the nios2 low-level preemption
code ourselves. Also get rid of the now needless re-check for
TIF_NEED_RESCHED, preempt_schedule_irq will already take care of
rescheduling.
This also fixes the following build error when building with
CONFIG_PREEMPT:
arch/nios2/kernel/built-in.o: In function `need_resched':
arch/nios2/kernel/entry.S:374: undefined reference to `PREEMPT_ACTIVE'
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Tobias Klauser <tklauser@distanz.ch>
Acked-by: Ley Foon Tan <lftan@altera.com>
Diffstat (limited to 'arch/nios2/kernel/entry.S')
-rw-r--r-- | arch/nios2/kernel/entry.S | 20 |
1 files changed, 2 insertions, 18 deletions
diff --git a/arch/nios2/kernel/entry.S b/arch/nios2/kernel/entry.S index 83bca17d1008..0bdfd13ff98b 100644 --- a/arch/nios2/kernel/entry.S +++ b/arch/nios2/kernel/entry.S | |||
@@ -365,30 +365,14 @@ ENTRY(ret_from_interrupt) | |||
365 | GET_THREAD_INFO r1 | 365 | GET_THREAD_INFO r1 |
366 | ldw r4, TI_PREEMPT_COUNT(r1) | 366 | ldw r4, TI_PREEMPT_COUNT(r1) |
367 | bne r4, r0, restore_all | 367 | bne r4, r0, restore_all |
368 | |||
369 | need_resched: | ||
370 | ldw r4, TI_FLAGS(r1) /* ? Need resched set */ | 368 | ldw r4, TI_FLAGS(r1) /* ? Need resched set */ |
371 | BTBZ r10, r4, TIF_NEED_RESCHED, restore_all | 369 | BTBZ r10, r4, TIF_NEED_RESCHED, restore_all |
372 | ldw r4, PT_ESTATUS(sp) /* ? Interrupts off */ | 370 | ldw r4, PT_ESTATUS(sp) /* ? Interrupts off */ |
373 | andi r10, r4, ESTATUS_EPIE | 371 | andi r10, r4, ESTATUS_EPIE |
374 | beq r10, r0, restore_all | 372 | beq r10, r0, restore_all |
375 | movia r4, PREEMPT_ACTIVE | 373 | call preempt_schedule_irq |
376 | stw r4, TI_PREEMPT_COUNT(r1) | ||
377 | rdctl r10, status /* enable intrs again */ | ||
378 | ori r10, r10 ,STATUS_PIE | ||
379 | wrctl status, r10 | ||
380 | PUSH r1 | ||
381 | call schedule | ||
382 | POP r1 | ||
383 | mov r4, r0 | ||
384 | stw r4, TI_PREEMPT_COUNT(r1) | ||
385 | rdctl r10, status /* disable intrs */ | ||
386 | andi r10, r10, %lo(~STATUS_PIE) | ||
387 | wrctl status, r10 | ||
388 | br need_resched | ||
389 | #else | ||
390 | br restore_all | ||
391 | #endif | 374 | #endif |
375 | br restore_all | ||
392 | 376 | ||
393 | /*********************************************************************** | 377 | /*********************************************************************** |
394 | * A few syscall wrappers | 378 | * A few syscall wrappers |