提交 d9676fa1 编写于 作者: E Evgeny Voevodin 提交者: Vineet Gupta

ARCv2: Enable LOCKDEP

- The asm helpers for calling into irq tracer were missing

- Add calls to above helpers in low level assembly entry code for ARCv2

- irq_save() uses CLRI to disable interrupts and returns the prev interrupt
  state (in STATUS32) in a specific encoding (and not the raw value of
  STATUS32). This is usable with SETI in irq_restore(). However
  save_flags() reads the raw value of STATUS32 which doesn't pair with
  irq_save/restore() and thus needs fixing.
Signed-off-by: NEvgeny Voevodin <evgeny.voevodin@intel.com>
[vgupta: updated changelog and also added some comments]
Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
上级 c3b46c73
...@@ -18,6 +18,12 @@ ...@@ -18,6 +18,12 @@
#define STATUS_AD_MASK (1<<STATUS_AD_BIT) #define STATUS_AD_MASK (1<<STATUS_AD_BIT)
#define STATUS_IE_MASK (1<<STATUS_IE_BIT) #define STATUS_IE_MASK (1<<STATUS_IE_BIT)
/* status32 Bits as encoded/expected by CLRI/SETI */
#define CLRI_STATUS_IE_BIT 4
#define CLRI_STATUS_E_MASK 0xF
#define CLRI_STATUS_IE_MASK (1 << CLRI_STATUS_IE_BIT)
#define AUX_USER_SP 0x00D #define AUX_USER_SP 0x00D
#define AUX_IRQ_CTRL 0x00E #define AUX_IRQ_CTRL 0x00E
#define AUX_IRQ_ACT 0x043 /* Active Intr across all levels */ #define AUX_IRQ_ACT 0x043 /* Active Intr across all levels */
...@@ -100,6 +106,13 @@ static inline long arch_local_save_flags(void) ...@@ -100,6 +106,13 @@ static inline long arch_local_save_flags(void)
: :
: "memory"); : "memory");
/* To be compatible with irq_save()/irq_restore()
* encode the irq bits as expected by CLRI/SETI
* (this was needed to make CONFIG_TRACE_IRQFLAGS work)
*/
temp = (1 << 5) |
((!!(temp & STATUS_IE_MASK)) << CLRI_STATUS_IE_BIT) |
(temp & CLRI_STATUS_E_MASK);
return temp; return temp;
} }
...@@ -108,7 +121,7 @@ static inline long arch_local_save_flags(void) ...@@ -108,7 +121,7 @@ static inline long arch_local_save_flags(void)
*/ */
static inline int arch_irqs_disabled_flags(unsigned long flags) static inline int arch_irqs_disabled_flags(unsigned long flags)
{ {
return !(flags & (STATUS_IE_MASK)); return !(flags & CLRI_STATUS_IE_MASK);
} }
static inline int arch_irqs_disabled(void) static inline int arch_irqs_disabled(void)
...@@ -128,11 +141,32 @@ static inline void arc_softirq_clear(int irq) ...@@ -128,11 +141,32 @@ static inline void arc_softirq_clear(int irq)
#else #else
#ifdef CONFIG_TRACE_IRQFLAGS
.macro TRACE_ASM_IRQ_DISABLE
bl trace_hardirqs_off
.endm
.macro TRACE_ASM_IRQ_ENABLE
bl trace_hardirqs_on
.endm
#else
.macro TRACE_ASM_IRQ_DISABLE
.endm
.macro TRACE_ASM_IRQ_ENABLE
.endm
#endif
.macro IRQ_DISABLE scratch .macro IRQ_DISABLE scratch
clri clri
TRACE_ASM_IRQ_DISABLE
.endm .endm
.macro IRQ_ENABLE scratch .macro IRQ_ENABLE scratch
TRACE_ASM_IRQ_ENABLE
seti seti
.endm .endm
......
...@@ -69,8 +69,11 @@ ENTRY(handle_interrupt) ...@@ -69,8 +69,11 @@ ENTRY(handle_interrupt)
clri ; To make status32.IE agree with CPU internal state clri ; To make status32.IE agree with CPU internal state
lr r0, [ICAUSE] #ifdef CONFIG_TRACE_IRQFLAGS
TRACE_ASM_IRQ_DISABLE
#endif
lr r0, [ICAUSE]
mov blink, ret_from_exception mov blink, ret_from_exception
b.d arch_do_IRQ b.d arch_do_IRQ
...@@ -169,6 +172,11 @@ END(EV_TLBProtV) ...@@ -169,6 +172,11 @@ END(EV_TLBProtV)
.Lrestore_regs: .Lrestore_regs:
# Interrpts are actually disabled from this point on, but will get
# reenabled after we return from interrupt/exception.
# But irq tracer needs to be told now...
TRACE_ASM_IRQ_ENABLE
ld r0, [sp, PT_status32] ; U/K mode at time of entry ld r0, [sp, PT_status32] ; U/K mode at time of entry
lr r10, [AUX_IRQ_ACT] lr r10, [AUX_IRQ_ACT]
......
...@@ -341,6 +341,9 @@ END(call_do_page_fault) ...@@ -341,6 +341,9 @@ END(call_do_page_fault)
.Lrestore_regs: .Lrestore_regs:
# Interrpts are actually disabled from this point on, but will get
# reenabled after we return from interrupt/exception.
# But irq tracer needs to be told now...
TRACE_ASM_IRQ_ENABLE TRACE_ASM_IRQ_ENABLE
lr r10, [status32] lr r10, [status32]
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册