use small lock in following file

arch/or1k/src/mor1kx/mor1kx_serial.c
arch/risc-v/src/bl602/bl602_serial.c
arch/risc-v/src/common/espressif/esp_lowputc.c
arch/risc-v/src/common/espressif/esp_lowputc.h
arch/risc-v/src/common/espressif/esp_tickless.c
arch/risc-v/src/esp32c3-legacy/esp32c3_idle.c
arch/risc-v/src/esp32c3-legacy/esp32c3_lowputc.c
arch/risc-v/src/esp32c3-legacy/esp32c3_lowputc.h
arch/risc-v/src/esp32c3-legacy/esp32c3_rtc_lowerhalf.c
arch/risc-v/src/fe310/fe310_gpio.c

Signed-off-by: hujun5 <hujun5@xiaomi.com>
This commit is contained in:
hujun5 2024-12-20 21:44:51 +08:00 committed by Xiang Xiao
parent d59b8f25b8
commit 97eef351dc
10 changed files with 71 additions and 33 deletions

View file

@ -52,6 +52,14 @@
#define OR1K_BAUD (115200) #define OR1K_BAUD (115200)
#define OR1K_DIVISOR (OR1K_SYS_CLK / (16*OR1K_BAUD)) #define OR1K_DIVISOR (OR1K_SYS_CLK / (16*OR1K_BAUD))
/****************************************************************************
* Private Data
****************************************************************************/
#ifdef HAVE_SERIAL_CONSOLE
static spinlock_t g_serial_lock = SP_UNLOCKED;
#endif
/**************************************************************************** /****************************************************************************
* Public Functions * Public Functions
****************************************************************************/ ****************************************************************************/
@ -117,10 +125,10 @@ void up_putc(int ch)
* interrupts from firing in the serial driver code. * interrupts from firing in the serial driver code.
*/ */
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_serial_lock);
/* or1k_lowputc(ch); */ /* or1k_lowputc(ch); */
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_serial_lock, flags);
#endif #endif
} }

View file

@ -152,6 +152,8 @@ static bool bl602_txempty(struct uart_dev_s *dev);
* Private Data * Private Data
****************************************************************************/ ****************************************************************************/
static spinlock_t g_bl602_serial_lock = SP_UNLOCKED;
static const struct uart_ops_s g_uart_ops = static const struct uart_ops_s g_uart_ops =
{ {
.setup = bl602_setup, .setup = bl602_setup,
@ -891,10 +893,10 @@ void riscv_serialinit(void)
void up_putc(int ch) void up_putc(int ch)
{ {
#ifdef HAVE_SERIAL_CONSOLE #ifdef HAVE_SERIAL_CONSOLE
irqstate_t flags = spin_lock_irqsave(NULL); irqstate_t flags = spin_lock_irqsave(&g_bl602_serial_lock);
riscv_lowputc(ch); riscv_lowputc(ch);
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_bl602_serial_lock, flags);
#endif #endif
} }

View file

@ -102,7 +102,8 @@ struct esp_uart_s g_uart0_config =
.oflow = false, /* output flow control (CTS) disabled */ .oflow = false, /* output flow control (CTS) disabled */
#endif #endif
#endif #endif
.hal = &g_uart0_hal .hal = &g_uart0_hal,
.lock = SP_UNLOCKED
}; };
#endif /* CONFIG_ESPRESSIF_UART0 */ #endif /* CONFIG_ESPRESSIF_UART0 */
@ -147,7 +148,8 @@ struct esp_uart_s g_uart1_config =
.oflow = false, /* output flow control (CTS) disabled */ .oflow = false, /* output flow control (CTS) disabled */
#endif #endif
#endif #endif
.hal = &g_uart1_hal .hal = &g_uart1_hal,
.lock = SP_UNLOCKED
}; };
#endif /* CONFIG_ESPRESSIF_UART1 */ #endif /* CONFIG_ESPRESSIF_UART1 */
@ -210,7 +212,7 @@ void esp_lowputc_disable_all_uart_int(const struct esp_uart_s *priv,
{ {
irqstate_t flags; irqstate_t flags;
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&priv->lock);
if (current_status != NULL) if (current_status != NULL)
{ {
@ -227,7 +229,7 @@ void esp_lowputc_disable_all_uart_int(const struct esp_uart_s *priv,
uart_hal_clr_intsts_mask(priv->hal, UINT32_MAX); uart_hal_clr_intsts_mask(priv->hal, UINT32_MAX);
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&priv->lock, flags);
} }
/**************************************************************************** /****************************************************************************

View file

@ -39,6 +39,7 @@
#include <nuttx/arch.h> #include <nuttx/arch.h>
#include <nuttx/irq.h> #include <nuttx/irq.h>
#include <nuttx/spinlock.h>
#include "chip.h" #include "chip.h"
#include "esp_irq.h" #include "esp_irq.h"
@ -76,6 +77,7 @@ struct esp_uart_s
bool oflow; /* Output flow control (CTS) enabled */ bool oflow; /* Output flow control (CTS) enabled */
#endif #endif
uart_hal_context_t *hal; /* HAL context */ uart_hal_context_t *hal; /* HAL context */
spinlock_t lock; /* Spinlock */
}; };
extern struct esp_uart_s g_uart0_config; extern struct esp_uart_s g_uart0_config;

