This commit adds driver support for DMA on f0/f1/f2/f3/f4/l0/l4 series stm32. Notice due to some bugs, this is currently not working with f7. There are two kinds of IP blocks are used across these stm32, one is the one that has been used on F2/F4/F7 series, and the other one is the one that has been used on F0/F1/F3/L0/L4 series. Memory to memory transfer is only supported on the second DMA on F2/F4 with 'st,mem2mem' to be declared in dts. This driver depends on k_malloc to allocate memory for stream instances, so CONFIG_HEAP_MEM_POOL_SIZE must be big enough to hold them. Common parts of the driver are in dma_stm32.c and SoC related parts are implemented in dma_stm32_v*.c. This driver has been tested on multiple nucleo boards, including NUCLEO_F091RC/F103RB/F207ZG/F302R8/F401RE/L073RZ/L476RG with the loop_transfer and chan_blen_transfer test cases. Signed-off-by: Song Qiang <songqiang1304521@gmail.com>
76 lines
1.5 KiB
C
76 lines
1.5 KiB
C
/*
|
|
* Copyright (c) 2016 Open-RnD Sp. z o.o.
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
/**
|
|
* @file SoC configuration macros for the STM32F1 family processors.
|
|
*
|
|
* Based on reference manual:
|
|
* STM32F101xx, STM32F102xx, STM32F103xx, STM32F105xx and STM32F107xx
|
|
* advanced ARM(r)-based 32-bit MCUs
|
|
*
|
|
* Chapter 3.3: Memory Map
|
|
*/
|
|
|
|
|
|
#ifndef _STM32F1_SOC_H_
|
|
#define _STM32F1_SOC_H_
|
|
|
|
#ifndef _ASMLANGUAGE
|
|
|
|
#include <stm32f1xx.h>
|
|
|
|
/* ARM CMSIS definitions must be included before kernel_includes.h.
|
|
* Therefore, it is essential to include kernel_includes.h after including
|
|
* core SOC-specific headers.
|
|
*/
|
|
#include <kernel_includes.h>
|
|
|
|
#ifdef CONFIG_EXTI_STM32
|
|
#include <stm32f1xx_ll_exti.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_SERIAL_HAS_DRIVER
|
|
#include <stm32f1xx_ll_usart.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_CLOCK_CONTROL_STM32_CUBE
|
|
#include <stm32f1xx_ll_utils.h>
|
|
#include <stm32f1xx_ll_bus.h>
|
|
#include <stm32f1xx_ll_rcc.h>
|
|
#include <stm32f1xx_ll_system.h>
|
|
#endif /* CONFIG_CLOCK_CONTROL_STM32_CUBE */
|
|
|
|
#ifdef CONFIG_I2C_STM32
|
|
#include <stm32f1xx_ll_i2c.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_SPI_STM32
|
|
#include <stm32f1xx_ll_spi.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_IWDG_STM32
|
|
#include <stm32f1xx_ll_iwdg.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_WWDG_STM32
|
|
#include <stm32f1xx_ll_wwdg.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_GPIO_STM32
|
|
#include <stm32f1xx_ll_gpio.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_ADC_STM32
|
|
#include <stm32f1xx_ll_adc.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_DMA_STM32
|
|
#include <stm32f1xx_ll_dma.h>
|
|
#endif
|
|
|
|
#endif /* !_ASMLANGUAGE */
|
|
|
|
#endif /* _STM32F1_SOC_H_ */
|