mirror of https://github.com/ARMmbed/mbed-os.git
Merge pull request #13906 from jeromecoutant/PR_G070
STM32G070: generic target creationpull/13978/head
commit
33a7e66a07
|
@ -28,6 +28,8 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define RTC_WKUP_IRQn RTC_TAMP_IRQn
|
||||||
|
|
||||||
struct gpio_irq_s {
|
struct gpio_irq_s {
|
||||||
IRQn_Type irq_n;
|
IRQn_Type irq_n;
|
||||||
uint32_t irq_index;
|
uint32_t irq_index;
|
||||||
|
|
|
@ -129,24 +129,32 @@ void serial_irq_set(serial_t *obj, SerialIrq irq, uint32_t enable)
|
||||||
|
|
||||||
#if defined(USART3_BASE)
|
#if defined(USART3_BASE)
|
||||||
if (obj_s->uart == UART_3) {
|
if (obj_s->uart == UART_3) {
|
||||||
|
#if defined(LPUART1_BASE)
|
||||||
irq_n = USART3_4_LPUART1_IRQn;
|
irq_n = USART3_4_LPUART1_IRQn;
|
||||||
|
#else
|
||||||
|
irq_n = USART3_4_IRQn;
|
||||||
|
#endif
|
||||||
vector = (uint32_t)&uart3_irq;
|
vector = (uint32_t)&uart3_irq;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(USART4_BASE)
|
#if defined(USART4_BASE)
|
||||||
if (obj_s->uart == UART_4) {
|
if (obj_s->uart == UART_4) {
|
||||||
|
#if defined(LPUART1_BASE)
|
||||||
irq_n = USART3_4_LPUART1_IRQn;
|
irq_n = USART3_4_LPUART1_IRQn;
|
||||||
|
#else
|
||||||
|
irq_n = USART3_4_IRQn;
|
||||||
|
#endif
|
||||||
vector = (uint32_t)&uart4_irq;
|
vector = (uint32_t)&uart4_irq;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LPUART1_BASE)
|
#if defined(LPUART1_BASE)
|
||||||
if (obj_s->uart == LPUART_1) {
|
if (obj_s->uart == LPUART_1) {
|
||||||
#if defined(STM32G031xx)
|
#if defined(USART3_BASE)
|
||||||
irq_n = LPUART1_IRQn;
|
|
||||||
#else
|
|
||||||
irq_n = USART3_4_LPUART1_IRQn;
|
irq_n = USART3_4_LPUART1_IRQn;
|
||||||
|
#else
|
||||||
|
irq_n = LPUART1_IRQn;
|
||||||
#endif
|
#endif
|
||||||
vector = (uint32_t)&lpuart1_irq;
|
vector = (uint32_t)&lpuart1_irq;
|
||||||
}
|
}
|
||||||
|
@ -326,21 +334,29 @@ static IRQn_Type serial_get_irq_n(UARTName uart_name)
|
||||||
#endif
|
#endif
|
||||||
#if defined(USART3_BASE)
|
#if defined(USART3_BASE)
|
||||||
case UART_3:
|
case UART_3:
|
||||||
|
#if defined(LPUART1_BASE)
|
||||||
irq_n = USART3_4_LPUART1_IRQn;
|
irq_n = USART3_4_LPUART1_IRQn;
|
||||||
|
#else
|
||||||
|
irq_n = USART3_4_IRQn;
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#if defined(USART4_BASE)
|
#if defined(USART4_BASE)
|
||||||
case UART_4:
|
case UART_4:
|
||||||
|
#if defined(LPUART1_BASE)
|
||||||
irq_n = USART3_4_LPUART1_IRQn;
|
irq_n = USART3_4_LPUART1_IRQn;
|
||||||
|
#else
|
||||||
|
irq_n = USART3_4_IRQn;
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LPUART1_BASE)
|
#if defined(LPUART1_BASE)
|
||||||
case LPUART_1:
|
case LPUART_1:
|
||||||
#if defined(STM32G031xx)
|
#if defined(USART3_BASE)
|
||||||
irq_n = LPUART1_IRQn;
|
|
||||||
#else
|
|
||||||
irq_n = USART3_4_LPUART1_IRQn;
|
irq_n = USART3_4_LPUART1_IRQn;
|
||||||
|
#else
|
||||||
|
irq_n = LPUART1_IRQn;
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -16,13 +16,15 @@
|
||||||
#define __US_TICKER_DATA_H
|
#define __US_TICKER_DATA_H
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "stm32g0xx.h"
|
#include "stm32g0xx.h"
|
||||||
#include "stm32g0xx_ll_tim.h"
|
#include "stm32g0xx_ll_tim.h"
|
||||||
#include "cmsis_nvic.h"
|
#include "cmsis_nvic.h"
|
||||||
|
|
||||||
|
#if defined TIM2_BASE
|
||||||
|
|
||||||
#define TIM_MST TIM2
|
#define TIM_MST TIM2
|
||||||
#define TIM_MST_IRQ TIM2_IRQn
|
#define TIM_MST_IRQ TIM2_IRQn
|
||||||
#define TIM_MST_RCC __TIM2_CLK_ENABLE()
|
#define TIM_MST_RCC __TIM2_CLK_ENABLE()
|
||||||
|
@ -33,12 +35,24 @@
|
||||||
|
|
||||||
#define TIM_MST_BIT_WIDTH 32 // 16 or 32
|
#define TIM_MST_BIT_WIDTH 32 // 16 or 32
|
||||||
|
|
||||||
#define TIM_MST_PCLK 1 // Select the peripheral clock number (1 or 2)
|
#else // TIM2_BASE
|
||||||
|
|
||||||
|
#define TIM_MST TIM3
|
||||||
|
#define TIM_MST_IRQ TIM3_IRQn
|
||||||
|
#define TIM_MST_RCC __TIM3_CLK_ENABLE()
|
||||||
|
#define TIM_MST_DBGMCU_FREEZE __HAL_DBGMCU_FREEZE_TIM3()
|
||||||
|
|
||||||
|
#define TIM_MST_RESET_ON __TIM3_FORCE_RESET()
|
||||||
|
#define TIM_MST_RESET_OFF __TIM3_RELEASE_RESET()
|
||||||
|
|
||||||
|
#define TIM_MST_BIT_WIDTH 16 // 16 or 32
|
||||||
|
|
||||||
|
#endif // TIM2_BASE
|
||||||
|
|
||||||
|
#define TIM_MST_PCLK 1 // Select the peripheral clock number (1 or 2)
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif // __US_TICKER_DATA_H
|
#endif // __US_TICKER_DATA_H
|
||||||
|
|
||||||
|
|
|
@ -2472,6 +2472,26 @@
|
||||||
],
|
],
|
||||||
"device_name": "STM32G031K8Tx"
|
"device_name": "STM32G031K8Tx"
|
||||||
},
|
},
|
||||||
|
"MCU_STM32G070xx": {
|
||||||
|
"inherits": [
|
||||||
|
"MCU_STM32G0"
|
||||||
|
],
|
||||||
|
"public": false,
|
||||||
|
"extra_labels_add": [
|
||||||
|
"STM32G070xx"
|
||||||
|
],
|
||||||
|
"macros_add": [
|
||||||
|
"STM32G070xx"
|
||||||
|
],
|
||||||
|
"macros_remove": [
|
||||||
|
"EXTRA_IDLE_STACK_REQUIRED",
|
||||||
|
"MBED_TICKLESS"
|
||||||
|
],
|
||||||
|
"overrides": {
|
||||||
|
"lpticker_delay_ticks": 1,
|
||||||
|
"lpticker_lptim": "0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"MCU_STM32G071xx": {
|
"MCU_STM32G071xx": {
|
||||||
"inherits": [
|
"inherits": [
|
||||||
"MCU_STM32G0"
|
"MCU_STM32G0"
|
||||||
|
|
Loading…
Reference in New Issue