2017-03-30 07:59:36 +01:00
|
|
|
// This board is confirmed to operate using stlink and openocd.
|
|
|
|
// REPL is on UART(1) and is available through the stlink USB-UART device.
|
2016-12-12 05:36:35 +00:00
|
|
|
// To use openocd run "OPENOCD_CONFIG=boards/openocd_stm32f7.cfg" in
|
|
|
|
// the make command.
|
|
|
|
#define MICROPY_HW_BOARD_NAME "F769DISC"
|
|
|
|
#define MICROPY_HW_MCU_NAME "STM32F769"
|
|
|
|
|
|
|
|
#define MICROPY_HW_HAS_SWITCH (1)
|
|
|
|
#define MICROPY_HW_HAS_FLASH (1)
|
|
|
|
#define MICROPY_HW_ENABLE_RNG (1)
|
|
|
|
#define MICROPY_HW_ENABLE_RTC (1)
|
2018-02-13 07:57:01 +00:00
|
|
|
#define MICROPY_HW_ENABLE_USB (1)
|
2019-04-01 05:21:26 +01:00
|
|
|
#define MICROPY_HW_ENABLE_SDCARD (1)
|
2016-12-12 05:36:35 +00:00
|
|
|
|
2019-03-04 11:32:44 +00:00
|
|
|
#define MICROPY_BOARD_EARLY_INIT board_early_init
|
|
|
|
void board_early_init(void);
|
|
|
|
|
2016-12-12 05:36:35 +00:00
|
|
|
// HSE is 25MHz
|
|
|
|
// VCOClock = HSE * PLLN / PLLM = 25 MHz * 432 / 25 = 432 MHz
|
|
|
|
// SYSCLK = VCOClock / PLLP = 432 MHz / 2 = 216 MHz
|
|
|
|
// USB/SDMMC/RNG Clock = VCOClock / PLLQ = 432 MHz / 9 = 48 MHz
|
|
|
|
#define MICROPY_HW_CLK_PLLM (25)
|
|
|
|
#define MICROPY_HW_CLK_PLLN (432)
|
|
|
|
#define MICROPY_HW_CLK_PLLP (RCC_PLLP_DIV2)
|
|
|
|
#define MICROPY_HW_CLK_PLLQ (9)
|
|
|
|
|
|
|
|
#define MICROPY_HW_FLASH_LATENCY FLASH_LATENCY_7 // 210-216 MHz needs 7 wait states
|
|
|
|
|
2020-01-30 03:40:38 +00:00
|
|
|
// 512MBit external QSPI flash, used for either the filesystem or XIP memory mapped
|
2019-03-04 11:32:44 +00:00
|
|
|
#define MICROPY_HW_QSPIFLASH_SIZE_BITS_LOG2 (29)
|
|
|
|
#define MICROPY_HW_QSPIFLASH_CS (pin_B6)
|
|
|
|
#define MICROPY_HW_QSPIFLASH_SCK (pin_B2)
|
|
|
|
#define MICROPY_HW_QSPIFLASH_IO0 (pin_C9)
|
|
|
|
#define MICROPY_HW_QSPIFLASH_IO1 (pin_C10)
|
|
|
|
#define MICROPY_HW_QSPIFLASH_IO2 (pin_E2)
|
|
|
|
#define MICROPY_HW_QSPIFLASH_IO3 (pin_D13)
|
|
|
|
|
2020-01-30 03:40:38 +00:00
|
|
|
// SPI flash, block device config (when used as the filesystem)
|
|
|
|
extern const struct _mp_spiflash_config_t spiflash_config;
|
|
|
|
extern struct _spi_bdev_t spi_bdev;
|
|
|
|
#if !USE_QSPI_XIP
|
|
|
|
#define MICROPY_HW_ENABLE_INTERNAL_FLASH_STORAGE (0)
|
2020-12-17 05:59:54 +00:00
|
|
|
#define MICROPY_HW_SPIFLASH_ENABLE_CACHE (1)
|
2020-01-30 03:40:38 +00:00
|
|
|
#define MICROPY_HW_BDEV_IOCTL(op, arg) ( \
|
2020-06-12 01:15:25 +01:00
|
|
|
(op) == BDEV_IOCTL_NUM_BLOCKS ? ((1 << MICROPY_HW_QSPIFLASH_SIZE_BITS_LOG2) / 8 / FLASH_BLOCK_SIZE) : \
|
2020-01-30 03:40:38 +00:00
|
|
|
(op) == BDEV_IOCTL_INIT ? spi_bdev_ioctl(&spi_bdev, (op), (uint32_t)&spiflash_config) : \
|
|
|
|
spi_bdev_ioctl(&spi_bdev, (op), (arg)) \
|
|
|
|
)
|
|
|
|
#define MICROPY_HW_BDEV_READBLOCKS(dest, bl, n) spi_bdev_readblocks(&spi_bdev, (dest), (bl), (n))
|
|
|
|
#define MICROPY_HW_BDEV_WRITEBLOCKS(src, bl, n) spi_bdev_writeblocks(&spi_bdev, (src), (bl), (n))
|
|
|
|
#define MICROPY_HW_BDEV_SPIFLASH_EXTENDED (&spi_bdev) // for extended block protocol
|
|
|
|
#endif
|
|
|
|
|
2016-12-12 05:36:35 +00:00
|
|
|
// UART config
|
|
|
|
#define MICROPY_HW_UART1_TX (pin_A9)
|
|
|
|
#define MICROPY_HW_UART1_RX (pin_A10)
|
|
|
|
#define MICROPY_HW_UART5_TX (pin_C12)
|
|
|
|
#define MICROPY_HW_UART5_RX (pin_D2)
|
|
|
|
#define MICROPY_HW_UART_REPL PYB_UART_1
|
|
|
|
#define MICROPY_HW_UART_REPL_BAUD 115200
|
|
|
|
|
2021-05-20 07:21:47 +01:00
|
|
|
// I2C buses
|
2016-12-12 05:36:35 +00:00
|
|
|
#define MICROPY_HW_I2C1_SCL (pin_B8)
|
|
|
|
#define MICROPY_HW_I2C1_SDA (pin_B9)
|
|
|
|
#define MICROPY_HW_I2C3_SCL (pin_H7)
|
|
|
|
#define MICROPY_HW_I2C3_SDA (pin_H8)
|
|
|
|
|
2021-05-20 07:21:47 +01:00
|
|
|
// SPI buses
|
2016-12-12 05:36:35 +00:00
|
|
|
#define MICROPY_HW_SPI2_NSS (pin_A11)
|
|
|
|
#define MICROPY_HW_SPI2_SCK (pin_A12)
|
|
|
|
#define MICROPY_HW_SPI2_MISO (pin_B14)
|
|
|
|
#define MICROPY_HW_SPI2_MOSI (pin_B15)
|
|
|
|
|
2021-05-20 07:21:47 +01:00
|
|
|
// CAN buses
|
2018-04-11 07:27:48 +01:00
|
|
|
#define MICROPY_HW_CAN1_TX (pin_B9)
|
|
|
|
#define MICROPY_HW_CAN1_RX (pin_B8)
|
|
|
|
#define MICROPY_HW_CAN2_TX (pin_B13)
|
|
|
|
#define MICROPY_HW_CAN2_RX (pin_B12)
|
|
|
|
|
2016-12-12 05:36:35 +00:00
|
|
|
// USRSW is pulled low. Pressing the button makes the input go high.
|
2017-03-30 07:59:36 +01:00
|
|
|
#define MICROPY_HW_USRSW_PIN (pin_A0)
|
2016-12-12 05:36:35 +00:00
|
|
|
#define MICROPY_HW_USRSW_PULL (GPIO_NOPULL)
|
|
|
|
#define MICROPY_HW_USRSW_EXTI_MODE (GPIO_MODE_IT_RISING)
|
|
|
|
#define MICROPY_HW_USRSW_PRESSED (1)
|
|
|
|
|
|
|
|
// LEDs
|
|
|
|
#define MICROPY_HW_LED1 (pin_J13) // red
|
|
|
|
#define MICROPY_HW_LED2 (pin_J5) // green
|
|
|
|
#define MICROPY_HW_LED3 (pin_A12) // green
|
|
|
|
#define MICROPY_HW_LED_ON(pin) (mp_hal_pin_high(pin))
|
|
|
|
#define MICROPY_HW_LED_OFF(pin) (mp_hal_pin_low(pin))
|
|
|
|
|
2021-04-29 03:08:20 +01:00
|
|
|
// SD card
|
|
|
|
#define MICROPY_HW_SDCARD_SDMMC (2)
|
|
|
|
#define MICROPY_HW_SDCARD_CK (pin_D6)
|
|
|
|
#define MICROPY_HW_SDCARD_CMD (pin_D7)
|
|
|
|
#define MICROPY_HW_SDCARD_D0 (pin_G9)
|
|
|
|
#define MICROPY_HW_SDCARD_D1 (pin_G10)
|
|
|
|
#define MICROPY_HW_SDCARD_D2 (pin_B3)
|
|
|
|
#define MICROPY_HW_SDCARD_D3 (pin_B4)
|
2016-12-12 05:36:35 +00:00
|
|
|
#define MICROPY_HW_SDCARD_DETECT_PIN (pin_I15)
|
|
|
|
#define MICROPY_HW_SDCARD_DETECT_PULL (GPIO_PULLUP)
|
|
|
|
#define MICROPY_HW_SDCARD_DETECT_PRESENT (GPIO_PIN_RESET)
|
|
|
|
|
2019-02-07 05:26:46 +00:00
|
|
|
// USB config (CN15 - USB OTG HS with external PHY)
|
|
|
|
#define MICROPY_HW_USB_HS (1)
|
2020-02-04 12:15:55 +00:00
|
|
|
#define MICROPY_HW_USB_HS_ULPI_NXT (pin_H4)
|
|
|
|
#define MICROPY_HW_USB_HS_ULPI_DIR (pin_I11)
|
2018-09-20 02:42:03 +01:00
|
|
|
|
2019-02-22 11:27:48 +00:00
|
|
|
// Ethernet via RMII
|
|
|
|
#define MICROPY_HW_ETH_MDC (pin_C1)
|
|
|
|
#define MICROPY_HW_ETH_MDIO (pin_A2)
|
|
|
|
#define MICROPY_HW_ETH_RMII_REF_CLK (pin_A1)
|
|
|
|
#define MICROPY_HW_ETH_RMII_CRS_DV (pin_A7)
|
|
|
|
#define MICROPY_HW_ETH_RMII_RXD0 (pin_C4)
|
|
|
|
#define MICROPY_HW_ETH_RMII_RXD1 (pin_C5)
|
|
|
|
#define MICROPY_HW_ETH_RMII_TX_EN (pin_G11)
|
|
|
|
#define MICROPY_HW_ETH_RMII_TXD0 (pin_G13)
|
|
|
|
#define MICROPY_HW_ETH_RMII_TXD1 (pin_G14)
|
|
|
|
|
2018-09-20 02:42:03 +01:00
|
|
|
#if 0
|
2019-09-10 12:31:53 +01:00
|
|
|
// Optional SDRAM configuration.
|
|
|
|
|
|
|
|
// Note: This requires SYSCLK <= 200MHz. 192MHz example below:
|
|
|
|
// #define MICROPY_HW_CLK_PLLM (25)
|
|
|
|
// #define MICROPY_HW_CLK_PLLN (384)
|
|
|
|
// #define MICROPY_HW_CLK_PLLP (RCC_PLLP_DIV2)
|
|
|
|
// #define MICROPY_HW_CLK_PLLQ (8)
|
|
|
|
|
2018-09-20 02:42:03 +01:00
|
|
|
#define MICROPY_HW_SDRAM_SIZE (128 * 1024 * 1024 / 8) // 128 Mbit
|
|
|
|
#define MICROPY_HW_SDRAM_STARTUP_TEST (0)
|
2018-10-02 13:08:25 +01:00
|
|
|
#define MICROPY_HEAP_START sdram_start()
|
|
|
|
#define MICROPY_HEAP_END sdram_end()
|
2018-09-20 02:42:03 +01:00
|
|
|
|
|
|
|
// Timing configuration for 90 Mhz (11.90ns) of SD clock frequency (180Mhz/2)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TMRD (2)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TXSR (7)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TRAS (4)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TRC (7)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TWR (2)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TRP (2)
|
|
|
|
#define MICROPY_HW_SDRAM_TIMING_TRCD (2)
|
|
|
|
#define MICROPY_HW_SDRAM_REFRESH_RATE (64) // ms
|
|
|
|
|
|
|
|
#define MICROPY_HW_SDRAM_BURST_LENGTH 1
|
|
|
|
#define MICROPY_HW_SDRAM_CAS_LATENCY 2
|
|
|
|
#define MICROPY_HW_SDRAM_COLUMN_BITS_NUM 8
|
2019-09-10 12:31:53 +01:00
|
|
|
#define MICROPY_HW_SDRAM_ROW_BITS_NUM 12
|
2018-09-20 02:42:03 +01:00
|
|
|
#define MICROPY_HW_SDRAM_MEM_BUS_WIDTH 32
|
|
|
|
#define MICROPY_HW_SDRAM_INTERN_BANKS_NUM 4
|
|
|
|
#define MICROPY_HW_SDRAM_CLOCK_PERIOD 2
|
|
|
|
#define MICROPY_HW_SDRAM_RPIPE_DELAY 0
|
|
|
|
#define MICROPY_HW_SDRAM_RBURST (1)
|
|
|
|
#define MICROPY_HW_SDRAM_WRITE_PROTECTION (0)
|
|
|
|
#define MICROPY_HW_SDRAM_AUTOREFRESH_NUM (8)
|
|
|
|
|
|
|
|
// See pins.csv for CPU pin mapping
|
|
|
|
#define MICROPY_HW_FMC_SDCKE0 (pyb_pin_FMC_SDCKE0)
|
|
|
|
#define MICROPY_HW_FMC_SDNE0 (pyb_pin_FMC_SDNE0)
|
|
|
|
#define MICROPY_HW_FMC_SDCLK (pyb_pin_FMC_SDCLK)
|
|
|
|
#define MICROPY_HW_FMC_SDNCAS (pyb_pin_FMC_SDNCAS)
|
|
|
|
#define MICROPY_HW_FMC_SDNRAS (pyb_pin_FMC_SDNRAS)
|
|
|
|
#define MICROPY_HW_FMC_SDNWE (pyb_pin_FMC_SDNWE)
|
|
|
|
#define MICROPY_HW_FMC_BA0 (pyb_pin_FMC_BA0)
|
|
|
|
#define MICROPY_HW_FMC_BA1 (pyb_pin_FMC_BA1)
|
|
|
|
#define MICROPY_HW_FMC_NBL0 (pyb_pin_FMC_NBL0)
|
|
|
|
#define MICROPY_HW_FMC_NBL1 (pyb_pin_FMC_NBL1)
|
|
|
|
#define MICROPY_HW_FMC_NBL2 (pyb_pin_FMC_NBL2)
|
|
|
|
#define MICROPY_HW_FMC_NBL3 (pyb_pin_FMC_NBL3)
|
|
|
|
#define MICROPY_HW_FMC_A0 (pyb_pin_FMC_A0)
|
|
|
|
#define MICROPY_HW_FMC_A1 (pyb_pin_FMC_A1)
|
|
|
|
#define MICROPY_HW_FMC_A2 (pyb_pin_FMC_A2)
|
|
|
|
#define MICROPY_HW_FMC_A3 (pyb_pin_FMC_A3)
|
|
|
|
#define MICROPY_HW_FMC_A4 (pyb_pin_FMC_A4)
|
|
|
|
#define MICROPY_HW_FMC_A5 (pyb_pin_FMC_A5)
|
|
|
|
#define MICROPY_HW_FMC_A6 (pyb_pin_FMC_A6)
|
|
|
|
#define MICROPY_HW_FMC_A7 (pyb_pin_FMC_A7)
|
|
|
|
#define MICROPY_HW_FMC_A8 (pyb_pin_FMC_A8)
|
|
|
|
#define MICROPY_HW_FMC_A9 (pyb_pin_FMC_A9)
|
|
|
|
#define MICROPY_HW_FMC_A10 (pyb_pin_FMC_A10)
|
|
|
|
#define MICROPY_HW_FMC_A11 (pyb_pin_FMC_A11)
|
|
|
|
#define MICROPY_HW_FMC_A12 (pyb_pin_FMC_A12)
|
|
|
|
#define MICROPY_HW_FMC_D0 (pyb_pin_FMC_D0)
|
|
|
|
#define MICROPY_HW_FMC_D1 (pyb_pin_FMC_D1)
|
|
|
|
#define MICROPY_HW_FMC_D2 (pyb_pin_FMC_D2)
|
|
|
|
#define MICROPY_HW_FMC_D3 (pyb_pin_FMC_D3)
|
|
|
|
#define MICROPY_HW_FMC_D4 (pyb_pin_FMC_D4)
|
|
|
|
#define MICROPY_HW_FMC_D5 (pyb_pin_FMC_D5)
|
|
|
|
#define MICROPY_HW_FMC_D6 (pyb_pin_FMC_D6)
|
|
|
|
#define MICROPY_HW_FMC_D7 (pyb_pin_FMC_D7)
|
|
|
|
#define MICROPY_HW_FMC_D8 (pyb_pin_FMC_D8)
|
|
|
|
#define MICROPY_HW_FMC_D9 (pyb_pin_FMC_D9)
|
|
|
|
#define MICROPY_HW_FMC_D10 (pyb_pin_FMC_D10)
|
|
|
|
#define MICROPY_HW_FMC_D11 (pyb_pin_FMC_D11)
|
|
|
|
#define MICROPY_HW_FMC_D12 (pyb_pin_FMC_D12)
|
|
|
|
#define MICROPY_HW_FMC_D13 (pyb_pin_FMC_D13)
|
|
|
|
#define MICROPY_HW_FMC_D14 (pyb_pin_FMC_D14)
|
|
|
|
#define MICROPY_HW_FMC_D15 (pyb_pin_FMC_D15)
|
|
|
|
#define MICROPY_HW_FMC_D16 (pyb_pin_FMC_D16)
|
|
|
|
#define MICROPY_HW_FMC_D17 (pyb_pin_FMC_D17)
|
|
|
|
#define MICROPY_HW_FMC_D18 (pyb_pin_FMC_D18)
|
|
|
|
#define MICROPY_HW_FMC_D19 (pyb_pin_FMC_D19)
|
|
|
|
#define MICROPY_HW_FMC_D20 (pyb_pin_FMC_D20)
|
|
|
|
#define MICROPY_HW_FMC_D21 (pyb_pin_FMC_D21)
|
|
|
|
#define MICROPY_HW_FMC_D22 (pyb_pin_FMC_D22)
|
|
|
|
#define MICROPY_HW_FMC_D23 (pyb_pin_FMC_D23)
|
|
|
|
#define MICROPY_HW_FMC_D24 (pyb_pin_FMC_D24)
|
|
|
|
#define MICROPY_HW_FMC_D25 (pyb_pin_FMC_D25)
|
|
|
|
#define MICROPY_HW_FMC_D26 (pyb_pin_FMC_D26)
|
|
|
|
#define MICROPY_HW_FMC_D27 (pyb_pin_FMC_D27)
|
|
|
|
#define MICROPY_HW_FMC_D28 (pyb_pin_FMC_D28)
|
|
|
|
#define MICROPY_HW_FMC_D29 (pyb_pin_FMC_D29)
|
|
|
|
#define MICROPY_HW_FMC_D30 (pyb_pin_FMC_D30)
|
|
|
|
#define MICROPY_HW_FMC_D31 (pyb_pin_FMC_D31)
|
|
|
|
#endif
|
2019-03-04 11:32:44 +00:00
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
// Bootloader configuration
|
|
|
|
|
|
|
|
// Give Mboot access to the external QSPI flash
|
|
|
|
#define MBOOT_SPIFLASH_ADDR (0x90000000)
|
|
|
|
#define MBOOT_SPIFLASH_BYTE_SIZE (512 * 128 * 1024)
|
|
|
|
#define MBOOT_SPIFLASH_LAYOUT "/0x90000000/512*128Kg"
|
|
|
|
#define MBOOT_SPIFLASH_ERASE_BLOCKS_PER_PAGE (128 / 4) // 128k page, 4k erase block
|
|
|
|
#define MBOOT_SPIFLASH_CONFIG (&spiflash_config)
|
2020-01-30 03:40:38 +00:00
|
|
|
#define MBOOT_SPIFLASH_SPIFLASH (&spi_bdev.spiflash)
|