diff options
| -rw-r--r-- | arch/arm64/kernel/entry.S | 29 |
1 files changed, 7 insertions, 22 deletions
diff --git a/arch/arm64/kernel/entry.S b/arch/arm64/kernel/entry.S index e1166145ca29..4d2c6f3f0c41 100644 --- a/arch/arm64/kernel/entry.S +++ b/arch/arm64/kernel/entry.S | |||
| @@ -309,15 +309,12 @@ el1_irq: | |||
| 309 | #ifdef CONFIG_TRACE_IRQFLAGS | 309 | #ifdef CONFIG_TRACE_IRQFLAGS |
| 310 | bl trace_hardirqs_off | 310 | bl trace_hardirqs_off |
| 311 | #endif | 311 | #endif |
| 312 | #ifdef CONFIG_PREEMPT | 312 | |
| 313 | get_thread_info tsk | ||
| 314 | ldr w24, [tsk, #TI_PREEMPT] // get preempt count | ||
| 315 | add w0, w24, #1 // increment it | ||
| 316 | str w0, [tsk, #TI_PREEMPT] | ||
| 317 | #endif | ||
| 318 | irq_handler | 313 | irq_handler |
| 314 | |||
| 319 | #ifdef CONFIG_PREEMPT | 315 | #ifdef CONFIG_PREEMPT |
| 320 | str w24, [tsk, #TI_PREEMPT] // restore preempt count | 316 | get_thread_info tsk |
| 317 | ldr w24, [tsk, #TI_PREEMPT] // restore preempt count | ||
| 321 | cbnz w24, 1f // preempt count != 0 | 318 | cbnz w24, 1f // preempt count != 0 |
| 322 | ldr x0, [tsk, #TI_FLAGS] // get flags | 319 | ldr x0, [tsk, #TI_FLAGS] // get flags |
| 323 | tbz x0, #TIF_NEED_RESCHED, 1f // needs rescheduling? | 320 | tbz x0, #TIF_NEED_RESCHED, 1f // needs rescheduling? |
| @@ -507,22 +504,10 @@ el0_irq_naked: | |||
| 507 | #ifdef CONFIG_TRACE_IRQFLAGS | 504 | #ifdef CONFIG_TRACE_IRQFLAGS |
| 508 | bl trace_hardirqs_off | 505 | bl trace_hardirqs_off |
| 509 | #endif | 506 | #endif |
| 510 | get_thread_info tsk | 507 | |
| 511 | #ifdef CONFIG_PREEMPT | ||
| 512 | ldr w24, [tsk, #TI_PREEMPT] // get preempt count | ||
| 513 | add w23, w24, #1 // increment it | ||
| 514 | str w23, [tsk, #TI_PREEMPT] | ||
| 515 | #endif | ||
| 516 | irq_handler | 508 | irq_handler |
| 517 | #ifdef CONFIG_PREEMPT | 509 | get_thread_info tsk |
| 518 | ldr w0, [tsk, #TI_PREEMPT] | 510 | |
| 519 | str w24, [tsk, #TI_PREEMPT] | ||
| 520 | cmp w0, w23 | ||
| 521 | b.eq 1f | ||
| 522 | mov x1, #0 | ||
| 523 | str x1, [x1] // BUG | ||
| 524 | 1: | ||
| 525 | #endif | ||
| 526 | #ifdef CONFIG_TRACE_IRQFLAGS | 511 | #ifdef CONFIG_TRACE_IRQFLAGS |
| 527 | bl trace_hardirqs_on | 512 | bl trace_hardirqs_on |
| 528 | #endif | 513 | #endif |
