New memory section types for DMA
[betaflight.git] / src / main / target / ALIENFLIGHTF4 / target.c
blobefb2fbcfbc1fd9021cc19de4d13591dc7fb5ff6b
1 /*
2 * This file is part of Cleanflight and Betaflight.
4 * Cleanflight and Betaflight are free software. You can redistribute
5 * this software and/or modify this software under the terms of the
6 * GNU General Public License as published by the Free Software
7 * Foundation, either version 3 of the License, or (at your option)
8 * any later version.
10 * Cleanflight and Betaflight are distributed in the hope that they
11 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
12 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * See the GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software.
18 * If not, see <http://www.gnu.org/licenses/>.
21 #include <stdint.h>
23 #include "platform.h"
24 #include "drivers/io.h"
26 #include "drivers/dma.h"
27 #include "drivers/timer.h"
28 #include "drivers/timer_def.h"
30 // DSHOT will work for motor 1,3,4,5,6,7 and 8.
31 // Motor 2 pin timers have no DMA channel assigned in the hardware. Remapping of the pin is needed.
32 // If SDCard or UART4 DMA is used motor 4 will not work.
33 // If UART1 DMA is used motor 8 will not work.
35 const timerHardware_t timerHardware[USABLE_TIMER_CHANNEL_COUNT] = {
36 DEF_TIM(TIM1, CH1, PA8, TIM_USE_PWM | TIM_USE_PPM, 0, 1), // PWM1 - PA8 RC1 - DMA2_ST6, *DMA2_ST1, DMA2_ST3
37 DEF_TIM(TIM3, CH3, PB0, TIM_USE_PWM, 0, 0), // PWM2 - PB0 RC2 - DMA1_ST5
38 DEF_TIM(TIM3, CH4, PB1, TIM_USE_PWM, 0, 0), // PWM3 - PB1 RC3 - DMA1_ST7
39 DEF_TIM(TIM1, CH2, PB14, TIM_USE_PWM, 0, 1), // PWM4 - PA14 RC4 - DMA2_ST6, *DMA2_ST2
40 DEF_TIM(TIM1, CH3, PB15, TIM_USE_PWM | TIM_USE_LED, 0, 0), // PWM5 - PA15 RC5 - DMA2_ST6, DMA2_ST6
41 DEF_TIM(TIM4, CH3, PB8, TIM_USE_MOTOR, 0, 0), // PWM6 - PB8 OUT1 - DMA1_ST7
42 DEF_TIM(TIM4, CH4, PB9, TIM_USE_MOTOR, 0, 0), // PWM7 - PB9 OUT2 - DMA_NONE
43 DEF_TIM(TIM5, CH1, PA0, TIM_USE_MOTOR, 0, 0), // PWM8 - PA0 OUT3 - DMA1_ST2
44 DEF_TIM(TIM5, CH2, PA1, TIM_USE_MOTOR, 0, 0), // PWM9 - PA1 OUT4 - DMA1_ST4
45 DEF_TIM(TIM8, CH1, PC6, TIM_USE_MOTOR, 0, 0), // PWM10 - PC6 OUT5 - DMA2_ST2, DMA2_ST2
46 DEF_TIM(TIM8, CH2, PC7, TIM_USE_MOTOR, 0, 0), // PWM11 - PC7 OUT6 - DMA2_ST3, DMA2_ST2
47 DEF_TIM(TIM8, CH3, PC8, TIM_USE_MOTOR, 0, 1), // PWM13 - PC8 OUT7 - DMA2_ST2, *DMA2_ST4
48 DEF_TIM(TIM8, CH4, PC9, TIM_USE_MOTOR, 0, 0), // PWM13 - PC9 OUT8 - DMA2_ST7