summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ports/stm32/adc.c6
-rw-r--r--ports/stm32/flash.c9
-rw-r--r--ports/stm32/flashbdev.c2
-rw-r--r--ports/stm32/main.c2
-rw-r--r--ports/stm32/spi.c22
-rw-r--r--ports/stm32/timer.c6
6 files changed, 37 insertions, 10 deletions
diff --git a/ports/stm32/adc.c b/ports/stm32/adc.c
index 5e8a1a152..b25fefadf 100644
--- a/ports/stm32/adc.c
+++ b/ports/stm32/adc.c
@@ -134,8 +134,8 @@
#define VBAT_DIV (4)
#elif defined(STM32H743xx)
#define VBAT_DIV (4)
-#elif defined(STM32L475xx) || defined(STM32L476xx) || \
- defined(STM32L496xx)
+#elif defined(STM32L432xx) || defined(STM32L475xx) || \
+ defined(STM32L476xx) || defined(STM32L496xx)
#define VBAT_DIV (3)
#else
#error Unsupported processor
@@ -281,7 +281,7 @@ STATIC void adc_init_single(pyb_obj_adc_t *adc_obj) {
adcx_init_periph(&adc_obj->handle, ADC_RESOLUTION_12B);
-#if defined(STM32L4)
+#if defined(STM32L4) && defined(ADC_DUALMODE_REGSIMULT_INJECSIMULT)
ADC_MultiModeTypeDef multimode;
multimode.Mode = ADC_MODE_INDEPENDENT;
if (HAL_ADCEx_MultiModeConfigChannel(&adc_obj->handle, &multimode) != HAL_OK)
diff --git a/ports/stm32/flash.c b/ports/stm32/flash.c
index 26f76a174..e1cf707d3 100644
--- a/ports/stm32/flash.c
+++ b/ports/stm32/flash.c
@@ -84,7 +84,7 @@ static const flash_layout_t flash_layout[] = {
#error Unsupported processor
#endif
-#if defined(STM32L4) || defined(STM32H7)
+#if (defined(STM32L4) && defined(SYSCFG_MEMRMP_FB_MODE)) || defined(STM32H7)
// get the bank of a given flash address
static uint32_t get_bank(uint32_t addr) {
@@ -109,7 +109,7 @@ static uint32_t get_bank(uint32_t addr) {
}
}
-#if defined(STM32L4)
+#if (defined(STM32L4) && defined(SYSCFG_MEMRMP_FB_MODE))
// get the page of a given flash address
static uint32_t get_page(uint32_t addr) {
if (addr < (FLASH_BASE + FLASH_BANK_SIZE)) {
@@ -164,6 +164,11 @@ void flash_erase(uint32_t flash_dest, uint32_t num_word32) {
EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
EraseInitStruct.PageAddress = flash_dest;
EraseInitStruct.NbPages = (4 * num_word32 + FLASH_PAGE_SIZE - 4) / FLASH_PAGE_SIZE;
+ #elif (defined(STM32L4) && !defined(SYSCFG_MEMRMP_FB_MODE))
+ __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_ALL_ERRORS);
+ EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
+ EraseInitStruct.Page = flash_dest;
+ EraseInitStruct.NbPages = (4 * num_word32 + FLASH_PAGE_SIZE - 4) / FLASH_PAGE_SIZE;
#elif defined(STM32L4)
__HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_ALL_ERRORS);
diff --git a/ports/stm32/flashbdev.c b/ports/stm32/flashbdev.c
index 193a43762..0b95dcc4f 100644
--- a/ports/stm32/flashbdev.c
+++ b/ports/stm32/flashbdev.c
@@ -94,7 +94,7 @@ STATIC byte flash_cache_mem[0x4000] __attribute__((aligned(4))); // 16k
#define FLASH_MEM_SEG1_START_ADDR (0x08020000) // sector 1
#define FLASH_MEM_SEG1_NUM_BLOCKS (256) // Sector 1: 128k / 512b = 256 blocks
-#elif defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L496xx)
+#elif defined(STM32L432xx) || defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L496xx)
// The STM32L475/6 doesn't have CCRAM, so we use the 32K SRAM2 for this, although
// actual location and size is defined by the linker script.
diff --git a/ports/stm32/main.c b/ports/stm32/main.c
index 7656569c8..6c37e1351 100644
--- a/ports/stm32/main.c
+++ b/ports/stm32/main.c
@@ -474,7 +474,9 @@ void stm32_main(uint32_t reset_mode) {
__HAL_RCC_GPIOA_CLK_ENABLE();
__HAL_RCC_GPIOB_CLK_ENABLE();
__HAL_RCC_GPIOC_CLK_ENABLE();
+ #if defined(GPIOD)
__HAL_RCC_GPIOD_CLK_ENABLE();
+ #endif
#if defined(STM32F4) || defined(STM32F7)
#if defined(__HAL_RCC_DTCMRAMEN_CLK_ENABLE)
diff --git a/ports/stm32/spi.c b/ports/stm32/spi.c
index 06c6bcebb..ae97d9ab4 100644
--- a/ports/stm32/spi.c
+++ b/ports/stm32/spi.c
@@ -186,9 +186,14 @@ void spi_set_params(const spi_t *spi_obj, uint32_t prescale, int32_t baudrate,
spi_clock = HAL_RCCEx_GetPeriphCLKFreq(RCC_PERIPHCLK_SPI6);
}
#else
- if (spi->Instance == SPI2 || spi->Instance == SPI3) {
- // SPI2 and SPI3 are on APB1
+ if (spi->Instance == SPI3) {
+ // SPI3 is on APB1
+ spi_clock = HAL_RCC_GetPCLK1Freq();
+ #if defined(SPI2)
+ } else if (spi->Instance == SPI2) {
+ // SPI2 is on APB1
spi_clock = HAL_RCC_GetPCLK1Freq();
+ #endif
} else {
// SPI1, SPI4, SPI5 and SPI6 are on APB2
spi_clock = HAL_RCC_GetPCLK2Freq();
@@ -510,7 +515,10 @@ void spi_print(const mp_print_t *print, const spi_t *spi_obj, bool legacy) {
SPI_HandleTypeDef *spi = spi_obj->spi;
uint spi_num = 1; // default to SPI1
- if (spi->Instance == SPI2) { spi_num = 2; }
+ if (0) { }
+ #if defined(SPI2)
+ else if (spi->Instance == SPI2) { spi_num = 2; }
+ #endif
#if defined(SPI3)
else if (spi->Instance == SPI3) { spi_num = 3; }
#endif
@@ -540,7 +548,13 @@ void spi_print(const mp_print_t *print, const spi_t *spi_obj, bool legacy) {
spi_clock = HAL_RCCEx_GetPeriphCLKFreq(RCC_PERIPHCLK_SPI6);
}
#else
- if (spi->Instance == SPI2 || spi->Instance == SPI3) {
+ #if defined(SPI2)
+ if (spi->Instance == SPI2) {
+ // SPI2 is on APB1
+ spi_clock = HAL_RCC_GetPCLK1Freq();
+ } else
+ #endif
+ if (spi->Instance == SPI3) {
// SPI2 and SPI3 are on APB1
spi_clock = HAL_RCC_GetPCLK1Freq();
} else {
diff --git a/ports/stm32/timer.c b/ports/stm32/timer.c
index 0aa3c47b6..983f7cbc6 100644
--- a/ports/stm32/timer.c
+++ b/ports/stm32/timer.c
@@ -611,7 +611,9 @@ STATIC mp_obj_t pyb_timer_init_helper(pyb_timer_obj_t *self, size_t n_args, cons
switch (self->tim_id) {
case 1: __HAL_RCC_TIM1_CLK_ENABLE(); break;
case 2: __HAL_RCC_TIM2_CLK_ENABLE(); break;
+ #if defined(TIM3)
case 3: __HAL_RCC_TIM3_CLK_ENABLE(); break;
+ #endif
#if defined(TIM4)
case 4: __HAL_RCC_TIM4_CLK_ENABLE(); break;
#endif
@@ -706,7 +708,9 @@ STATIC const uint32_t tim_instance_table[MICROPY_HW_MAX_TIMER] = {
TIM_ENTRY(1, TIM1_UP_TIM16_IRQn),
#endif
TIM_ENTRY(2, TIM2_IRQn),
+ #if defined(TIM3)
TIM_ENTRY(3, TIM3_IRQn),
+ #endif
#if defined(TIM4)
TIM_ENTRY(4, TIM4_IRQn),
#endif
@@ -1127,7 +1131,9 @@ STATIC mp_obj_t pyb_timer_channel(size_t n_args, const mp_obj_t *pos_args, mp_ma
// Only Timers 1, 2, 3, 4, 5, and 8 support encoder mode
if (self->tim.Instance != TIM1
&& self->tim.Instance != TIM2
+ #if defined(TIM3)
&& self->tim.Instance != TIM3
+ #endif
#if defined(TIM4)
&& self->tim.Instance != TIM4
#endif