spinlock: Introduce SP_WFE() and SP_SEV()
Summary: - This commit introduces SP_WFE() and SP_SEV() to be used for spinlock - Also, use wfe/sev instructions for ARMV7-A to reduce power consumption Impact: - ARMV7-a SMP only Testing: - sabre-6quad:smp (QEMU, dev board) - maix-bit:smp, esp32-devkitc:smp, spresense:smp sim:smp (compile only) Signed-off-by: Masayuki Ishikawa <Masayuki.Ishikawa@jp.sony.com>
This commit is contained in:
parent
21cb7935c5
commit
6158b6b77b
@ -590,6 +590,7 @@ config ARCH_CORTEXM7
|
|||||||
config ARCH_ARMV7A
|
config ARCH_ARMV7A
|
||||||
bool
|
bool
|
||||||
default n
|
default n
|
||||||
|
select ARM_HAVE_WFE_SEV
|
||||||
|
|
||||||
config ARCH_CORTEXA5
|
config ARCH_CORTEXA5
|
||||||
bool
|
bool
|
||||||
@ -789,6 +790,12 @@ config ARM_THUMB
|
|||||||
default n
|
default n
|
||||||
depends on ARCH_ARMV7A
|
depends on ARCH_ARMV7A
|
||||||
|
|
||||||
|
config ARM_HAVE_WFE_SEV
|
||||||
|
bool
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Use WFE and SEV instructions for spinlock to reduce power consumption
|
||||||
|
|
||||||
config ARM_HAVE_MPU_UNIFIED
|
config ARM_HAVE_MPU_UNIFIED
|
||||||
bool
|
bool
|
||||||
default n
|
default n
|
||||||
|
@ -95,6 +95,11 @@
|
|||||||
#define SP_DSB(n) __asm__ __volatile__ ("dsb sy" : : : "memory")
|
#define SP_DSB(n) __asm__ __volatile__ ("dsb sy" : : : "memory")
|
||||||
#define SP_DMB(n) __asm__ __volatile__ ("dmb st" : : : "memory")
|
#define SP_DMB(n) __asm__ __volatile__ ("dmb st" : : : "memory")
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARM_HAVE_WFE_SEV
|
||||||
|
#define SP_WFE() __asm__ __volatile__ ("wfe" : : : "memory")
|
||||||
|
#define SP_SEV() __asm__ __volatile__ ("sev" : : : "memory")
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Types
|
* Public Types
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -80,6 +80,14 @@
|
|||||||
# define SP_DSB()
|
# define SP_DSB()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(SP_WFE)
|
||||||
|
# define SP_WFE()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(SP_SEV)
|
||||||
|
# define SP_SEV()
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS) && !defined(__SP_UNLOCK_FUNCTION)
|
#if defined(CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS) && !defined(__SP_UNLOCK_FUNCTION)
|
||||||
# define __SP_UNLOCK_FUNCTION 1
|
# define __SP_UNLOCK_FUNCTION 1
|
||||||
#endif
|
#endif
|
||||||
|
@ -89,6 +89,7 @@ void spin_lock(FAR volatile spinlock_t *lock)
|
|||||||
while (up_testset(lock) == SP_LOCKED)
|
while (up_testset(lock) == SP_LOCKED)
|
||||||
{
|
{
|
||||||
SP_DSB();
|
SP_DSB();
|
||||||
|
SP_WFE();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS
|
||||||
@ -126,6 +127,7 @@ void spin_lock_wo_note(FAR volatile spinlock_t *lock)
|
|||||||
while (up_testset(lock) == SP_LOCKED)
|
while (up_testset(lock) == SP_LOCKED)
|
||||||
{
|
{
|
||||||
SP_DSB();
|
SP_DSB();
|
||||||
|
SP_WFE();
|
||||||
}
|
}
|
||||||
|
|
||||||
SP_DMB();
|
SP_DMB();
|
||||||
@ -241,6 +243,7 @@ void spin_unlock(FAR volatile spinlock_t *lock)
|
|||||||
SP_DMB();
|
SP_DMB();
|
||||||
*lock = SP_UNLOCKED;
|
*lock = SP_UNLOCKED;
|
||||||
SP_DSB();
|
SP_DSB();
|
||||||
|
SP_SEV();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -269,6 +272,7 @@ void spin_unlock_wo_note(FAR volatile spinlock_t *lock)
|
|||||||
SP_DMB();
|
SP_DMB();
|
||||||
*lock = SP_UNLOCKED;
|
*lock = SP_UNLOCKED;
|
||||||
SP_DSB();
|
SP_DSB();
|
||||||
|
SP_SEV();
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
Loading…
Reference in New Issue
Block a user