/* * (C) Copyright 2016 * Vikas Manocha, * * SPDX-License-Identifier: GPL-2.0+ */ #include #include #include #include #include #include #include #include #include DECLARE_GLOBAL_DATA_PTR; const struct stm32_gpio_ctl gpio_ctl_gpout = { .mode = STM32_GPIO_MODE_OUT, .otype = STM32_GPIO_OTYPE_PP, .speed = STM32_GPIO_SPEED_50M, .pupd = STM32_GPIO_PUPD_NO, .af = STM32_GPIO_AF0 }; const struct stm32_gpio_ctl gpio_ctl_usart = { .mode = STM32_GPIO_MODE_AF, .otype = STM32_GPIO_OTYPE_PP, .speed = STM32_GPIO_SPEED_50M, .pupd = STM32_GPIO_PUPD_UP, .af = STM32_GPIO_AF7 }; static const struct stm32_gpio_dsc usart_gpio[] = { {STM32_GPIO_PORT_A, STM32_GPIO_PIN_9}, /* TX */ {STM32_GPIO_PORT_B, STM32_GPIO_PIN_7}, /* RX */ }; int uart_setup_gpio(void) { int i; int rv = 0; clock_setup(GPIO_A_CLOCK_CFG); clock_setup(GPIO_B_CLOCK_CFG); for (i = 0; i < ARRAY_SIZE(usart_gpio); i++) { rv = stm32_gpio_config(&usart_gpio[i], &gpio_ctl_usart); if (rv) goto out; } out: return rv; } static const struct stm32x7_serial_platdata serial_platdata = { .base = (struct stm32_usart *)USART1_BASE, .clock = CONFIG_SYS_CLK_FREQ, }; U_BOOT_DEVICE(stm32x7_serials) = { .name = "serial_stm32x7", .platdata = &serial_platdata, }; u32 get_board_rev(void) { return 0; } int board_early_init_f(void) { int res; res = uart_setup_gpio(); clock_setup(USART1_CLOCK_CFG); if (res) return res; return 0; } int board_init(void) { gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100; return 0; } int dram_init(void) { gd->bd->bi_dram[0].start = CONFIG_SYS_RAM_BASE; gd->bd->bi_dram[0].size = CONFIG_SYS_RAM_SIZE; gd->ram_size = CONFIG_SYS_RAM_SIZE; return 0; }