2018-02-20 22:35:05 +00:00
|
|
|
#define MICROPY_HW_BOARD_NAME "NUCLEO_H743ZI"
|
|
|
|
#define MICROPY_HW_MCU_NAME "STM32H743"
|
|
|
|
|
|
|
|
#define MICROPY_HW_ENABLE_RTC (1)
|
2018-04-13 23:11:46 +01:00
|
|
|
#define MICROPY_HW_ENABLE_RNG (1)
|
2018-04-11 13:19:40 +01:00
|
|
|
#define MICROPY_HW_ENABLE_ADC (1)
|
2018-04-06 00:05:22 +01:00
|
|
|
#define MICROPY_HW_ENABLE_DAC (1)
|
2018-02-20 22:35:05 +00:00
|
|
|
#define MICROPY_HW_ENABLE_USB (1)
|
2019-04-01 05:21:26 +01:00
|
|
|
#define MICROPY_HW_ENABLE_SDCARD (1)
|
2018-02-20 22:35:05 +00:00
|
|
|
#define MICROPY_HW_HAS_SWITCH (1)
|
|
|
|
#define MICROPY_HW_HAS_FLASH (1)
|
|
|
|
|
|
|
|
#define MICROPY_BOARD_EARLY_INIT NUCLEO_H743ZI_board_early_init
|
|
|
|
void NUCLEO_H743ZI_board_early_init(void);
|
|
|
|
|
|
|
|
// The board has an 8MHz HSE, the following gives 400MHz CPU speed
|
2022-04-08 08:41:19 +01:00
|
|
|
#define MICROPY_HW_CLK_PLLM (4)
|
|
|
|
#define MICROPY_HW_CLK_PLLN (400)
|
|
|
|
#define MICROPY_HW_CLK_PLLP (2)
|
|
|
|
#define MICROPY_HW_CLK_PLLQ (4)
|
|
|
|
#define MICROPY_HW_CLK_PLLR (2)
|
|
|
|
#define MICROPY_HW_CLK_PLLVCI (RCC_PLL1VCIRANGE_1)
|
|
|
|
#define MICROPY_HW_CLK_PLLVCO (RCC_PLL1VCOWIDE)
|
|
|
|
#define MICROPY_HW_CLK_PLLFRAC (0)
|
2018-02-20 22:35:05 +00:00
|
|
|
|
2018-10-24 21:52:36 +01:00
|
|
|
// The USB clock is set using PLL3
|
2022-04-08 08:41:19 +01:00
|
|
|
#define MICROPY_HW_CLK_PLL3M (4)
|
|
|
|
#define MICROPY_HW_CLK_PLL3N (120)
|
|
|
|
#define MICROPY_HW_CLK_PLL3P (2)
|
|
|
|
#define MICROPY_HW_CLK_PLL3Q (5)
|
|
|
|
#define MICROPY_HW_CLK_PLL3R (2)
|
|
|
|
#define MICROPY_HW_CLK_PLL3VCI (RCC_PLL3VCIRANGE_1)
|
|
|
|
#define MICROPY_HW_CLK_PLL3VCO (RCC_PLL3VCOWIDE)
|
|
|
|
#define MICROPY_HW_CLK_PLL3FRAC (0)
|
2018-10-24 21:52:36 +01:00
|
|
|
|
2018-02-20 22:35:05 +00:00
|
|
|
// 4 wait states
|
|
|
|
#define MICROPY_HW_FLASH_LATENCY FLASH_LATENCY_4
|
|
|
|
|
|
|
|
// UART config
|
2019-12-10 20:52:30 +00:00
|
|
|
#define MICROPY_HW_UART2_TX (pin_D5)
|
|
|
|
#define MICROPY_HW_UART2_RX (pin_D6)
|
|
|
|
#define MICROPY_HW_UART2_RTS (pin_D4)
|
|
|
|
#define MICROPY_HW_UART2_CTS (pin_D3)
|
2018-02-20 22:35:05 +00:00
|
|
|
#define MICROPY_HW_UART3_TX (pin_D8)
|
|
|
|
#define MICROPY_HW_UART3_RX (pin_D9)
|
2019-12-10 20:52:30 +00:00
|
|
|
#define MICROPY_HW_UART5_TX (pin_B6)
|
|
|
|
#define MICROPY_HW_UART5_RX (pin_B12)
|
|
|
|
#define MICROPY_HW_UART6_TX (pin_C6)
|
|
|
|
#define MICROPY_HW_UART6_RX (pin_C7)
|
|
|
|
#define MICROPY_HW_UART7_TX (pin_F7)
|
|
|
|
#define MICROPY_HW_UART7_RX (pin_F6)
|
|
|
|
#define MICROPY_HW_UART8_TX (pin_E1)
|
|
|
|
#define MICROPY_HW_UART8_RX (pin_E0)
|
|
|
|
|
2018-02-20 22:35:05 +00:00
|
|
|
#define MICROPY_HW_UART_REPL PYB_UART_3
|
|
|
|
#define MICROPY_HW_UART_REPL_BAUD 115200
|
|
|
|
|
2021-05-20 07:21:47 +01:00
|
|
|
// I2C buses
|
2018-03-19 13:10:57 +00:00
|
|
|
#define MICROPY_HW_I2C1_SCL (pin_B8)
|
|
|
|
#define MICROPY_HW_I2C1_SDA (pin_B9)
|
|
|
|
#define MICROPY_HW_I2C2_SCL (pin_F1)
|
|
|
|
#define MICROPY_HW_I2C2_SDA (pin_F0)
|
2019-12-10 20:52:30 +00:00
|
|
|
#define MICROPY_HW_I2C4_SCL (pin_F14)
|
|
|
|
#define MICROPY_HW_I2C4_SDA (pin_F15)
|
2018-02-20 22:35:05 +00:00
|
|
|
|
2021-05-20 07:21:47 +01:00
|
|
|
// SPI buses
|
2019-05-14 14:56:40 +01:00
|
|
|
#define MICROPY_HW_SPI3_NSS (pin_A4)
|
|
|
|
#define MICROPY_HW_SPI3_SCK (pin_B3)
|
|
|
|
#define MICROPY_HW_SPI3_MISO (pin_B4)
|
|
|
|
#define MICROPY_HW_SPI3_MOSI (pin_B5)
|
2018-02-20 22:35:05 +00:00
|
|
|
|
|
|
|
// USRSW is pulled low. Pressing the button makes the input go high.
|
|
|
|
#define MICROPY_HW_USRSW_PIN (pin_C13)
|
|
|
|
#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_B0) // green
|
|
|
|
#define MICROPY_HW_LED2 (pin_B7) // blue
|
|
|
|
#define MICROPY_HW_LED3 (pin_B14) // red
|
|
|
|
#define MICROPY_HW_LED_ON(pin) (mp_hal_pin_high(pin))
|
|
|
|
#define MICROPY_HW_LED_OFF(pin) (mp_hal_pin_low(pin))
|
|
|
|
|
|
|
|
// USB config
|
|
|
|
#define MICROPY_HW_USB_FS (1)
|
|
|
|
#define MICROPY_HW_USB_VBUS_DETECT_PIN (pin_A9)
|
|
|
|
#define MICROPY_HW_USB_OTG_ID_PIN (pin_A10)
|
2018-03-24 19:24:06 +00:00
|
|
|
|
2019-09-16 00:57:08 +01:00
|
|
|
// FDCAN bus
|
|
|
|
#define MICROPY_HW_CAN1_NAME "FDCAN1"
|
|
|
|
#define MICROPY_HW_CAN1_TX (pin_D1)
|
|
|
|
#define MICROPY_HW_CAN1_RX (pin_D0)
|
|
|
|
|
2018-03-24 19:24:06 +00:00
|
|
|
// SD card detect switch
|
|
|
|
#define MICROPY_HW_SDCARD_DETECT_PIN (pin_G2)
|
|
|
|
#define MICROPY_HW_SDCARD_DETECT_PULL (GPIO_PULLUP)
|
|
|
|
#define MICROPY_HW_SDCARD_DETECT_PRESENT (GPIO_PIN_RESET)
|
2019-12-10 20:52:30 +00:00
|
|
|
|
2020-07-24 22:13:17 +01:00
|
|
|
// Ethernet via RMII
|
|
|
|
#define MICROPY_HW_ETH_MDC (pin_C1)
|
2019-12-10 20:52:30 +00:00
|
|
|
#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_B13)
|