Skip to content

Commit 90bb98e

Browse files
iabdalkaderdpgeorge
authored andcommitted
stm32/dac: Add support for H7 MCUs.
Includes a fix for H7 DAC DMA requests.
1 parent cbf981f commit 90bb98e

2 files changed

Lines changed: 12 additions & 2 deletions

File tree

ports/stm32/dac.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,10 @@
6565

6666
#if defined(MICROPY_HW_ENABLE_DAC) && MICROPY_HW_ENABLE_DAC
6767

68+
#if defined(STM32H7)
69+
#define DAC DAC1
70+
#endif
71+
6872
STATIC DAC_HandleTypeDef DAC_Handle;
6973

7074
void dac_init(void) {
@@ -160,6 +164,8 @@ STATIC mp_obj_t pyb_dac_init_helper(pyb_dac_obj_t *self, size_t n_args, const mp
160164
// DAC peripheral clock
161165
#if defined(STM32F4) || defined(STM32F7)
162166
__DAC_CLK_ENABLE();
167+
#elif defined(STM32H7)
168+
__HAL_RCC_DAC12_CLK_ENABLE();
163169
#elif defined(STM32L4)
164170
__HAL_RCC_DAC1_CLK_ENABLE();
165171
#else
@@ -256,10 +262,14 @@ STATIC mp_obj_t pyb_dac_deinit(mp_obj_t self_in) {
256262
pyb_dac_obj_t *self = self_in;
257263
if (self->dac_channel == DAC_CHANNEL_1) {
258264
DAC_Handle.Instance->CR &= ~DAC_CR_EN1;
265+
#ifndef STM32H7
259266
DAC_Handle.Instance->CR |= DAC_CR_BOFF1;
267+
#endif
260268
} else {
261269
DAC_Handle.Instance->CR &= ~DAC_CR_EN2;
270+
#ifndef STM32H7
262271
DAC_Handle.Instance->CR |= DAC_CR_BOFF2;
272+
#endif
263273
}
264274
return mp_const_none;
265275
}

ports/stm32/dma.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -336,8 +336,8 @@ const dma_descr_t dma_SPI_2_TX = { DMA1_Stream4, DMA_REQUEST_SPI2_TX, DMA_MEMORY
336336
const dma_descr_t dma_I2C_3_TX = { DMA1_Stream4, DMA_REQUEST_I2C3_TX, DMA_MEMORY_TO_PERIPH, dma_id_4, &dma_init_struct_spi_i2c };
337337
const dma_descr_t dma_I2C_4_TX = { DMA1_Stream5, BDMA_REQUEST_I2C4_TX, DMA_MEMORY_TO_PERIPH, dma_id_5, &dma_init_struct_spi_i2c };
338338
#if defined(MICROPY_HW_ENABLE_DAC) && MICROPY_HW_ENABLE_DAC
339-
const dma_descr_t dma_DAC_1_TX = { DMA1_Stream5, DMA_REQUEST_DAC1_TX, DMA_MEMORY_TO_PERIPH, dma_id_5, &dma_init_struct_dac };
340-
const dma_descr_t dma_DAC_2_TX = { DMA1_Stream6, DMA_REQUEST_DAC2_TX, DMA_MEMORY_TO_PERIPH, dma_id_6, &dma_init_struct_dac };
339+
const dma_descr_t dma_DAC_1_TX = { DMA1_Stream5, DMA_REQUEST_DAC1_CH1, DMA_MEMORY_TO_PERIPH, dma_id_5, &dma_init_struct_dac };
340+
const dma_descr_t dma_DAC_2_TX = { DMA1_Stream6, DMA_REQUEST_DAC1_CH2, DMA_MEMORY_TO_PERIPH, dma_id_6, &dma_init_struct_dac };
341341
#endif
342342
const dma_descr_t dma_SPI_3_TX = { DMA1_Stream7, DMA_REQUEST_SPI3_TX, DMA_MEMORY_TO_PERIPH, dma_id_7, &dma_init_struct_spi_i2c };
343343
const dma_descr_t dma_I2C_1_TX = { DMA1_Stream7, DMA_REQUEST_I2C1_TX, DMA_MEMORY_TO_PERIPH, dma_id_7, &dma_init_struct_spi_i2c };

0 commit comments

Comments
 (0)