diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-03-10 08:25:32 +0100 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-03-11 10:58:09 +0100 |
commit | d50acdbb6c8213114ce887a56daea02697c9e1a1 (patch) | |
tree | e48fb252786992308fa2dd6337c8a02db35bd10b /c/src | |
parent | sapi: Use one SMP lock for all chains (diff) | |
download | rtems-d50acdbb6c8213114ce887a56daea02697c9e1a1.tar.bz2 |
score: Add local context to SMP lock API
Add a local context structure to the SMP lock API for acquire and
release pairs. This context can be used to store the ISR level and
profiling information. It may be later used to enable more
sophisticated lock algorithms, e.g. MCS locks.
There is only one lock that cannot be used with a local context. This
is the per-CPU lock since here we would have to transfer the local
context through a context switch which is very complicated.
Diffstat (limited to 'c/src')
-rw-r--r-- | c/src/lib/libbsp/sparc/leon3/include/leon.h | 32 |
1 files changed, 16 insertions, 16 deletions
diff --git a/c/src/lib/libbsp/sparc/leon3/include/leon.h b/c/src/lib/libbsp/sparc/leon3/include/leon.h index 00f158f0c3..685b553052 100644 --- a/c/src/lib/libbsp/sparc/leon3/include/leon.h +++ b/c/src/lib/libbsp/sparc/leon3/include/leon.h @@ -169,11 +169,11 @@ static __inline__ int bsp_irq_fixup(int irq) extern rtems_interrupt_lock LEON3_IrqCtrl_Lock; -#define LEON3_IRQCTRL_ACQUIRE(_level ) \ - rtems_interrupt_lock_acquire( &LEON3_IrqCtrl_Lock, _level ) +#define LEON3_IRQCTRL_ACQUIRE( _lock_context ) \ + rtems_interrupt_lock_acquire( &LEON3_IrqCtrl_Lock, _lock_context ) -#define LEON3_IRQCTRL_RELEASE(_level ) \ - rtems_interrupt_lock_release( &LEON3_IrqCtrl_Lock, _level ) +#define LEON3_IRQCTRL_RELEASE( _lock_context ) \ + rtems_interrupt_lock_release( &LEON3_IrqCtrl_Lock, _lock_context ) #define LEON_Clear_interrupt( _source ) \ do { \ @@ -195,39 +195,39 @@ extern rtems_interrupt_lock LEON3_IrqCtrl_Lock; #define LEON_Mask_interrupt( _source ) \ do { \ - rtems_interrupt_level _level; \ - LEON3_IRQCTRL_ACQUIRE( _level ); \ + rtems_interrupt_lock_context _lock_context; \ + LEON3_IRQCTRL_ACQUIRE( &_lock_context ); \ LEON3_IrqCtrl_Regs->mask[LEON3_Cpu_Index] &= ~(1 << (_source)); \ - LEON3_IRQCTRL_RELEASE( _level ); \ + LEON3_IRQCTRL_RELEASE( &_lock_context ); \ } while (0) #define LEON_Unmask_interrupt( _source ) \ do { \ - rtems_interrupt_level _level; \ - LEON3_IRQCTRL_ACQUIRE( _level ); \ + rtems_interrupt_lock_context _lock_context; \ + LEON3_IRQCTRL_ACQUIRE( &_lock_context ); \ LEON3_IrqCtrl_Regs->mask[LEON3_Cpu_Index] |= (1 << (_source)); \ - LEON3_IRQCTRL_RELEASE( _level ); \ + LEON3_IRQCTRL_RELEASE( &_lock_context ); \ } while (0) #define LEON_Disable_interrupt( _source, _previous ) \ do { \ - rtems_interrupt_level _level; \ + rtems_interrupt_lock_context _lock_context; \ uint32_t _mask = 1 << (_source); \ - LEON3_IRQCTRL_ACQUIRE( _level ); \ + LEON3_IRQCTRL_ACQUIRE( &_lock_context ); \ (_previous) = LEON3_IrqCtrl_Regs->mask[LEON3_Cpu_Index]; \ LEON3_IrqCtrl_Regs->mask[LEON3_Cpu_Index] = _previous & ~_mask; \ - LEON3_IRQCTRL_RELEASE( _level ); \ + LEON3_IRQCTRL_RELEASE( &_lock_context ); \ (_previous) &= _mask; \ } while (0) #define LEON_Restore_interrupt( _source, _previous ) \ do { \ - rtems_interrupt_level _level; \ + rtems_interrupt_lock_context _lock_context; \ uint32_t _mask = 1 << (_source); \ - LEON3_IRQCTRL_ACQUIRE( _level ); \ + LEON3_IRQCTRL_ACQUIRE( &_lock_context ); \ LEON3_IrqCtrl_Regs->mask[LEON3_Cpu_Index] = \ (LEON3_IrqCtrl_Regs->mask[LEON3_Cpu_Index] & ~_mask) | (_previous); \ - LEON3_IRQCTRL_RELEASE( _level ); \ + LEON3_IRQCTRL_RELEASE( &_lock_context ); \ } while (0) /* Make all SPARC BSPs have common macros for interrupt handling */ |