From 5e23c4a79b8e261dba7b43349985050e984ed6e2 Mon Sep 17 00:00:00 2001 From: hujun5 Date: Fri, 22 Nov 2024 10:05:12 +0800 Subject: [PATCH] spinlock: use inline replace macro reason: we.avoid.use gcc express statement extension in spinlock, to enhance compatibility Signed-off-by: hujun5 --- include/nuttx/spinlock.h | 66 +++++++++++++++++++++++++--------------- 1 file changed, 42 insertions(+), 24 deletions(-) diff --git a/include/nuttx/spinlock.h b/include/nuttx/spinlock.h index bd15818d6a..867ce0ad3c 100644 --- a/include/nuttx/spinlock.h +++ b/include/nuttx/spinlock.h @@ -633,19 +633,28 @@ irqstate_t spin_lock_irqsave(FAR volatile spinlock_t *lock) ****************************************************************************/ #ifdef CONFIG_SPINLOCK -# define spin_trylock_irqsave_wo_note(l, f) \ -({ \ - f = up_irq_save(); \ - spin_trylock_wo_note(l) ? \ - true : ({ up_irq_restore(f); false; }); \ -}) +static inline_function +bool spin_trylock_irqsave_wo_note(FAR volatile spinlock_t *lock, + FAR irqstate_t *flags) +{ + *flags = up_irq_save(); + + if (!spin_trylock_wo_note(lock)) + { + up_irq_restore(*flags); + return false; + } + + return true; +} #else -# define spin_trylock_irqsave_wo_note(l, f) \ -({ \ - (void)(l); \ - f = up_irq_save(); \ - true; \ -}) +static inline_function +bool spin_trylock_irqsave_wo_note(FAR volatile spinlock_t *lock, + FAR irqstate_t *flags) +{ + *flags = up_irq_save(); + return true; +} #endif /* CONFIG_SPINLOCK */ /**************************************************************************** @@ -669,19 +678,28 @@ irqstate_t spin_lock_irqsave(FAR volatile spinlock_t *lock) ****************************************************************************/ #ifdef CONFIG_SPINLOCK -# define spin_trylock_irqsave(l, f) \ -({ \ - f = up_irq_save(); \ - spin_trylock(l) ? \ - true : ({ up_irq_restore(f); false; }); \ -}) +static inline_function +bool spin_trylock_irqsave(FAR volatile spinlock_t *lock, + FAR irqstate_t *flags) +{ + *flags = up_irq_save(); + + if (!spin_trylock(lock)) + { + up_irq_restore(*flags); + return false; + } + + return true; +} #else -# define spin_trylock_irqsave(l, f) \ -({ \ - (void)(l); \ - f = up_irq_save(); \ - true; \ -}) +static inline_function +bool spin_trylock_irqsave(FAR volatile spinlock_t *lock, + FAR irqstate_t *flags) +{ + *flags = up_irq_save(); + return true; +} #endif /* CONFIG_SPINLOCK */ /****************************************************************************