View file

@ -59,6 +59,8 @@
* Private Data * Private Data
****************************************************************************/ ****************************************************************************/
static spinlock_t g_esp_tickless_lock = SP_UNLOCKED;
/* Systimer HAL layer object */ /* Systimer HAL layer object */
static systimer_hal_context_t systimer_hal; static systimer_hal_context_t systimer_hal;
@ -126,10 +128,10 @@ uint32_t up_get_idletime(void)
uint64_t counter; uint64_t counter;
irqstate_t flags; irqstate_t flags;
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_esp_tickless_lock);
if (!g_timer_started) if (!g_timer_started)
{ {
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp_tickless_lock, flags);
return 0; return 0;
} }
@ -147,7 +149,7 @@ uint32_t up_get_idletime(void)
us = 0; us = 0;
} }
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp_tickless_lock, flags);
return us; return us;
} }
@ -172,12 +174,12 @@ void up_step_idletime(uint32_t idletime_us)
DEBUGASSERT(g_timer_started); DEBUGASSERT(g_timer_started);
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_esp_tickless_lock);
systimer_hal_counter_value_advance(&systimer_hal, SYSTIMER_COUNTER_OS_TICK, systimer_hal_counter_value_advance(&systimer_hal, SYSTIMER_COUNTER_OS_TICK,
idletime_us); idletime_us);
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp_tickless_lock, flags);
} }
/**************************************************************************** /****************************************************************************
@ -216,13 +218,13 @@ void up_step_idletime(uint32_t idletime_us)
int IRAM_ATTR up_timer_gettime(struct timespec *ts) int IRAM_ATTR up_timer_gettime(struct timespec *ts)
{ {
uint64_t time_us; uint64_t time_us;
irqstate_t flags = spin_lock_irqsave(NULL); irqstate_t flags = spin_lock_irqsave(&g_esp_tickless_lock);
time_us = systimer_hal_get_time(&systimer_hal, SYSTIMER_COUNTER_OS_TICK); time_us = systimer_hal_get_time(&systimer_hal, SYSTIMER_COUNTER_OS_TICK);
ts->tv_sec = time_us / USEC_PER_SEC; ts->tv_sec = time_us / USEC_PER_SEC;
ts->tv_nsec = (time_us % USEC_PER_SEC) * NSEC_PER_USEC; ts->tv_nsec = (time_us % USEC_PER_SEC) * NSEC_PER_USEC;
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp_tickless_lock, flags);
return OK; return OK;
} }
@ -267,7 +269,7 @@ int IRAM_ATTR up_timer_cancel(struct timespec *ts)
{ {
irqstate_t flags; irqstate_t flags;
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_esp_tickless_lock);
if (ts != NULL) if (ts != NULL)
{ {
@ -314,7 +316,7 @@ int IRAM_ATTR up_timer_cancel(struct timespec *ts)
systimer_ll_clear_alarm_int(systimer_hal.dev, systimer_ll_clear_alarm_int(systimer_hal.dev,
SYSTIMER_ALARM_OS_TICK_CORE0); SYSTIMER_ALARM_OS_TICK_CORE0);
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp_tickless_lock, flags);
return OK; return OK;
} }
@ -350,7 +352,7 @@ int IRAM_ATTR up_timer_start(const struct timespec *ts)
uint64_t alarm_ticks; uint64_t alarm_ticks;
irqstate_t flags; irqstate_t flags;
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_esp_tickless_lock);
if (g_timer_started) if (g_timer_started)
{ {
@ -375,7 +377,7 @@ int IRAM_ATTR up_timer_start(const struct timespec *ts)
g_timer_started = true; g_timer_started = true;
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp_tickless_lock, flags);
return OK; return OK;
} }

View file

@ -76,6 +76,14 @@
#endif #endif
/****************************************************************************
* Private Data
****************************************************************************/
#ifdef CONFIG_PM
static spinlock_t g_esp32c3_idle_lock = SP_UNLOCKED;
#endif
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
****************************************************************************/ ****************************************************************************/
@ -94,7 +102,7 @@ static void up_idlepm(void)
irqstate_t flags; irqstate_t flags;
#ifdef CONFIG_ESP32C3_AUTO_SLEEP #ifdef CONFIG_ESP32C3_AUTO_SLEEP
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_esp32c3_idle_lock);
if (esp32c3_pm_lockstatus() == 0 && if (esp32c3_pm_lockstatus() == 0 &&
(esp32c3_should_skip_light_sleep() == false)) (esp32c3_should_skip_light_sleep() == false))
{ {
@ -138,7 +146,7 @@ static void up_idlepm(void)
} }
} }
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp32c3_idle_lock, flags);
#else /* CONFIG_ESP32C3_AUTO_SLEEP */ #else /* CONFIG_ESP32C3_AUTO_SLEEP */
static enum pm_state_e oldstate = PM_NORMAL; static enum pm_state_e oldstate = PM_NORMAL;
enum pm_state_e newstate; enum pm_state_e newstate;
@ -152,7 +160,7 @@ static void up_idlepm(void)
if (newstate != oldstate) if (newstate != oldstate)
{ {
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_esp32c3_idle_lock);
/* Perform board-specific, state-dependent logic here */ /* Perform board-specific, state-dependent logic here */
@ -174,7 +182,7 @@ static void up_idlepm(void)
oldstate = newstate; oldstate = newstate;
} }
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_esp32c3_idle_lock, flags);
/* MCU-specific power management logic */ /* MCU-specific power management logic */

