193 lines
7.5 KiB
C
193 lines
7.5 KiB
C
/******************************************************************************
|
|
* The MIT License
|
|
*
|
|
* Copyright (c) 2011 LeafLabs, LLC.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person
|
|
* obtaining a copy of this software and associated documentation
|
|
* files (the "Software"), to deal in the Software without
|
|
* restriction, including without limitation the rights to use, copy,
|
|
* modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
* of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be
|
|
* included in all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*****************************************************************************/
|
|
|
|
/**
|
|
* @file generic_f407v.h
|
|
* @author Marti Bolivar <mbolivar@leaflabs.com>
|
|
* @brief Private include file for Maple Native in boards.h
|
|
*
|
|
* See maple.h for more information on these definitions.
|
|
*/
|
|
|
|
#ifndef _BOARD_GENERIC_F407V_H_
|
|
#define _BOARD_GENERIC_F407V_H_
|
|
|
|
#define Port2Pin(port, bit) ((port-'A')*16+bit)
|
|
|
|
#define CYCLES_PER_MICROSECOND 168
|
|
|
|
|
|
#undef STM32_PCLK1
|
|
#undef STM32_PCLK2
|
|
#define STM32_PCLK1 (CYCLES_PER_MICROSECOND*1000000/4)
|
|
#define STM32_PCLK2 (CYCLES_PER_MICROSECOND*1000000/2)
|
|
|
|
#define SYSTICK_RELOAD_VAL (CYCLES_PER_MICROSECOND*1000-1)
|
|
|
|
/*****************************************************************************/
|
|
// Board pin definitions
|
|
#define BOARD_USB_DM_PIN PA11
|
|
#define BOARD_USB_DP_PIN PA12
|
|
|
|
#define BOARD_LED_PIN PA6 //Port2Pin('A', 6)
|
|
#define BOARD_LED2_PIN PA7 //Port2Pin('A', 7)
|
|
#define BOARD_BUTTON1_PIN PA0 //Port2Pin('A', 0)
|
|
#define BOARD_BUTTON2_PIN PE4 //Port2Pin('E', 4)
|
|
#define BOARD_BUTTON3_PIN PE3 //Port2Pin('E', 3)
|
|
|
|
#define BOARD_NR_USARTS 5
|
|
#define BOARD_USART1_TX_PIN PA9 //Port2Pin('A', 9)
|
|
#define BOARD_USART1_RX_PIN PA10 //Port2Pin('A',10)
|
|
#define BOARD_USART2_TX_PIN PA2 //Port2Pin('A', 2)
|
|
#define BOARD_USART2_RX_PIN PA3 //Port2Pin('A', 3)
|
|
#define BOARD_USART3_TX_PIN PB10 //Port2Pin('B',10)
|
|
#define BOARD_USART3_RX_PIN PB11 //Port2Pin('B',11)
|
|
#define BOARD_UART4_TX_PIN PA0 //Port2Pin('A', 0)
|
|
#define BOARD_UART4_RX_PIN PA1 //Port2Pin('A', 1)
|
|
#define BOARD_UART5_TX_PIN PC12 //Port2Pin('C',12)
|
|
#define BOARD_UART5_RX_PIN PD2 //Port2Pin('D', 2)
|
|
|
|
#define BOARD_NR_SPI 3
|
|
#define BOARD_SPI1_NSS_PIN PA4 //Port2Pin('A', 4)
|
|
#define BOARD_SPI1_SCK_PIN PA5 //Port2Pin('A', 5)
|
|
#define BOARD_SPI1_MISO_PIN PA6 //Port2Pin('A', 6)
|
|
#define BOARD_SPI1_MOSI_PIN PA7 //Port2Pin('A', 7)
|
|
#define BOARD_SPI1A_NSS_PIN PA15 //Port2Pin('A',15)
|
|
#define BOARD_SPI1A_SCK_PIN PB3 //Port2Pin('B', 3)
|
|
#define BOARD_SPI1A_MISO_PIN PB4 //Port2Pin('B', 4)
|
|
#define BOARD_SPI1A_MOSI_PIN PB5 //Port2Pin('B', 5)
|
|
|
|
#define BOARD_SPI2_NSS_PIN PB12 //Port2Pin('B',12)
|
|
#define BOARD_SPI2_SCK_PIN PB13 //Port2Pin('B',13)
|
|
#define BOARD_SPI2_MISO_PIN PB14 //Port2Pin('B',14)
|
|
#define BOARD_SPI2_MOSI_PIN PB15 //Port2Pin('B',15)
|
|
#define BOARD_SPI2A_NSS_PIN PB9 //Port2Pin('B', 9)
|
|
#define BOARD_SPI2A_SCK_PIN PB10 //Port2Pin('B',10)
|
|
#define BOARD_SPI2A_MISO_PIN PC2 //Port2Pin('C', 2)
|
|
#define BOARD_SPI2A_MOSI_PIN PC3 //Port2Pin('C', 3)
|
|
|
|
#define BOARD_SPI3_NSS_PIN PA15 //Port2Pin('A',15)
|
|
#define BOARD_SPI3_SCK_PIN PB3 //Port2Pin('B', 3)
|
|
#define BOARD_SPI3_MISO_PIN PB4 //Port2Pin('B', 4)
|
|
#define BOARD_SPI3_MOSI_PIN PB5 //Port2Pin('B', 5)
|
|
/* overlap with the SDIO interface for SD card
|
|
#define BOARD_SPI3A_NSS_PIN PA4 //Port2Pin('A', 4)
|
|
#define BOARD_SPI3A_SCK_PIN PC10 //Port2Pin('C',10)
|
|
#define BOARD_SPI3A_MISO_PIN PC11 //Port2Pin('C',11)
|
|
#define BOARD_SPI3A_MOSI_PIN PC12 //Port2Pin('C',12)
|
|
*/
|
|
#define BOARD_SDIO_D0 PC8 //Port2Pin('C', 8)
|
|
#define BOARD_SDIO_D1 PC9 //Port2Pin('C', 9)
|
|
#define BOARD_SDIO_D2 PC10 //Port2Pin('C',10)
|
|
#define BOARD_SDIO_D3 PC11 //Port2Pin('C',11)
|
|
#define BOARD_SDIO_CLK PC12 //Port2Pin('C',12)
|
|
#define BOARD_SDIO_CMD PD2 //Port2Pin('D', 2)
|
|
|
|
#define FSMC_NOE PD4
|
|
#define FSMC_NWE PD5
|
|
#define FSMC_NE1 PD7
|
|
#define FSMC_A18 PD13
|
|
#define FSMC_A17 PD12
|
|
#define FSMC_A16 PD11
|
|
#define FSMC_D0 PD14
|
|
#define FSMC_D1 PD15
|
|
#define FSMC_D2 PD0
|
|
#define FSMC_D3 PD1
|
|
#define FSMC_D4 PE7
|
|
#define FSMC_D5 PE8
|
|
#define FSMC_D6 PE9
|
|
#define FSMC_D7 PE10
|
|
#define FSMC_D8 PE11
|
|
#define FSMC_D9 PE12
|
|
#define FSMC_D10 PE13
|
|
#define FSMC_D11 PE14
|
|
#define FSMC_D12 PE15
|
|
#define FSMC_D13 PD8
|
|
#define FSMC_D14 PD9
|
|
#define FSMC_D15 PD10
|
|
|
|
#define BOARD_T_CS BOARD_SPI2_NSS_PIN
|
|
#define BOARD_T_SCK BOARD_SPI2_SCK_PIN
|
|
#define BOARD_T_MISO BOARD_SPI2_MISO_PIN
|
|
#define BOARD_T_MOSI BOARD_SPI2_MOSI_PIN
|
|
#define BOARD_T_PEN PC5
|
|
|
|
#define BOARD_NR_GPIO_PINS 80
|
|
#define BOARD_NR_PWM_PINS 22
|
|
#define BOARD_NR_ADC_PINS 16
|
|
#define BOARD_NR_USED_PINS 22
|
|
#define BOARD_JTMS_SWDIO_PIN PA13 //Port2Pin('A',13)
|
|
#define BOARD_JTCK_SWCLK_PIN PA14 //Port2Pin('A',14)
|
|
#define BOARD_JTDI_PIN PA15 //Port2Pin('A',15)
|
|
#define BOARD_JTDO_PIN PB3 //Port2Pin('B', 3)
|
|
#define BOARD_NJTRST_PIN PB4 //Port2Pin('B', 4)
|
|
|
|
/*****************************************************************************/
|
|
// Pins reserved for the on-board hardware
|
|
#define USB_DM_PIN BOARD_USB_DM_PIN // PA11
|
|
#define USB_DP_PIN BOARD_USB_DP_PIN // PA12
|
|
|
|
#define FLASH_CS_PIN PB0
|
|
#define FLASH_CLK_PIN BOARD_SPI3_SCK_PIN // PB3
|
|
#define FLASH_DO_PIN BOARD_SPI3_MISO_PIN // PB4
|
|
#define FLASH_DI_PIN BOARD_SPI3_MOSI_PIN // PB5
|
|
|
|
#define NRF24_CLK_PIN BOARD_SPI3_SCK_PIN // PB3
|
|
#define NRF24_DO_PIN BOARD_SPI3_MISO_PIN // PB4
|
|
#define NRF24_DI_PIN BOARD_SPI3_MOSI_PIN // PB5
|
|
#define NRF24_CE_PIN PB6
|
|
#define NRF24_CS_PIN PB7
|
|
#define NRF24_IRQ_PIN PB8
|
|
|
|
// SD card, SDIO mode
|
|
#define SD_DAT0 BOARD_SDIO_D0 // PC8
|
|
#define SD_DAT1 BOARD_SDIO_D1 // PC9
|
|
#define SD_DAT2 BOARD_SDIO_D2 // PC10
|
|
#define SD_DAT3 BOARD_SDIO_D3 // PC11
|
|
#define SD_CLK BOARD_SDIO_CK // PC12
|
|
#define SD_CMD BOARD_SDIO_CMD // PD2
|
|
// SD card, SPI mode, only usable with software SPI
|
|
#define SD_DI BOARD_SDIO_CMD // PD2
|
|
#define SD_DO BOARD_SDIO_D0 // PC8
|
|
#define SD_CS BOARD_SDIO_D3 // PC11
|
|
#define SD_SCLK BOARD_SDIO_CK // PC12
|
|
|
|
/*****************************************************************************/
|
|
|
|
enum {
|
|
PA0,PA1,PA2,PA3,PA4,PA5,PA6,PA7,PA8,PA9,PA10,PA11,PA12,PA13,PA14,PA15,
|
|
PB0,PB1,PB2,PB3,PB4,PB5,PB6,PB7,PB8,PB9,PB10,PB11,PB12,PB13,PB14,PB15,
|
|
PC0,PC1,PC2,PC3,PC4,PC5,PC6,PC7,PC8,PC9,PC10,PC11,PC12,PC13,PC14,PC15,
|
|
PD0,PD1,PD2,PD3,PD4,PD5,PD6,PD7,PD8,PD9,PD10,PD11,PD12,PD13,PD14,PD15,
|
|
PE0,PE1,PE2,PE3,PE4,PE5,PE6,PE7,PE8,PE9,PE10,PE11,PE12,PE13,PE14,PE15,
|
|
#if 0 // not available on LQFP100 package
|
|
PF0,PF1,PF2,PF3,PF4,PF5,PF6,PF7,PF8,PF9,PF10,PF11,PF12,PF13,PF14,PF15,
|
|
PG0,PG1,PG2,PG3,PG4,PG5,PG6,PG7,PG8,PG9,PG10,PG11,PG12,PG13,PG14,PG15
|
|
#endif // not available on LQFP100 package
|
|
};
|
|
|
|
#endif
|