/****************************************************************************** * 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 * @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