View file

@ -79,6 +79,7 @@ struct esp32c3_uart_s g_uart0_config =
.txsig = U0TXD_OUT_IDX, .txsig = U0TXD_OUT_IDX,
.rxpin = CONFIG_ESP32C3_UART0_RXPIN, .rxpin = CONFIG_ESP32C3_UART0_RXPIN,
.rxsig = U0RXD_IN_IDX, .rxsig = U0RXD_IN_IDX,
.lock = SP_UNLOCKED,
#ifdef CONFIG_SERIAL_IFLOWCONTROL #ifdef CONFIG_SERIAL_IFLOWCONTROL
.rtspin = CONFIG_ESP32C3_UART0_RTSPIN, .rtspin = CONFIG_ESP32C3_UART0_RTSPIN,
.rtssig = U0RTS_OUT_IDX, .rtssig = U0RTS_OUT_IDX,
@ -118,6 +119,7 @@ struct esp32c3_uart_s g_uart1_config =
.txsig = U1TXD_OUT_IDX, .txsig = U1TXD_OUT_IDX,
.rxpin = CONFIG_ESP32C3_UART1_RXPIN, .rxpin = CONFIG_ESP32C3_UART1_RXPIN,
.rxsig = U1RXD_IN_IDX, .rxsig = U1RXD_IN_IDX,
.lock = SP_UNLOCKED,
#ifdef CONFIG_SERIAL_IFLOWCONTROL #ifdef CONFIG_SERIAL_IFLOWCONTROL
.rtspin = CONFIG_ESP32C3_UART1_RTSPIN, .rtspin = CONFIG_ESP32C3_UART1_RTSPIN,
.rtssig = U1RTS_OUT_IDX, .rtssig = U1RTS_OUT_IDX,
@ -708,12 +710,12 @@ void esp32c3_lowputc_enable_sysclk(const struct esp32c3_uart_s *priv)
* *
****************************************************************************/ ****************************************************************************/
void esp32c3_lowputc_disable_all_uart_int(const struct esp32c3_uart_s *priv, void esp32c3_lowputc_disable_all_uart_int(struct esp32c3_uart_s *priv,
uint32_t *current_status) uint32_t *current_status)
{ {
irqstate_t flags; irqstate_t flags;
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&priv->lock);
if (current_status != NULL) if (current_status != NULL)
{ {
@ -730,7 +732,7 @@ void esp32c3_lowputc_disable_all_uart_int(const struct esp32c3_uart_s *priv,
putreg32(0xffffffff, UART_INT_CLR_REG(priv->id)); putreg32(0xffffffff, UART_INT_CLR_REG(priv->id));
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&priv->lock, flags);
} }
/**************************************************************************** /****************************************************************************

View file

@ -30,6 +30,7 @@
#include <nuttx/config.h> #include <nuttx/config.h>
#include <nuttx/arch.h> #include <nuttx/arch.h>
#include <nuttx/irq.h> #include <nuttx/irq.h>
#include <nuttx/spinlock.h>
#include <sys/types.h> #include <sys/types.h>
#include <stdint.h> #include <stdint.h>
@ -102,6 +103,7 @@ struct esp32c3_uart_s
uint8_t txsig; /* TX signal */ uint8_t txsig; /* TX signal */
uint8_t rxpin; /* RX pin */ uint8_t rxpin; /* RX pin */
uint8_t rxsig; /* RX signal */ uint8_t rxsig; /* RX signal */
spinlock_t lock; /* Spinlock */
#ifdef CONFIG_SERIAL_IFLOWCONTROL #ifdef CONFIG_SERIAL_IFLOWCONTROL
uint8_t rtspin; /* RTS pin number */ uint8_t rtspin; /* RTS pin number */
uint8_t rtssig; /* RTS signal */ uint8_t rtssig; /* RTS signal */
@ -433,7 +435,7 @@ void esp32c3_lowputc_enable_sysclk(const struct esp32c3_uart_s *priv);
* *
****************************************************************************/ ****************************************************************************/
void esp32c3_lowputc_disable_all_uart_int(const struct esp32c3_uart_s *priv, void esp32c3_lowputc_disable_all_uart_int(struct esp32c3_uart_s *priv,
uint32_t *current_status); uint32_t *current_status);
/**************************************************************************** /****************************************************************************

View file

@ -63,6 +63,7 @@ struct esp32c3_lowerhalf_s
*/ */
const struct rtc_ops_s *ops; const struct rtc_ops_s *ops;
spinlock_t lock;
#ifdef CONFIG_RTC_ALARM #ifdef CONFIG_RTC_ALARM
/* Alarm callback information */ /* Alarm callback information */
@ -118,6 +119,7 @@ static const struct rtc_ops_s g_rtc_ops =
static struct esp32c3_lowerhalf_s g_rtc_lowerhalf = static struct esp32c3_lowerhalf_s g_rtc_lowerhalf =
{ {
.ops = &g_rtc_ops, .ops = &g_rtc_ops,
.lock = SP_UNLOCKED,
}; };
/**************************************************************************** /****************************************************************************
@ -378,6 +380,7 @@ static int rtc_lh_setalarm(struct rtc_lowerhalf_s *lower,
static int rtc_lh_setrelative(struct rtc_lowerhalf_s *lower, static int rtc_lh_setrelative(struct rtc_lowerhalf_s *lower,
const struct lower_setrelative_s *alarminfo) const struct lower_setrelative_s *alarminfo)
{ {
struct esp32c3_lowerhalf_s *priv = (struct esp32c3_lowerhalf_s *)lower;
struct lower_setalarm_s setalarm; struct lower_setalarm_s setalarm;
time_t seconds; time_t seconds;
int ret = -EINVAL; int ret = -EINVAL;
@ -389,7 +392,7 @@ static int rtc_lh_setrelative(struct rtc_lowerhalf_s *lower,
if (alarminfo->reltime > 0) if (alarminfo->reltime > 0)
{ {
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&priv->lock);
seconds = alarminfo->reltime; seconds = alarminfo->reltime;
gmtime_r(&seconds, (struct tm *)&setalarm.time); gmtime_r(&seconds, (struct tm *)&setalarm.time);
@ -401,7 +404,7 @@ static int rtc_lh_setrelative(struct rtc_lowerhalf_s *lower,
setalarm.priv = alarminfo->priv; setalarm.priv = alarminfo->priv;
ret = rtc_lh_setalarm(lower, &setalarm); ret = rtc_lh_setalarm(lower, &setalarm);
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&priv->lock, flags);
} }
return ret; return ret;
@ -468,6 +471,7 @@ static int rtc_lh_cancelalarm(struct rtc_lowerhalf_s *lower, int alarmid)
static int rtc_lh_rdalarm(struct rtc_lowerhalf_s *lower, static int rtc_lh_rdalarm(struct rtc_lowerhalf_s *lower,
struct lower_rdalarm_s *alarminfo) struct lower_rdalarm_s *alarminfo)
{ {
struct esp32c3_lowerhalf_s *priv = (struct esp32c3_lowerhalf_s *)lower;
struct timespec ts; struct timespec ts;
int ret; int ret;
irqstate_t flags; irqstate_t flags;
@ -476,13 +480,13 @@ static int rtc_lh_rdalarm(struct rtc_lowerhalf_s *lower,
DEBUGASSERT((RTC_ALARM0 <= alarminfo->id) && DEBUGASSERT((RTC_ALARM0 <= alarminfo->id) &&
(alarminfo->id < RTC_ALARM_LAST)); (alarminfo->id < RTC_ALARM_LAST));
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&priv->lock);
ret = up_rtc_rdalarm(&ts, alarminfo->id); ret = up_rtc_rdalarm(&ts, alarminfo->id);
localtime_r((const time_t *)&ts.tv_sec, localtime_r((const time_t *)&ts.tv_sec,
(struct tm *)alarminfo->time); (struct tm *)alarminfo->time);
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&priv->lock, flags);
return ret; return ret;
} }

View file

@ -38,6 +38,12 @@
#include "fe310_gpio.h" #include "fe310_gpio.h"
#include "fe310_memorymap.h" #include "fe310_memorymap.h"
/****************************************************************************
* Private Data
****************************************************************************/
static spinlock_t g_fe310_gpio_lock = SP_UNLOCKED;
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
****************************************************************************/ ****************************************************************************/
@ -147,7 +153,7 @@ int fe310_gpio_config(uint16_t gpiocfg)
uint32_t pin = fe310_gpio_getpin(gpiocfg); uint32_t pin = fe310_gpio_getpin(gpiocfg);
flags = spin_lock_irqsave(NULL); flags = spin_lock_irqsave(&g_fe310_gpio_lock);
/* Disable IOF for the pin to be used as GPIO */ /* Disable IOF for the pin to be used as GPIO */
@ -182,7 +188,7 @@ int fe310_gpio_config(uint16_t gpiocfg)
break; break;
} }
spin_unlock_irqrestore(NULL, flags); spin_unlock_irqrestore(&g_fe310_gpio_lock, flags);
return ret; return ret;
} }