231 lines
6.2 KiB
C
231 lines
6.2 KiB
C
/**
|
|
* @file arro_board.h
|
|
*
|
|
* This file contents a configuration of default ecu board. Pinout and other.
|
|
* TODO: most of the pins should get configurable
|
|
*
|
|
*
|
|
* @date Nov 14, 2013
|
|
* @author Andrey Belomutskiy, (c) 2012-2014
|
|
* @author frig
|
|
*
|
|
* This file is part of rusEfi - see http://rusefi.com
|
|
*
|
|
* rusEfi is free software; you can redistribute it and/or modify it under the terms of
|
|
* the GNU General Public License as published by the Free Software Foundation; either
|
|
* version 3 of the License, or (at your option) any later version.
|
|
*
|
|
* rusEfi is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
|
|
* even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with this program.
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef ARRO_BOARD_H_
|
|
#define ARRO_BOARD_H_
|
|
|
|
|
|
#define STM32_ICU_USE_TIM1 TRUE // wave input
|
|
#define STM32_ICU_USE_TIM2 TRUE // primary position sensor
|
|
#define STM32_ICU_USE_TIM3 TRUE // secondary position sensor
|
|
#define STM32_ICU_USE_TIM4 FALSE
|
|
#define STM32_ICU_USE_TIM5 FALSE
|
|
#define STM32_ICU_USE_TIM8 FALSE
|
|
#define STM32_ICU_USE_TIM9 TRUE // wave input
|
|
|
|
// todo: switch to continues ADC conversion for slow ADC?
|
|
#define EFI_INTERNAL_SLOW_ADC_PWM &PWMD8
|
|
// todo: switch to continues ADC conversion for fast ADC?
|
|
#define EFI_INTERNAL_FAST_ADC_PWM &PWMD4
|
|
|
|
|
|
#define STM32_PWM_USE_TIM1 FALSE
|
|
#define STM32_PWM_USE_TIM2 FALSE
|
|
#define STM32_PWM_USE_TIM3 FALSE
|
|
//
|
|
#define STM32_PWM_USE_TIM4 TRUE // fast adc
|
|
#define STM32_PWM_USE_TIM5 FALSE
|
|
#define STM32_PWM_USE_TIM8 TRUE // slow adc
|
|
#define STM32_PWM_USE_TIM9 FALSE
|
|
|
|
#define STM32_SPI_USE_SPI1 TRUE
|
|
#define STM32_SPI_USE_SPI2 FALSE // external ADC
|
|
#define STM32_SPI_USE_SPI3 TRUE // potentiometer
|
|
|
|
#define STM32_CAN_USE_CAN1 TRUE
|
|
#define STM32_CAN_USE_CAN2 TRUE
|
|
|
|
#define STM32_I2C_I2C1_RX_DMA_STREAM STM32_DMA_STREAM_ID(1, 5)
|
|
#define STM32_I2C_I2C1_TX_DMA_STREAM STM32_DMA_STREAM_ID(1, 6)
|
|
|
|
#define EFI_CAN_DEVICE CAND2
|
|
#define EFI_CAN_RX_AF 9
|
|
#define EFI_CAN_TX_AF 9
|
|
|
|
//#define EFI_CAN_DEVICE CAND1
|
|
//#define EFI_CAN_RX_AF 9
|
|
//#define EFI_CAN_TX_AF 9
|
|
|
|
/**
|
|
* This section is for bottom-left corner SPI
|
|
*/
|
|
//#define SPI_CS1_PORT GPIOE
|
|
//#define SPI_CS1_PIN 13
|
|
//#define SPI_CS2_PORT GPIOE
|
|
//#define SPI_CS2_PIN 14
|
|
//#define SPI_CS3_PORT GPIOE
|
|
//#define SPI_CS3_PIN 15
|
|
//#define SPI_CS4_PORT GPIOD
|
|
//#define SPI_CS4_PIN 10
|
|
//#define SPI_SD_MODULE_PORT GPIOD
|
|
//#define SPI_SD_MODULE_PIN 11
|
|
|
|
#define EFI_SPI1_SCK_PORT GPIOB
|
|
#define EFI_SPI1_SCK_PIN 3
|
|
#define EFI_SPI1_MISO_PORT GPIOB
|
|
#define EFI_SPI1_MISO_PIN 4
|
|
#define EFI_SPI1_MOSI_PORT GPIOB
|
|
#define EFI_SPI1_MOSI_PIN 5
|
|
#define EFI_SPI1_AF 5
|
|
|
|
|
|
#define EFI_SPI2_SCK_PORT GPIOB
|
|
#define EFI_SPI2_SCK_PIN 13
|
|
#define EFI_SPI2_MISO_PORT GPIOB
|
|
#define EFI_SPI2_MISO_PIN 14
|
|
#define EFI_SPI2_MOSI_PORT GPIOB
|
|
#define EFI_SPI2_MOSI_PIN 15
|
|
#define EFI_SPI2_AF 5
|
|
|
|
|
|
/**
|
|
* This section is for right-side center SPI
|
|
*/
|
|
// this is pointing into the sky for now - conflict with I2C
|
|
#define SPI_CS2_PORT GPIOH
|
|
// this is pointing into the sky for now - conflict with I2C
|
|
#define SPI_CS2_PIN 0
|
|
#define SPI_CS4_PORT GPIOD
|
|
#define SPI_CS4_PIN 3
|
|
#define SPI_SD_MODULE_PORT GPIOD
|
|
#define SPI_SD_MODULE_PIN 4
|
|
#define EFI_SPI3_SCK_PORT GPIOB
|
|
#define EFI_SPI3_SCK_PIN 3
|
|
#define EFI_SPI3_MISO_PORT GPIOB
|
|
#define EFI_SPI3_MISO_PIN 4
|
|
#define EFI_SPI3_MOSI_PORT GPIOB
|
|
#define EFI_SPI3_MOSI_PIN 5
|
|
#define EFI_SPI3_AF 6
|
|
#define MMC_CARD_SPI SPID3
|
|
|
|
#define EFI_I2C_SCL_PORT GPIOB
|
|
#define EFI_I2C_SCL_PIN 6
|
|
#define EFI_I2C_SDA_PORT GPIOB
|
|
#define EFI_I2C_SDA_PIN 7
|
|
#define EFI_I2C_AF 4
|
|
|
|
/**
|
|
* Patched version of ChibiOS/RT support extra details in the system error messages
|
|
*/
|
|
#define EFI_CUSTOM_PANIC_METHOD TRUE
|
|
|
|
/*
|
|
* 10 channel board is (from left to right):
|
|
* ADC 15 PC5 TPS
|
|
* ADC 14 PC4 MAP
|
|
* ADC 7 PA7 IAT
|
|
* ADC 6 PA6 CLT
|
|
* ADC 5 PA5 TIM2_CH1
|
|
* ADC 4 PA4
|
|
* ADC 3 PA3
|
|
* ADC 2 PA2
|
|
* ADC 1 PA1 vBatt
|
|
* ADC 0 PA0 MAF
|
|
*/
|
|
|
|
#define ADC_LOGIC_TPS_2 ADC_CHANNEL_IN0
|
|
|
|
#define ADC_CHANNEL_VREF ADC_CHANNEL_IN14
|
|
|
|
|
|
/**
|
|
* currently ChibiOS uses only first and second channels of each timer for input capture
|
|
*
|
|
* So, our options are:
|
|
*
|
|
* TIM2_CH1
|
|
* PA5
|
|
*
|
|
* TIM4_CH1
|
|
* PB6
|
|
* PD12
|
|
*
|
|
* TIM9_CH1
|
|
* PE5
|
|
*/
|
|
|
|
//#define ETB_CONTROL_LINE_1_PORT GPIOE
|
|
//#define ETB_CONTROL_LINE_1_PIN 0
|
|
//
|
|
//#define ETB_CONTROL_LINE_2_PORT GPIOB
|
|
//#define ETB_CONTROL_LINE_2_PIN 8
|
|
|
|
//#define CONSOLE_PORT GPIOB
|
|
//#define CONSOLE_TX_PIN 10
|
|
//#define CONSOLE_RX_PIN 11
|
|
|
|
/**
|
|
* Here we define the pinout for the human-readable protocol via UART, TunerStudio pinout is defined separately
|
|
*/
|
|
//#define EFI_CONSOLE_TX_PORT GPIOD
|
|
//#define EFI_CONSOLE_TX_PIN 8
|
|
//#define EFI_CONSOLE_RX_PORT GPIOD
|
|
//#define EFI_CONSOLE_RX_PIN 9
|
|
//#define EFI_CONSOLE_AF 7
|
|
|
|
#define EFI_CONSOLE_UART_DEVICE (&SD3)
|
|
|
|
#define EFI_CONSOLE_TX_PORT GPIOC
|
|
#define EFI_CONSOLE_TX_PIN 10
|
|
#define EFI_CONSOLE_RX_PORT GPIOC
|
|
#define EFI_CONSOLE_RX_PIN 11
|
|
#define EFI_CONSOLE_AF 7
|
|
|
|
//#define TS_SERIAL_TX_PORT GPIOD
|
|
//#define TS_SERIAL_TX_PIN 8
|
|
//#define TS_SERIAL_RX_PORT GPIOD
|
|
//#define TS_SERIAL_RX_PIN 9
|
|
//#define TS_SERIAL_AF 7
|
|
|
|
#define TS_SERIAL_TX_PORT GPIOC
|
|
#define TS_SERIAL_TX_PIN 10
|
|
#define TS_SERIAL_RX_PORT GPIOC
|
|
#define TS_SERIAL_RX_PIN 11
|
|
#define TS_SERIAL_AF 7
|
|
|
|
#define LED_WARNING_PORT GPIOD
|
|
#define LED_WARNING_PIN GPIOD_LED3
|
|
|
|
#define LED_RUNNING_STATUS_PORT GPIOD
|
|
#define LED_RUNNING_STATUS_PIN GPIOD_LED4
|
|
|
|
#define LED_ERROR_PORT GPIOD
|
|
#define LED_ERROR_PIN GPIOD_LED5
|
|
|
|
#define LED_COMMUNICATION_PORT GPIOD
|
|
#define LED_COMMUNICATION_PIN GPIOD_LED6
|
|
|
|
// USART1 -> check defined STM32_SERIAL_USE_USART1
|
|
// For GPS we have USART1. We can start with PB7 USART1_RX and PB6 USART1_TX
|
|
#define GPS_SERIAL_DEVICE &SD1
|
|
#define GPS_SERIAL_SPEED 38400
|
|
|
|
#define CONSOLE_MODE_SWITCH_PORT GPIOB
|
|
#define CONSOLE_MODE_SWITCH_PIN 1
|
|
|
|
#define CONFIG_RESET_SWITCH_PORT GPIOD
|
|
#define CONFIG_RESET_SWITCH_PIN 6
|
|
|
|
#endif /*ARRO_BOARD_H_*/
|