|
| 1 | +#define MICROPY_HW_BOARD_NAME "NUCLEO_H723ZG" |
| 2 | +#define MICROPY_HW_MCU_NAME "STM32H723ZGT6" |
| 3 | + |
| 4 | +#define MICROPY_HW_ENABLE_RTC (1) |
| 5 | +#define MICROPY_HW_ENABLE_RNG (0) // RNG needs proper configuration |
| 6 | +#define MICROPY_HW_ENABLE_ADC (1) |
| 7 | +#define MICROPY_HW_ENABLE_DAC (1) |
| 8 | +#define MICROPY_HW_ENABLE_USB (1) |
| 9 | +#define MICROPY_HW_ENABLE_SDCARD (1) |
| 10 | +#define MICROPY_HW_HAS_SWITCH (1) |
| 11 | +#define MICROPY_HW_HAS_FLASH (1) |
| 12 | + |
| 13 | +#define MICROPY_BOARD_EARLY_INIT NUCLEO_H723ZG_board_early_init |
| 14 | + |
| 15 | +// There is no external HS crystal, instead it comes from ST-LINK MCO output which is 8MHz. |
| 16 | +// The following gives a 550MHz CPU speed. |
| 17 | +#define MICROPY_HW_CLK_USE_BYPASS (1) |
| 18 | +#define MICROPY_HW_CLK_PLLM (4) |
| 19 | +#define MICROPY_HW_CLK_PLLN (275) |
| 20 | +#define MICROPY_HW_CLK_PLLP (1) |
| 21 | +#define MICROPY_HW_CLK_PLLQ (4) |
| 22 | +#define MICROPY_HW_CLK_PLLR (2) |
| 23 | +#define MICROPY_HW_CLK_PLLVCI (RCC_PLL1VCIRANGE_1) |
| 24 | +#define MICROPY_HW_CLK_PLLVCO (RCC_PLL1VCOWIDE) |
| 25 | +#define MICROPY_HW_CLK_PLLFRAC (0) |
| 26 | + |
| 27 | +// The USB clock is set using PLL3 |
| 28 | +#define MICROPY_HW_CLK_PLL3M (4) |
| 29 | +#define MICROPY_HW_CLK_PLL3N (120) |
| 30 | +#define MICROPY_HW_CLK_PLL3P (2) |
| 31 | +#define MICROPY_HW_CLK_PLL3Q (5) |
| 32 | +#define MICROPY_HW_CLK_PLL3R (2) |
| 33 | +#define MICROPY_HW_CLK_PLL3VCI (RCC_PLL3VCIRANGE_1) |
| 34 | +#define MICROPY_HW_CLK_PLL3VCO (RCC_PLL3VCOWIDE) |
| 35 | +#define MICROPY_HW_CLK_PLL3FRAC (0) |
| 36 | + |
| 37 | +// 4 wait states |
| 38 | +#define MICROPY_HW_FLASH_LATENCY FLASH_LATENCY_4 |
| 39 | + |
| 40 | +// The board has an external 32kHz crystal attached |
| 41 | +#define MICROPY_HW_RTC_USE_LSE (1) |
| 42 | + |
| 43 | +// UART config |
| 44 | +#define MICROPY_HW_UART2_TX (pin_D5) |
| 45 | +#define MICROPY_HW_UART2_RX (pin_D6) |
| 46 | +#define MICROPY_HW_UART2_RTS (pin_D4) |
| 47 | +#define MICROPY_HW_UART2_CTS (pin_D3) |
| 48 | +#define MICROPY_HW_UART3_TX (pin_D8) |
| 49 | +#define MICROPY_HW_UART3_RX (pin_D9) |
| 50 | +#define MICROPY_HW_UART5_TX (pin_B6) |
| 51 | +#define MICROPY_HW_UART5_RX (pin_B12) |
| 52 | +#define MICROPY_HW_UART6_TX (pin_C6) |
| 53 | +#define MICROPY_HW_UART6_RX (pin_C7) |
| 54 | +#define MICROPY_HW_UART7_TX (pin_F7) |
| 55 | +#define MICROPY_HW_UART7_RX (pin_F6) |
| 56 | +#define MICROPY_HW_UART8_TX (pin_E1) |
| 57 | +#define MICROPY_HW_UART8_RX (pin_E0) |
| 58 | + |
| 59 | +#define MICROPY_HW_UART_REPL PYB_UART_3 |
| 60 | +#define MICROPY_HW_UART_REPL_BAUD 115200 |
| 61 | + |
| 62 | +// I2C buses |
| 63 | +#define MICROPY_HW_I2C1_SCL (pin_B8) |
| 64 | +#define MICROPY_HW_I2C1_SDA (pin_B9) |
| 65 | +#define MICROPY_HW_I2C2_SCL (pin_F1) |
| 66 | +#define MICROPY_HW_I2C2_SDA (pin_F0) |
| 67 | +#define MICROPY_HW_I2C4_SCL (pin_F14) |
| 68 | +#define MICROPY_HW_I2C4_SDA (pin_F15) |
| 69 | + |
| 70 | +// SPI buses |
| 71 | +#define MICROPY_HW_SPI3_NSS (pin_A4) |
| 72 | +#define MICROPY_HW_SPI3_SCK (pin_B3) |
| 73 | +#define MICROPY_HW_SPI3_MISO (pin_B4) |
| 74 | +#define MICROPY_HW_SPI3_MOSI (pin_B5) |
| 75 | + |
| 76 | +// USRSW is pulled low. Pressing the button makes the input go high. |
| 77 | +#define MICROPY_HW_USRSW_PIN (pin_C13) |
| 78 | +#define MICROPY_HW_USRSW_PULL (GPIO_NOPULL) |
| 79 | +#define MICROPY_HW_USRSW_EXTI_MODE (GPIO_MODE_IT_RISING) |
| 80 | +#define MICROPY_HW_USRSW_PRESSED (1) |
| 81 | + |
| 82 | +// LEDs |
| 83 | +#define MICROPY_HW_LED1 (pin_B0) // green |
| 84 | +#define MICROPY_HW_LED2 (pin_E1) // yellow |
| 85 | +#define MICROPY_HW_LED3 (pin_B14) // red |
| 86 | +#define MICROPY_HW_LED_ON(pin) (mp_hal_pin_high(pin)) |
| 87 | +#define MICROPY_HW_LED_OFF(pin) (mp_hal_pin_low(pin)) |
| 88 | + |
| 89 | +// USB config |
| 90 | +#define MICROPY_HW_USB_HS (1) |
| 91 | +#define MICROPY_HW_USB_HS_IN_FS (1) |
| 92 | +#define MICROPY_HW_USB_VBUS_DETECT_PIN (pin_A9) |
| 93 | +#define MICROPY_HW_USB_OTG_ID_PIN (pin_A10) |
| 94 | + |
| 95 | +// FDCAN bus |
| 96 | +#define MICROPY_HW_CAN1_NAME "FDCAN1" |
| 97 | +#define MICROPY_HW_CAN1_TX (pin_D1) |
| 98 | +#define MICROPY_HW_CAN1_RX (pin_D0) |
| 99 | + |
| 100 | +// SD card detect switch |
| 101 | +#define MICROPY_HW_SDCARD_DETECT_PIN (pin_G2) |
| 102 | +#define MICROPY_HW_SDCARD_DETECT_PULL (GPIO_PULLUP) |
| 103 | +#define MICROPY_HW_SDCARD_DETECT_PRESENT (GPIO_PIN_RESET) |
| 104 | + |
| 105 | +// Ethernet via RMII |
| 106 | +#define MICROPY_HW_ETH_MDC (pin_C1) |
| 107 | +#define MICROPY_HW_ETH_MDIO (pin_A2) |
| 108 | +#define MICROPY_HW_ETH_RMII_REF_CLK (pin_A1) |
| 109 | +#define MICROPY_HW_ETH_RMII_CRS_DV (pin_A7) |
| 110 | +#define MICROPY_HW_ETH_RMII_RXD0 (pin_C4) |
| 111 | +#define MICROPY_HW_ETH_RMII_RXD1 (pin_C5) |
| 112 | +#define MICROPY_HW_ETH_RMII_TX_EN (pin_G11) |
| 113 | +#define MICROPY_HW_ETH_RMII_TXD0 (pin_G13) |
| 114 | +#define MICROPY_HW_ETH_RMII_TXD1 (pin_B13) |
| 115 | + |
| 116 | +void NUCLEO_H723ZG_board_early_init(void); |
0 commit comments