diff --git a/arch/arm/src/at32/at32_serial.c b/arch/arm/src/at32/at32_serial.c index 05c70cd967..8acfe1bc1d 100644 --- a/arch/arm/src/at32/at32_serial.c +++ b/arch/arm/src/at32/at32_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/efm32/efm32_leserial.c b/arch/arm/src/efm32/efm32_leserial.c index c8d396cd26..e6b2cbee96 100644 --- a/arch/arm/src/efm32/efm32_leserial.c +++ b/arch/arm/src/efm32/efm32_leserial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/arm/src/gd32f4/gd32f4xx_serial.c b/arch/arm/src/gd32f4/gd32f4xx_serial.c index 348840af55..36cc9e540e 100644 --- a/arch/arm/src/gd32f4/gd32f4xx_serial.c +++ b/arch/arm/src/gd32f4/gd32f4xx_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/kinetis/kinetis_lpserial.c b/arch/arm/src/kinetis/kinetis_lpserial.c index d7ca5db9eb..65ea3f91f4 100644 --- a/arch/arm/src/kinetis/kinetis_lpserial.c +++ b/arch/arm/src/kinetis/kinetis_lpserial.c @@ -37,6 +37,7 @@ #include #include #include +#include #ifdef CONFIG_SERIAL_TERMIOS # include diff --git a/arch/arm/src/kinetis/kinetis_serial.c b/arch/arm/src/kinetis/kinetis_serial.c index 5b6f8f59a8..0ff5294e8b 100644 --- a/arch/arm/src/kinetis/kinetis_serial.c +++ b/arch/arm/src/kinetis/kinetis_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #ifdef CONFIG_SERIAL_TERMIOS # include diff --git a/arch/arm/src/kl/kl_serial.c b/arch/arm/src/kl/kl_serial.c index 4becc1e2c2..0da514d139 100644 --- a/arch/arm/src/kl/kl_serial.c +++ b/arch/arm/src/kl/kl_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/arm/src/lpc54xx/lpc54_lowputc.c b/arch/arm/src/lpc54xx/lpc54_lowputc.c index 4360c91b03..d9cbd444ff 100644 --- a/arch/arm/src/lpc54xx/lpc54_lowputc.c +++ b/arch/arm/src/lpc54xx/lpc54_lowputc.c @@ -64,6 +64,7 @@ #include #include +#include /**************************************************************************** * Pre-processor Definitions diff --git a/arch/arm/src/lpc54xx/lpc54_serial.c b/arch/arm/src/lpc54xx/lpc54_serial.c index 4d62be6222..ff6b18b8f5 100644 --- a/arch/arm/src/lpc54xx/lpc54_serial.c +++ b/arch/arm/src/lpc54xx/lpc54_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/arm/src/sam34/sam_lowputc.c b/arch/arm/src/sam34/sam_lowputc.c index 0c2f1078cc..43715c04e5 100644 --- a/arch/arm/src/sam34/sam_lowputc.c +++ b/arch/arm/src/sam34/sam_lowputc.c @@ -28,6 +28,7 @@ #include #include +#include #include "arm_internal.h" #include "sam_gpio.h" diff --git a/arch/arm/src/sama5/sam_lowputc.c b/arch/arm/src/sama5/sam_lowputc.c index 51130a3ad6..191f17aae6 100644 --- a/arch/arm/src/sama5/sam_lowputc.c +++ b/arch/arm/src/sama5/sam_lowputc.c @@ -28,6 +28,7 @@ #include #include +#include #include "arm_internal.h" #include "sam_pio.h" diff --git a/arch/arm/src/samd2l2/sam_serial.c b/arch/arm/src/samd2l2/sam_serial.c index 342548fc6a..ad91c0f706 100644 --- a/arch/arm/src/samd2l2/sam_serial.c +++ b/arch/arm/src/samd2l2/sam_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include diff --git a/arch/arm/src/samd5e5/sam_serial.c b/arch/arm/src/samd5e5/sam_serial.c index c5b3687419..b8a8c017ba 100644 --- a/arch/arm/src/samd5e5/sam_serial.c +++ b/arch/arm/src/samd5e5/sam_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include diff --git a/arch/arm/src/samv7/sam_lowputc.c b/arch/arm/src/samv7/sam_lowputc.c index afbd732037..679678702b 100644 --- a/arch/arm/src/samv7/sam_lowputc.c +++ b/arch/arm/src/samv7/sam_lowputc.c @@ -28,6 +28,7 @@ #include #include +#include #include #include "arm_internal.h" diff --git a/arch/arm/src/stm32/stm32_serial.c b/arch/arm/src/stm32/stm32_serial.c index ca5010446c..5bcc36099c 100644 --- a/arch/arm/src/stm32/stm32_serial.c +++ b/arch/arm/src/stm32/stm32_serial.c @@ -38,6 +38,7 @@ #include #include #include +#include #ifdef CONFIG_SERIAL_TERMIOS # include diff --git a/arch/arm/src/stm32f0l0g0/stm32_serial_v1.c b/arch/arm/src/stm32f0l0g0/stm32_serial_v1.c index 770aacb4dc..9799dc81b8 100644 --- a/arch/arm/src/stm32f0l0g0/stm32_serial_v1.c +++ b/arch/arm/src/stm32f0l0g0/stm32_serial_v1.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/stm32f0l0g0/stm32_serial_v2.c b/arch/arm/src/stm32f0l0g0/stm32_serial_v2.c index 2c2a701ee8..11009babdf 100644 --- a/arch/arm/src/stm32f0l0g0/stm32_serial_v2.c +++ b/arch/arm/src/stm32f0l0g0/stm32_serial_v2.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/stm32f7/stm32_serial.c b/arch/arm/src/stm32f7/stm32_serial.c index 691823f8b4..6f43be55bb 100644 --- a/arch/arm/src/stm32f7/stm32_serial.c +++ b/arch/arm/src/stm32f7/stm32_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/stm32h7/stm32_serial.c b/arch/arm/src/stm32h7/stm32_serial.c index ee33b6a5bc..5bf37e7e0d 100644 --- a/arch/arm/src/stm32h7/stm32_serial.c +++ b/arch/arm/src/stm32h7/stm32_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #include diff --git a/arch/arm/src/stm32l4/stm32l4_serial.c b/arch/arm/src/stm32l4/stm32l4_serial.c index 648fc995ba..c3d65693db 100644 --- a/arch/arm/src/stm32l4/stm32l4_serial.c +++ b/arch/arm/src/stm32l4/stm32l4_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/stm32l5/stm32l5_serial.c b/arch/arm/src/stm32l5/stm32l5_serial.c index b483d1835f..d529ddaf33 100644 --- a/arch/arm/src/stm32l5/stm32l5_serial.c +++ b/arch/arm/src/stm32l5/stm32l5_serial.c @@ -38,6 +38,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/stm32u5/stm32_serial.c b/arch/arm/src/stm32u5/stm32_serial.c index 97f90300e2..9394ee9f49 100644 --- a/arch/arm/src/stm32u5/stm32_serial.c +++ b/arch/arm/src/stm32u5/stm32_serial.c @@ -38,6 +38,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/stm32wb/stm32wb_serial.c b/arch/arm/src/stm32wb/stm32wb_serial.c index b83a23ff69..d1d8bb3ced 100644 --- a/arch/arm/src/stm32wb/stm32wb_serial.c +++ b/arch/arm/src/stm32wb/stm32wb_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include #include diff --git a/arch/arm/src/stm32wl5/stm32wl5_serial.c b/arch/arm/src/stm32wl5/stm32wl5_serial.c index 037bbbcfa5..fb34ef7519 100644 --- a/arch/arm/src/stm32wl5/stm32wl5_serial.c +++ b/arch/arm/src/stm32wl5/stm32wl5_serial.c @@ -38,6 +38,7 @@ #include #include #include +#include #include #ifdef CONFIG_SERIAL_TERMIOS diff --git a/arch/arm/src/tms570/tms570_lowputc.c b/arch/arm/src/tms570/tms570_lowputc.c index 9f7232460b..87d6dd5709 100644 --- a/arch/arm/src/tms570/tms570_lowputc.c +++ b/arch/arm/src/tms570/tms570_lowputc.c @@ -52,6 +52,7 @@ #include #include #include +#include #include "arm_internal.h" #include "hardware/tms570_sci.h" diff --git a/arch/arm/src/xmc4/xmc4_serial.c b/arch/arm/src/xmc4/xmc4_serial.c index 6e0644a1a7..a2b060d080 100644 --- a/arch/arm/src/xmc4/xmc4_serial.c +++ b/arch/arm/src/xmc4/xmc4_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/mips/src/pic32mx/pic32mx_serial.c b/arch/mips/src/pic32mx/pic32mx_serial.c index 1726f628d5..7f35a82500 100644 --- a/arch/mips/src/pic32mx/pic32mx_serial.c +++ b/arch/mips/src/pic32mx/pic32mx_serial.c @@ -40,6 +40,7 @@ #include #include #include +#include #include diff --git a/arch/mips/src/pic32mz/pic32mz_serial.c b/arch/mips/src/pic32mz/pic32mz_serial.c index 8f5353010e..f1c81bceeb 100644 --- a/arch/mips/src/pic32mz/pic32mz_serial.c +++ b/arch/mips/src/pic32mz/pic32mz_serial.c @@ -41,6 +41,7 @@ #include #include #include +#include #include diff --git a/arch/risc-v/src/bl602/bl602_serial.c b/arch/risc-v/src/bl602/bl602_serial.c index f9b5d03334..f03ab039e0 100644 --- a/arch/risc-v/src/bl602/bl602_serial.c +++ b/arch/risc-v/src/bl602/bl602_serial.c @@ -37,6 +37,7 @@ #include #include #include +#include #include "bl602_lowputc.h" #include "bl602_gpio.h" diff --git a/arch/risc-v/src/c906/c906_serial.c b/arch/risc-v/src/c906/c906_serial.c index fb1341d115..d893da252a 100644 --- a/arch/risc-v/src/c906/c906_serial.c +++ b/arch/risc-v/src/c906/c906_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/risc-v/src/common/espressif/esp_lowputc.c b/arch/risc-v/src/common/espressif/esp_lowputc.c index e630a70b83..12995456b0 100644 --- a/arch/risc-v/src/common/espressif/esp_lowputc.c +++ b/arch/risc-v/src/common/espressif/esp_lowputc.c @@ -35,6 +35,7 @@ #include #include +#include #include "chip.h" #include "riscv_internal.h" diff --git a/arch/risc-v/src/esp32c3-legacy/esp32c3_lowputc.c b/arch/risc-v/src/esp32c3-legacy/esp32c3_lowputc.c index d5a36999b5..4620942e47 100644 --- a/arch/risc-v/src/esp32c3-legacy/esp32c3_lowputc.c +++ b/arch/risc-v/src/esp32c3-legacy/esp32c3_lowputc.c @@ -25,6 +25,7 @@ #include #include #include +#include #include #include diff --git a/arch/risc-v/src/fe310/fe310_serial.c b/arch/risc-v/src/fe310/fe310_serial.c index 9250ce3098..d88d11326e 100644 --- a/arch/risc-v/src/fe310/fe310_serial.c +++ b/arch/risc-v/src/fe310/fe310_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/risc-v/src/hpm6750/hpm6750_serial.c b/arch/risc-v/src/hpm6750/hpm6750_serial.c index c18dafd44c..227c6cae8b 100644 --- a/arch/risc-v/src/hpm6750/hpm6750_serial.c +++ b/arch/risc-v/src/hpm6750/hpm6750_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/risc-v/src/k210/k210_serial.c b/arch/risc-v/src/k210/k210_serial.c index 4179c7fe7a..378e63d1dc 100644 --- a/arch/risc-v/src/k210/k210_serial.c +++ b/arch/risc-v/src/k210/k210_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #include diff --git a/arch/risc-v/src/rv32m1/rv32m1_serial.c b/arch/risc-v/src/rv32m1/rv32m1_serial.c index 093f3eccc7..9c3f23819b 100644 --- a/arch/risc-v/src/rv32m1/rv32m1_serial.c +++ b/arch/risc-v/src/rv32m1/rv32m1_serial.c @@ -36,6 +36,7 @@ #include #include #include +#include #ifdef CONFIG_SERIAL_TERMIOS # include diff --git a/arch/sparc/src/bm3803/bm3803-serial.c b/arch/sparc/src/bm3803/bm3803-serial.c index b6911025f5..192065d2cc 100644 --- a/arch/sparc/src/bm3803/bm3803-serial.c +++ b/arch/sparc/src/bm3803/bm3803-serial.c @@ -41,6 +41,7 @@ #include #include #include +#include #include diff --git a/arch/x86_64/src/intel64/intel64_cpustart.c b/arch/x86_64/src/intel64/intel64_cpustart.c index f8f2a703b7..c766ebfe1c 100644 --- a/arch/x86_64/src/intel64/intel64_cpustart.c +++ b/arch/x86_64/src/intel64/intel64_cpustart.c @@ -30,6 +30,7 @@ #include #include #include +#include #include "init/init.h" diff --git a/arch/xtensa/src/esp32/esp32_dac.c b/arch/xtensa/src/esp32/esp32_dac.c index 5f3b84540a..d1e127d2c8 100644 --- a/arch/xtensa/src/esp32/esp32_dac.c +++ b/arch/xtensa/src/esp32/esp32_dac.c @@ -25,6 +25,7 @@ #include "xtensa.h" #include #include +#include #include #include #include "esp32_dac.h" diff --git a/arch/xtensa/src/esp32s2/esp32s2_lowputc.c b/arch/xtensa/src/esp32s2/esp32s2_lowputc.c index 423b5907eb..f71acb90b1 100644 --- a/arch/xtensa/src/esp32s2/esp32s2_lowputc.c +++ b/arch/xtensa/src/esp32s2/esp32s2_lowputc.c @@ -34,6 +34,7 @@ #include #include +#include #include "xtensa.h" #include "esp32s2_clockconfig.h" diff --git a/arch/xtensa/src/esp32s3/esp32s3_idle.c b/arch/xtensa/src/esp32s3/esp32s3_idle.c index 25fbe6b9ef..305dbb31de 100644 --- a/arch/xtensa/src/esp32s3/esp32s3_idle.c +++ b/arch/xtensa/src/esp32s3/esp32s3_idle.c @@ -29,6 +29,7 @@ #include #include #include +#include #include "xtensa.h" #include "esp32s3_pm.h" diff --git a/drivers/note/note_driver.c b/drivers/note/note_driver.c index b02d94e98f..70c8c2dd03 100644 --- a/drivers/note/note_driver.c +++ b/drivers/note/note_driver.c @@ -1170,6 +1170,27 @@ void sched_note_spinlock(FAR struct tcb_s *tcb, note_add(*driver, ¬e, sizeof(struct note_spinlock_s)); } } + +void sched_note_spinlock_lock(FAR volatile spinlock_t *spinlock) +{ + sched_note_spinlock(this_task(), spinlock, NOTE_SPINLOCK_LOCK); +} + +void sched_note_spinlock_locked(FAR volatile spinlock_t *spinlock) +{ + sched_note_spinlock(this_task(), spinlock, NOTE_SPINLOCK_LOCKED); +} + +void sched_note_spinlock_abort(FAR volatile spinlock_t *spinlock) +{ + sched_note_spinlock(this_task(), spinlock, NOTE_SPINLOCK_ABORT); +} + +void sched_note_spinlock_unlock(FAR volatile spinlock_t *spinlock) +{ + sched_note_spinlock(this_task(), spinlock, NOTE_SPINLOCK_UNLOCK); +} + #endif #ifdef CONFIG_SCHED_INSTRUMENTATION_SYSCALL diff --git a/drivers/serial/uart_16550.c b/drivers/serial/uart_16550.c index 747383a6f5..e03fee887d 100644 --- a/drivers/serial/uart_16550.c +++ b/drivers/serial/uart_16550.c @@ -42,6 +42,7 @@ #include #include #include +#include #include diff --git a/fs/inode/fs_files.c b/fs/inode/fs_files.c index a95f31847a..f5177c8246 100644 --- a/fs/inode/fs_files.c +++ b/fs/inode/fs_files.c @@ -41,6 +41,7 @@ #include #include #include +#include #ifdef CONFIG_FDSAN # include @@ -66,11 +67,11 @@ static FAR struct file *files_fget_by_index(FAR struct filelist *list, FAR struct file *filep; irqstate_t flags; - flags = spin_lock_irqsave(&list->fl_lock); + flags = spin_lock_irqsave(NULL); filep = &list->fl_files[l1][l2]; - spin_unlock_irqrestore(&list->fl_lock, flags); + spin_unlock_irqrestore(NULL, flags); return filep; } @@ -125,7 +126,7 @@ static int files_extend(FAR struct filelist *list, size_t row) } while (++i < row); - flags = spin_lock_irqsave(&list->fl_lock); + flags = spin_lock_irqsave(NULL); /* To avoid race condition, if the file list is updated by other threads * and list rows is greater or equal than temp list, @@ -134,7 +135,7 @@ static int files_extend(FAR struct filelist *list, size_t row) if (orig_rows != list->fl_rows && list->fl_rows >= row) { - spin_unlock_irqrestore(&list->fl_lock, flags); + spin_unlock_irqrestore(NULL, flags); for (j = orig_rows; j < i; j++) { @@ -156,7 +157,7 @@ static int files_extend(FAR struct filelist *list, size_t row) list->fl_files = files; list->fl_rows = row; - spin_unlock_irqrestore(&list->fl_lock, flags); + spin_unlock_irqrestore(NULL, flags); if (tmp != NULL && tmp != &list->fl_prefile) { @@ -484,13 +485,13 @@ int file_allocate_from_tcb(FAR struct tcb_s *tcb, FAR struct inode *inode, /* Find free file */ - flags = spin_lock_irqsave(&list->fl_lock); + flags = spin_lock_irqsave(NULL); for (; ; i++, j = 0) { if (i >= list->fl_rows) { - spin_unlock_irqrestore(&list->fl_lock, flags); + spin_unlock_irqrestore(NULL, flags); ret = files_extend(list, i + 1); if (ret < 0) @@ -498,7 +499,7 @@ int file_allocate_from_tcb(FAR struct tcb_s *tcb, FAR struct inode *inode, return ret; } - flags = spin_lock_irqsave(&list->fl_lock); + flags = spin_lock_irqsave(NULL); } do @@ -518,7 +519,7 @@ int file_allocate_from_tcb(FAR struct tcb_s *tcb, FAR struct inode *inode, } found: - spin_unlock_irqrestore(&list->fl_lock, flags); + spin_unlock_irqrestore(NULL, flags); if (addref) { diff --git a/include/nuttx/fs/fs.h b/include/nuttx/fs/fs.h index bca2f8dd19..275f0646f0 100644 --- a/include/nuttx/fs/fs.h +++ b/include/nuttx/fs/fs.h @@ -37,10 +37,10 @@ #include #include -#include #include #include #include +#include /**************************************************************************** * Pre-processor Definitions @@ -490,7 +490,6 @@ struct file struct filelist { - spinlock_t fl_lock; /* Manage access to the file list */ uint8_t fl_rows; /* The number of rows of fl_files array */ FAR struct file **fl_files; /* The pointer of two layer file descriptors array */ diff --git a/include/nuttx/spinlock.h b/include/nuttx/spinlock.h index 4bb2203fcf..2e62e43512 100644 --- a/include/nuttx/spinlock.h +++ b/include/nuttx/spinlock.h @@ -28,8 +28,30 @@ #include #include +#include #include +#if defined(CONFIG_TICKET_SPINLOCK) || defined(CONFIG_RW_SPINLOCK) +# if !defined(__cplusplus) +# include +# define CONFIG_HAVE_INLINE_SPINLOCK +# elif defined(__has_include) && __has_include() +extern "C++" +{ +# include +# define CONFIG_HAVE_INLINE_SPINLOCK + using std::atomic_int; + using std::atomic_load; + using std::atomic_fetch_add; + using std::atomic_fetch_sub; + using std::atomic_compare_exchange_strong; +} +# endif +#else +# define CONFIG_HAVE_INLINE_SPINLOCK +#endif + +#include #include #undef EXTERN @@ -123,6 +145,18 @@ typedef union spinlock_u spinlock_t; * Public Function Prototypes ****************************************************************************/ +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS +void sched_note_spinlock_lock(FAR volatile spinlock_t *spinlock); +void sched_note_spinlock_locked(FAR volatile spinlock_t *spinlock); +void sched_note_spinlock_abort(FAR volatile spinlock_t *spinlock); +void sched_note_spinlock_unlock(FAR volatile spinlock_t *spinlock); +#else +# define sched_note_spinlock_lock(spinlock) +# define sched_note_spinlock_locked(spinlock) +# define sched_note_spinlock_abort(spinlock) +# define sched_note_spinlock_unlocked(spinlock) +#endif + /**************************************************************************** * Name: up_testset * @@ -184,6 +218,8 @@ static inline spinlock_t up_testset(FAR volatile spinlock_t *lock) /* void spin_lock_init(FAR spinlock_t *lock); */ #define spin_lock_init(l) do { *(l) = SP_UNLOCKED; } while (0) +#ifdef CONFIG_HAVE_INLINE_SPINLOCK + /**************************************************************************** * Name: spin_lock * @@ -207,7 +243,34 @@ static inline spinlock_t up_testset(FAR volatile spinlock_t *lock) * ****************************************************************************/ -void spin_lock(FAR volatile spinlock_t *lock); +static inline_function void spin_lock(FAR volatile spinlock_t *lock) +{ +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + + /* Notify that we are waiting for a spinlock */ + + sched_note_spinlock_lock(lock); +#endif + +#ifdef CONFIG_TICKET_SPINLOCK + unsigned short ticket = + atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.next, 1); + while (atomic_load((FAR atomic_ushort *)&lock->tickets.owner) != ticket) +#else /* CONFIG_SPINLOCK */ + while (up_testset(lock) == SP_LOCKED) +#endif + { + SP_DSB(); + SP_WFE(); + } + +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + /* Notify that we have the spinlock */ + + sched_note_spinlock_locked(lock); +#endif + SP_DMB(); +} /**************************************************************************** * Name: spin_lock_wo_note @@ -231,7 +294,22 @@ void spin_lock(FAR volatile spinlock_t *lock); * ****************************************************************************/ -void spin_lock_wo_note(FAR volatile spinlock_t *lock); +static inline_function void spin_lock_wo_note(FAR volatile spinlock_t *lock) +{ +#ifdef CONFIG_TICKET_SPINLOCK + unsigned short ticket = + atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.next, 1); + while (atomic_load((FAR atomic_ushort *)&lock->tickets.owner) != ticket) +#else /* CONFIG_TICKET_SPINLOCK */ + while (up_testset(lock) == SP_LOCKED) +#endif + { + SP_DSB(); + SP_WFE(); + } + + SP_DMB(); +} /**************************************************************************** * Name: spin_trylock @@ -252,7 +330,56 @@ void spin_lock_wo_note(FAR volatile spinlock_t *lock); * ****************************************************************************/ -bool spin_trylock(FAR volatile spinlock_t *lock); +static inline_function bool spin_trylock(FAR volatile spinlock_t *lock) +{ +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + + /* Notify that we are waiting for a spinlock */ + + sched_note_spinlock_lock(lock); +#endif + +#ifdef CONFIG_TICKET_SPINLOCK + unsigned short ticket = + atomic_load((FAR atomic_ushort *)&lock->tickets.next); + + spinlock_t old = + { + { + ticket, ticket + } + }; + + spinlock_t new = + { + { + ticket, ticket + 1 + } + }; + + if (!atomic_compare_exchange_strong((FAR atomic_uint *)&lock->value, + &old.value, new.value)) +#else /* CONFIG_TICKET_SPINLOCK */ + if (up_testset(lock) == SP_LOCKED) +#endif /* CONFIG_TICKET_SPINLOCK */ + { +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + /* Notify that we abort for a spinlock */ + + sched_note_spinlock_abort(lock); +#endif + SP_DSB(); + return false; + } + +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + /* Notify that we have the spinlock */ + + sched_note_spinlock_locked(lock); +#endif + SP_DMB(); + return true; +} /**************************************************************************** * Name: spin_trylock_wo_note @@ -276,7 +403,40 @@ bool spin_trylock(FAR volatile spinlock_t *lock); * ****************************************************************************/ -bool spin_trylock_wo_note(FAR volatile spinlock_t *lock); +static inline_function bool +spin_trylock_wo_note(FAR volatile spinlock_t *lock) +{ +#ifdef CONFIG_TICKET_SPINLOCK + unsigned short ticket = + atomic_load((FAR atomic_ushort *)&lock->tickets.next); + + spinlock_t old = + { + { + ticket, ticket + } + }; + + spinlock_t new = + { + { + ticket, ticket + 1 + } + }; + + if (!atomic_compare_exchange_strong((FAR atomic_uint *)&lock->value, + &old.value, new.value)) +#else /* CONFIG_TICKET_SPINLOCK */ + if (up_testset(lock) == SP_LOCKED) +#endif /* CONFIG_TICKET_SPINLOCK */ + { + SP_DSB(); + return false; + } + + SP_DMB(); + return true; +} /**************************************************************************** * Name: spin_unlock @@ -296,7 +456,23 @@ bool spin_trylock_wo_note(FAR volatile spinlock_t *lock); ****************************************************************************/ #ifdef __SP_UNLOCK_FUNCTION -void spin_unlock(FAR volatile spinlock_t *lock); +static inline_function void spin_unlock(FAR volatile spinlock_t *lock) +{ +# ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + /* Notify that we are unlocking the spinlock */ + + sched_note_spinlock_unlock(lock); +# endif + + SP_DMB(); +# ifdef CONFIG_TICKET_SPINLOCK + atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.owner, 1); +# else + *lock = SP_UNLOCKED; +# endif + SP_DSB(); + SP_SEV(); +} #else # define spin_unlock(l) do { *(l) = SP_UNLOCKED; } while (0) #endif @@ -321,7 +497,18 @@ void spin_unlock(FAR volatile spinlock_t *lock); * ****************************************************************************/ -void spin_unlock_wo_note(FAR volatile spinlock_t *lock); +static inline_function void +spin_unlock_wo_note(FAR volatile spinlock_t *lock) +{ + SP_DMB(); +#ifdef CONFIG_TICKET_SPINLOCK + atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.owner, 1); +#else + *lock = SP_UNLOCKED; +#endif + SP_DSB(); + SP_SEV(); +} /**************************************************************************** * Name: spin_is_locked @@ -502,7 +689,26 @@ void spin_unlock_irqrestore_wo_note(FAR spinlock_t *lock, irqstate_t flags); * ****************************************************************************/ -void read_lock(FAR volatile rwlock_t *lock); +static inline_function void read_lock(FAR volatile rwlock_t *lock) +{ + while (true) + { + int old = atomic_load((FAR atomic_int *)lock); + if (old <= RW_SP_WRITE_LOCKED) + { + DEBUGASSERT(old == RW_SP_WRITE_LOCKED); + SP_DSB(); + SP_WFE(); + } + else if(atomic_compare_exchange_strong((FAR atomic_int *)lock, + &old, old + 1)) + { + break; + } + } + + SP_DMB(); +} /**************************************************************************** * Name: read_trylock @@ -528,7 +734,26 @@ void read_lock(FAR volatile rwlock_t *lock); * ****************************************************************************/ -bool read_trylock(FAR volatile rwlock_t *lock); +static inline_function bool read_trylock(FAR volatile rwlock_t *lock) +{ + while (true) + { + int old = atomic_load((FAR atomic_int *)lock); + if (old <= RW_SP_WRITE_LOCKED) + { + DEBUGASSERT(old == RW_SP_WRITE_LOCKED); + return false; + } + else if (atomic_compare_exchange_strong((FAR atomic_int *)lock, + &old, old + 1)) + { + break; + } + } + + SP_DMB(); + return true; +} /**************************************************************************** * Name: read_unlock @@ -547,7 +772,15 @@ bool read_trylock(FAR volatile rwlock_t *lock); * ****************************************************************************/ -void read_unlock(FAR volatile rwlock_t *lock); +static inline_function void read_unlock(FAR volatile rwlock_t *lock) +{ + DEBUGASSERT(atomic_load((FAR atomic_int *)lock) >= RW_SP_READ_LOCKED); + + SP_DMB(); + atomic_fetch_sub((FAR atomic_int *)lock, 1); + SP_DSB(); + SP_SEV(); +} /**************************************************************************** * Name: write_lock @@ -574,7 +807,19 @@ void read_unlock(FAR volatile rwlock_t *lock); * ****************************************************************************/ -void write_lock(FAR volatile rwlock_t *lock); +static inline_function void write_lock(FAR volatile rwlock_t *lock) +{ + int zero = RW_SP_UNLOCKED; + + while (!atomic_compare_exchange_strong((FAR atomic_int *)lock, + &zero, RW_SP_WRITE_LOCKED)) + { + SP_DSB(); + SP_WFE(); + } + + SP_DMB(); +} /**************************************************************************** * Name: write_trylock @@ -601,7 +846,20 @@ void write_lock(FAR volatile rwlock_t *lock); * ****************************************************************************/ -bool write_trylock(FAR volatile rwlock_t *lock); +static inline_function bool write_trylock(FAR volatile rwlock_t *lock) +{ + int zero = RW_SP_UNLOCKED; + + if (atomic_compare_exchange_strong((FAR atomic_int *)lock, + &zero, RW_SP_WRITE_LOCKED)) + { + SP_DMB(); + return true; + } + + SP_DSB(); + return false; +} /**************************************************************************** * Name: write_unlock @@ -620,7 +878,17 @@ bool write_trylock(FAR volatile rwlock_t *lock); * ****************************************************************************/ -void write_unlock(FAR volatile rwlock_t *lock); +static inline_function void write_unlock(FAR volatile rwlock_t *lock) +{ + /* Ensure this cpu already get write lock */ + + DEBUGASSERT(atomic_load((FAR atomic_int *)lock) == RW_SP_WRITE_LOCKED); + + SP_DMB(); + atomic_store((FAR atomic_int *)lock, RW_SP_UNLOCKED); + SP_DSB(); + SP_SEV(); +} /**************************************************************************** * Name: read_lock_irqsave @@ -767,6 +1035,7 @@ void write_unlock_irqrestore(FAR rwlock_t *lock, irqstate_t flags); #endif #endif /* CONFIG_RW_SPINLOCK */ +#endif /* CONFIG_HAVE_INLINE_SPINLOCK */ #undef EXTERN #if defined(__cplusplus) diff --git a/sched/group/group_leave.c b/sched/group/group_leave.c index fe452f27c4..4cab22c46a 100644 --- a/sched/group/group_leave.c +++ b/sched/group/group_leave.c @@ -34,6 +34,7 @@ #include #include #include +#include #ifdef CONFIG_BINFMT_LOADABLE # include diff --git a/sched/irq/irq_csection.c b/sched/irq/irq_csection.c index 175ce0dace..24f6a98904 100644 --- a/sched/irq/irq_csection.c +++ b/sched/irq/irq_csection.c @@ -117,7 +117,7 @@ volatile uint8_t g_cpu_nestcount[CONFIG_SMP_NCPUS]; ****************************************************************************/ #ifdef CONFIG_SMP -static bool irq_waitlock(int cpu) +static inline_function bool irq_waitlock(int cpu) { #ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS FAR struct tcb_s *tcb = current_task(cpu); diff --git a/sched/semaphore/CMakeLists.txt b/sched/semaphore/CMakeLists.txt index 9ed4e0bdfa..8d378e04b0 100644 --- a/sched/semaphore/CMakeLists.txt +++ b/sched/semaphore/CMakeLists.txt @@ -36,12 +36,4 @@ if(CONFIG_PRIORITY_INHERITANCE) list(APPEND CSRCS sem_initialize.c sem_holder.c sem_setprotocol.c) endif() -if(CONFIG_SPINLOCK) - list(APPEND CSRCS spinlock.c) -endif() - -if(CONFIG_TICKET_SPINLOCK) - list(APPEND CSRCS spinlock.c) -endif() - target_sources(sched PRIVATE ${CSRCS}) diff --git a/sched/semaphore/Make.defs b/sched/semaphore/Make.defs index 71dcc26d12..f2a9e7ffb4 100644 --- a/sched/semaphore/Make.defs +++ b/sched/semaphore/Make.defs @@ -28,10 +28,6 @@ ifeq ($(CONFIG_PRIORITY_INHERITANCE),y) CSRCS += sem_initialize.c sem_holder.c sem_setprotocol.c endif -ifeq ($(CONFIG_SPINLOCK),y) -CSRCS += spinlock.c -endif - # Include semaphore build support DEPPATH += --dep-path semaphore diff --git a/sched/semaphore/spinlock.c b/sched/semaphore/spinlock.c deleted file mode 100644 index 49eeb752dc..0000000000 --- a/sched/semaphore/spinlock.c +++ /dev/null @@ -1,560 +0,0 @@ -/**************************************************************************** - * sched/semaphore/spinlock.c - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. The - * ASF licenses this file to you under the Apache License, Version 2.0 (the - * "License"); you may not use this file except in compliance with the - * License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - ****************************************************************************/ - -/**************************************************************************** - * Included Files - ****************************************************************************/ - -#include - -#include -#include -#include -#include - -#include -#include -#include - -#if defined(CONFIG_TICKET_SPINLOCK) || defined(CONFIG_RW_SPINLOCK) -# include -#endif - -#include "sched/sched.h" - -#if defined(CONFIG_SPINLOCK) || defined(CONFIG_TICKET_SPINLOCK) - -/**************************************************************************** - * Public Functions - ****************************************************************************/ - -/**************************************************************************** - * Name: spin_lock - * - * Description: - * If this CPU does not already hold the spinlock, then loop until the - * spinlock is successfully locked. - * - * This implementation is non-reentrant and is prone to deadlocks in - * the case that any logic on the same CPU attempts to take the lock - * more than once. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * None. When the function returns, the spinlock was successfully locked - * by this CPU. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void spin_lock(FAR volatile spinlock_t *lock) -{ -#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS - /* Notify that we are waiting for a spinlock */ - - sched_note_spinlock(this_task(), lock, NOTE_SPINLOCK_LOCK); -#endif - -#ifdef CONFIG_TICKET_SPINLOCK - unsigned short ticket = - atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.next, 1); - while (atomic_load((FAR atomic_ushort *)&lock->tickets.owner) != ticket) -#else /* CONFIG_SPINLOCK */ - while (up_testset(lock) == SP_LOCKED) -#endif - { - SP_DSB(); - SP_WFE(); - } - -#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS - /* Notify that we have the spinlock */ - - sched_note_spinlock(this_task(), lock, NOTE_SPINLOCK_LOCKED); -#endif - SP_DMB(); -} - -/**************************************************************************** - * Name: spin_lock_wo_note - * - * Description: - * If this CPU does not already hold the spinlock, then loop until the - * spinlock is successfully locked. - * - * This implementation is the same as the above spin_lock() except that - * it does not perform instrumentation logic. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * None. When the function returns, the spinlock was successfully locked - * by this CPU. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void spin_lock_wo_note(FAR volatile spinlock_t *lock) -{ -#ifdef CONFIG_TICKET_SPINLOCK - unsigned short ticket = - atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.next, 1); - while (atomic_load((FAR atomic_ushort *)&lock->tickets.owner) != ticket) -#else /* CONFIG_TICKET_SPINLOCK */ - while (up_testset(lock) == SP_LOCKED) -#endif - { - SP_DSB(); - SP_WFE(); - } - - SP_DMB(); -} - -/**************************************************************************** - * Name: spin_trylock - * - * Description: - * Try once to lock the spinlock. Do not wait if the spinlock is already - * locked. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * false - Failure, the spinlock was already locked - * true - Success, the spinlock was successfully locked - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -bool spin_trylock(FAR volatile spinlock_t *lock) -{ -#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS - /* Notify that we are waiting for a spinlock */ - - sched_note_spinlock(this_task(), lock, NOTE_SPINLOCK_LOCK); -#endif - -#ifdef CONFIG_TICKET_SPINLOCK - unsigned short ticket = - atomic_load((FAR atomic_ushort *)&lock->tickets.next); - - spinlock_t old = - { - { - ticket, ticket - } - }; - - spinlock_t new = - { - { - ticket, ticket + 1 - } - }; - - if (!atomic_compare_exchange_strong((FAR atomic_uint *)&lock->value, - &old.value, new.value)) -#else /* CONFIG_TICKET_SPINLOCK */ - if (up_testset(lock) == SP_LOCKED) -#endif /* CONFIG_TICKET_SPINLOCK */ - { -#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS - /* Notify that we abort for a spinlock */ - - sched_note_spinlock(this_task(), lock, NOTE_SPINLOCK_ABORT); -#endif - SP_DSB(); - return false; - } - -#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS - /* Notify that we have the spinlock */ - - sched_note_spinlock(this_task(), lock, NOTE_SPINLOCK_LOCKED); -#endif - SP_DMB(); - return true; -} - -/**************************************************************************** - * Name: spin_trylock_wo_note - * - * Description: - * Try once to lock the spinlock. Do not wait if the spinlock is already - * locked. - * - * This implementation is the same as the above spin_trylock() except that - * it does not perform instrumentation logic. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * false - Failure, the spinlock was already locked - * true - Success, the spinlock was successfully locked - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -bool spin_trylock_wo_note(FAR volatile spinlock_t *lock) -{ -#ifdef CONFIG_TICKET_SPINLOCK - unsigned short ticket = - atomic_load((FAR atomic_ushort *)&lock->tickets.next); - - spinlock_t old = - { - { - ticket, ticket - } - }; - - spinlock_t new = - { - { - ticket, ticket + 1 - } - }; - - if (!atomic_compare_exchange_strong((FAR atomic_uint *)&lock->value, - &old.value, new.value)) -#else /* CONFIG_TICKET_SPINLOCK */ - if (up_testset(lock) == SP_LOCKED) -#endif /* CONFIG_TICKET_SPINLOCK */ - { - SP_DSB(); - return false; - } - - SP_DMB(); - return true; -} - -/**************************************************************************** - * Name: spin_unlock - * - * Description: - * Release one count on a non-reentrant spinlock. - * - * Input Parameters: - * lock - A reference to the spinlock object to unlock. - * - * Returned Value: - * None. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -#ifdef __SP_UNLOCK_FUNCTION -void spin_unlock(FAR volatile spinlock_t *lock) -{ -#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS - /* Notify that we are unlocking the spinlock */ - - sched_note_spinlock(this_task(), lock, NOTE_SPINLOCK_UNLOCK); -#endif - - SP_DMB(); -#ifdef CONFIG_TICKET_SPINLOCK - atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.owner, 1); -#else - *lock = SP_UNLOCKED; -#endif - SP_DSB(); - SP_SEV(); -} -#endif - -/**************************************************************************** - * Name: spin_unlock_wo_note - * - * Description: - * Release one count on a non-reentrant spinlock. - * - * This implementation is the same as the above spin_unlock() except that - * it does not perform instrumentation logic. - * - * Input Parameters: - * lock - A reference to the spinlock object to unlock. - * - * Returned Value: - * None. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void spin_unlock_wo_note(FAR volatile spinlock_t *lock) -{ - SP_DMB(); -#ifdef CONFIG_TICKET_SPINLOCK - atomic_fetch_add((FAR atomic_ushort *)&lock->tickets.owner, 1); -#else - *lock = SP_UNLOCKED; -#endif - SP_DSB(); - SP_SEV(); -} - -#ifdef CONFIG_RW_SPINLOCK - -/**************************************************************************** - * Name: read_lock - * - * Description: - * If this task does not already hold the spinlock, then loop until the - * spinlock is successfully locked. - * - * This implementation is non-reentrant and set a bit of lock. - * - * The priority of reader is higher than writter if a reader hold the - * lock, a new reader can get its lock but writer can't get this lock. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * None. When the function returns, the spinlock was successfully locked - * by this CPU. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void read_lock(FAR volatile rwlock_t *lock) -{ - while (true) - { - int old = atomic_load((FAR atomic_int *)lock); - if (old <= RW_SP_WRITE_LOCKED) - { - DEBUGASSERT(old == RW_SP_WRITE_LOCKED); - SP_DSB(); - SP_WFE(); - } - else if(atomic_compare_exchange_strong((FAR atomic_int *)lock, - &old, old + 1)) - { - break; - } - } - - SP_DMB(); -} - -/**************************************************************************** - * Name: read_trylock - * - * Description: - * If this task does not already hold the spinlock, then try to get the - * lock. - * - * This implementation is non-reentrant and set a bit of lock. - * - * The priority of reader is higher than writter if a reader hold the - * lock, a new reader can get its lock but writer can't get this lock. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * false - Failure, the spinlock was already locked - * true - Success, the spinlock was successfully locked - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -bool read_trylock(FAR volatile rwlock_t *lock) -{ - while (true) - { - int old = atomic_load((FAR atomic_int *)lock); - if (old <= RW_SP_WRITE_LOCKED) - { - DEBUGASSERT(old == RW_SP_WRITE_LOCKED); - return false; - } - else if (atomic_compare_exchange_strong((FAR atomic_int *)lock, - &old, old + 1)) - { - break; - } - } - - SP_DMB(); - return true; -} - -/**************************************************************************** - * Name: read_unlock - * - * Description: - * Release a bit on a non-reentrant spinlock. - * - * Input Parameters: - * lock - A reference to the spinlock object to unlock. - * - * Returned Value: - * None. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void read_unlock(FAR volatile rwlock_t *lock) -{ - DEBUGASSERT(atomic_load((FAR atomic_int *)lock) >= RW_SP_READ_LOCKED); - - SP_DMB(); - atomic_fetch_sub((FAR atomic_int *)lock, 1); - SP_DSB(); - SP_SEV(); -} - -/**************************************************************************** - * Name: write_lock - * - * Description: - * If this task does not already hold the spinlock, then loop until the - * spinlock is successfully locked. - * - * This implementation is non-reentrant and set all bit on lock to avoid - * readers and writers. - * - * The priority of reader is higher than writter if a reader hold the - * lock, a new reader can get its lock but writer can't get this lock. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * None. When the function returns, the spinlock was successfully locked - * by this CPU. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void write_lock(FAR volatile rwlock_t *lock) -{ - int zero = RW_SP_UNLOCKED; - - while (!atomic_compare_exchange_strong((FAR atomic_int *)lock, - &zero, RW_SP_WRITE_LOCKED)) - { - SP_DSB(); - SP_WFE(); - } - - SP_DMB(); -} - -/**************************************************************************** - * Name: write_trylock - * - * Description: - * If this task does not already hold the spinlock, then loop until the - * spinlock is successfully locked. - * - * This implementation is non-reentrant and set all bit on lock to avoid - * readers and writers. - * - * The priority of reader is higher than writter if a reader hold the - * lock, a new reader can get its lock but writer can't get this lock. - * - * Input Parameters: - * lock - A reference to the spinlock object to lock. - * - * Returned Value: - * false - Failure, the spinlock was already locked - * true - Success, the spinlock was successfully locked - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -bool write_trylock(FAR volatile rwlock_t *lock) -{ - int zero = RW_SP_UNLOCKED; - - if (atomic_compare_exchange_strong((FAR atomic_int *)lock, - &zero, RW_SP_WRITE_LOCKED)) - { - SP_DMB(); - return true; - } - - SP_DSB(); - return false; -} - -/**************************************************************************** - * Name: write_unlock - * - * Description: - * Release write lock on a non-reentrant spinlock. - * - * Input Parameters: - * lock - A reference to the spinlock object to unlock. - * - * Returned Value: - * None. - * - * Assumptions: - * Not running at the interrupt level. - * - ****************************************************************************/ - -void write_unlock(FAR volatile rwlock_t *lock) -{ - /* Ensure this cpu already get write lock */ - - DEBUGASSERT(atomic_load((FAR atomic_int *)lock) == RW_SP_WRITE_LOCKED); - - SP_DMB(); - atomic_store((FAR atomic_int *)lock, RW_SP_UNLOCKED); - SP_DSB(); - SP_SEV(); -} - -#endif /* CONFIG_RW_SPINLOCK */ -#endif /* CONFIG_SPINLOCK */ diff --git a/sched/signal/sig_findaction.c b/sched/signal/sig_findaction.c index a0ef73171e..0c24bd761e 100644 --- a/sched/signal/sig_findaction.c +++ b/sched/signal/sig_findaction.c @@ -23,6 +23,8 @@ ****************************************************************************/ #include + +#include #include "signal/signal.h" /****************************************************************************