diff --git a/ARM-tegra-Add-NVIDIA-Jetson-Nano-Developer-Kit-support.patch b/ARM-tegra-Add-NVIDIA-Jetson-Nano-Developer-Kit-support.patch deleted file mode 100644 index 70bb946..0000000 --- a/ARM-tegra-Add-NVIDIA-Jetson-Nano-Developer-Kit-support.patch +++ /dev/null @@ -1,777 +0,0 @@ -From patchwork Mon Mar 18 23:24:22 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v2, - 15/15] ARM: tegra: Add NVIDIA Jetson Nano Developer Kit support -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1058155 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190318232422.24404-16-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Tue, 19 Mar 2019 00:24:22 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - -From: Thierry Reding - -The Jetson Nano Developer Kit is a Tegra X1 based development board. It -is similar to Jetson TX1 but it is not pin compatible. It features 4 GB -of LPDDR4, an SPI NOR flash for early boot firmware and an SD card slot -used for storage. - -HDMI 2.0 or DP 1.2 are available for display, four USB ports (3 USB 2.0 -and 1 USB 3.0) can be used to attach a variety of peripherals and a PCI -Ethernet controller provides onboard network connectivity. - -A 40-pin header on the board can be used to extend the capabilities and -exposed interfaces of the Jetson Nano. - -Signed-off-by: Thierry Reding ---- - arch/arm/dts/tegra210-p3450-0000.dts | 130 +++++++++ - arch/arm/mach-tegra/tegra210/Kconfig | 7 + - board/nvidia/p3450-0000/Kconfig | 12 + - board/nvidia/p3450-0000/MAINTAINERS | 6 + - board/nvidia/p3450-0000/Makefile | 8 + - board/nvidia/p3450-0000/p3450-0000.c | 143 ++++++++++ - .../p3450-0000/pinmux-config-p3450-0000.h | 257 ++++++++++++++++++ - configs/p3450-0000_defconfig | 54 ++++ - include/configs/p3450-0000.h | 44 +++ - 9 files changed, 661 insertions(+) - create mode 100644 arch/arm/dts/tegra210-p3450-0000.dts - create mode 100644 board/nvidia/p3450-0000/Kconfig - create mode 100644 board/nvidia/p3450-0000/MAINTAINERS - create mode 100644 board/nvidia/p3450-0000/Makefile - create mode 100644 board/nvidia/p3450-0000/p3450-0000.c - create mode 100644 board/nvidia/p3450-0000/pinmux-config-p3450-0000.h - create mode 100644 configs/p3450-0000_defconfig - create mode 100644 include/configs/p3450-0000.h - -diff --git a/arch/arm/dts/tegra210-p3450-0000.dts b/arch/arm/dts/tegra210-p3450-0000.dts -new file mode 100644 -index 000000000000..a2119165e2f6 ---- /dev/null -+++ b/arch/arm/dts/tegra210-p3450-0000.dts -@@ -0,0 +1,130 @@ -+/dts-v1/; -+ -+#include "tegra210.dtsi" -+ -+/ { -+ model = "NVIDIA Jetson Nano Development Kit"; -+ compatible = "nvidia,p3450-0000", "nvidia,tegra210"; -+ -+ chosen { -+ stdout-path = &uarta; -+ }; -+ -+ aliases { -+ i2c0 = "/i2c@7000d000"; -+ i2c2 = "/i2c@7000c400"; -+ i2c3 = "/i2c@7000c500"; -+ i2c4 = "/i2c@7000c700"; -+ sdhci0 = "/sdhci@700b0600"; -+ sdhci1 = "/sdhci@700b0000"; -+ spi0 = "/spi@70410000"; -+ usb0 = "/usb@7d000000"; -+ }; -+ -+ memory { -+ reg = <0x0 0x80000000 0x0 0xc0000000>; -+ }; -+ -+ pcie-controller@01003000 { -+ status = "okay"; -+ -+ pci@1,0 { -+ status = "okay"; -+ }; -+ -+ pci@2,0 { -+ status = "okay"; -+ }; -+ }; -+ -+ serial@70006000 { -+ status = "okay"; -+ }; -+ -+ padctl@7009f000 { -+ pinctrl-0 = <&padctl_default>; -+ pinctrl-names = "default"; -+ -+ padctl_default: pinmux { -+ xusb { -+ nvidia,lanes = "otg-1", "otg-2"; -+ nvidia,function = "xusb"; -+ nvidia,iddq = <0>; -+ }; -+ -+ usb3 { -+ nvidia,lanes = "pcie-5", "pcie-6"; -+ nvidia,function = "usb3"; -+ nvidia,iddq = <0>; -+ }; -+ -+ pcie-x1 { -+ nvidia,lanes = "pcie-0"; -+ nvidia,function = "pcie-x1"; -+ nvidia,iddq = <0>; -+ }; -+ -+ pcie-x4 { -+ nvidia,lanes = "pcie-1", "pcie-2", -+ "pcie-3", "pcie-4"; -+ nvidia,function = "pcie-x4"; -+ nvidia,iddq = <0>; -+ }; -+ -+ sata { -+ nvidia,lanes = "sata-0"; -+ nvidia,function = "sata"; -+ nvidia,iddq = <0>; -+ }; -+ }; -+ }; -+ -+ sdhci@700b0000 { -+ status = "okay"; -+ cd-gpios = <&gpio TEGRA_GPIO(Z, 1) GPIO_ACTIVE_LOW>; -+ power-gpios = <&gpio TEGRA_GPIO(Z, 3) GPIO_ACTIVE_HIGH>; -+ bus-width = <4>; -+ }; -+ -+ i2c@7000c400 { -+ status = "okay"; -+ clock-frequency = <400000>; -+ }; -+ -+ i2c@7000c500 { -+ status = "okay"; -+ clock-frequency = <400000>; -+ }; -+ -+ i2c@7000c700 { -+ status = "okay"; -+ clock-frequency = <400000>; -+ }; -+ -+ i2c@7000d000 { -+ status = "okay"; -+ clock-frequency = <400000>; -+ }; -+ -+ spi@70410000 { -+ status = "okay"; -+ }; -+ -+ usb@7d000000 { -+ status = "okay"; -+ dr_mode = "peripheral"; -+ }; -+ -+ clocks { -+ compatible = "simple-bus"; -+ #address-cells = <1>; -+ #size-cells = <0>; -+ -+ clk32k_in: clock@0 { -+ compatible = "fixed-clock"; -+ reg = <0>; -+ #clock-cells = <0>; -+ clock-frequency = <32768>; -+ }; -+ }; -+}; -diff --git a/arch/arm/mach-tegra/tegra210/Kconfig b/arch/arm/mach-tegra/tegra210/Kconfig -index 250738aed312..60dde5435940 100644 ---- a/arch/arm/mach-tegra/tegra210/Kconfig -+++ b/arch/arm/mach-tegra/tegra210/Kconfig -@@ -35,6 +35,12 @@ config TARGET_P2571 - help - P2571 is a P2530 married to a P1963 I/O board - -+config TARGET_P3450_0000 -+ bool "NVIDIA Jetson Nano Development Kit" -+ select BOARD_LATE_INIT -+ help -+ P3450-0000 is a P3448 CPU board married to a P3449 I/O board. -+ - endchoice - - config SYS_SOC -@@ -47,5 +53,6 @@ source "board/nvidia/e2220-1170/Kconfig" - source "board/nvidia/p2371-0000/Kconfig" - source "board/nvidia/p2371-2180/Kconfig" - source "board/nvidia/p2571/Kconfig" -+source "board/nvidia/p3450-0000/Kconfig" - - endif -diff --git a/board/nvidia/p3450-0000/Kconfig b/board/nvidia/p3450-0000/Kconfig -new file mode 100644 -index 000000000000..7a08cd88675f ---- /dev/null -+++ b/board/nvidia/p3450-0000/Kconfig -@@ -0,0 +1,12 @@ -+if TARGET_P3450_0000 -+ -+config SYS_BOARD -+ default "p3450-0000" -+ -+config SYS_VENDOR -+ default "nvidia" -+ -+config SYS_CONFIG_NAME -+ default "p3450-0000" -+ -+endif -diff --git a/board/nvidia/p3450-0000/MAINTAINERS b/board/nvidia/p3450-0000/MAINTAINERS -new file mode 100644 -index 000000000000..40700066bf39 ---- /dev/null -+++ b/board/nvidia/p3450-0000/MAINTAINERS -@@ -0,0 +1,6 @@ -+P3450-0000 BOARD -+M: Tom Warren -+S: Maintained -+F: board/nvidia/p3450-0000/ -+F: include/configs/p3450-0000.h -+F: configs/p3450-0000_defconfig -diff --git a/board/nvidia/p3450-0000/Makefile b/board/nvidia/p3450-0000/Makefile -new file mode 100644 -index 000000000000..993c506d8200 ---- /dev/null -+++ b/board/nvidia/p3450-0000/Makefile -@@ -0,0 +1,8 @@ -+# -+# (C) Copyright 2018 -+# NVIDIA Corporation -+# -+# SPDX-License-Identifier: GPL-2.0+ -+# -+ -+obj-y += p3450-0000.o -diff --git a/board/nvidia/p3450-0000/p3450-0000.c b/board/nvidia/p3450-0000/p3450-0000.c -new file mode 100644 -index 000000000000..fc13185c36b6 ---- /dev/null -+++ b/board/nvidia/p3450-0000/p3450-0000.c -@@ -0,0 +1,143 @@ -+/* -+ * (C) Copyright 2018 -+ * NVIDIA Corporation -+ * -+ * SPDX-License-Identifier: GPL-2.0+ -+ */ -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include "../p2571/max77620_init.h" -+#include "pinmux-config-p3450-0000.h" -+ -+void pin_mux_mmc(void) -+{ -+ struct udevice *dev; -+ uchar val; -+ int ret; -+ -+ /* Turn on MAX77620 LDO2 to 3.3V for SD card power */ -+ debug("%s: Set LDO2 for VDDIO_SDMMC_AP power to 3.3V\n", __func__); -+ ret = i2c_get_chip_for_busnum(0, MAX77620_I2C_ADDR_7BIT, 1, &dev); -+ if (ret) { -+ printf("%s: Cannot find MAX77620 I2C chip\n", __func__); -+ return; -+ } -+ /* 0xF2 for 3.3v, enabled: bit7:6 = 11 = enable, bit5:0 = voltage */ -+ val = 0xF2; -+ ret = dm_i2c_write(dev, MAX77620_CNFG1_L2_REG, &val, 1); -+ if (ret) -+ printf("i2c_write 0 0x3c 0x27 failed: %d\n", ret); -+ -+ /* Disable LDO4 discharge */ -+ ret = dm_i2c_read(dev, MAX77620_CNFG2_L4_REG, &val, 1); -+ if (ret) { -+ printf("i2c_read 0 0x3c 0x2c failed: %d\n", ret); -+ } else { -+ val &= ~BIT(1); /* ADE */ -+ ret = dm_i2c_write(dev, MAX77620_CNFG2_L4_REG, &val, 1); -+ if (ret) -+ printf("i2c_write 0 0x3c 0x2c failed: %d\n", ret); -+ } -+ -+ /* Set MBLPD */ -+ ret = dm_i2c_read(dev, MAX77620_CNFGGLBL1_REG, &val, 1); -+ if (ret) { -+ printf("i2c_write 0 0x3c 0x00 failed: %d\n", ret); -+ } else { -+ val |= BIT(6); /* MBLPD */ -+ ret = dm_i2c_write(dev, MAX77620_CNFGGLBL1_REG, &val, 1); -+ if (ret) -+ printf("i2c_write 0 0x3c 0x00 failed: %d\n", ret); -+ } -+} -+ -+/* -+ * Routine: pinmux_init -+ * Description: Do individual peripheral pinmux configs -+ */ -+void pinmux_init(void) -+{ -+ pinmux_clear_tristate_input_clamping(); -+ -+ gpio_config_table(p3450_0000_gpio_inits, -+ ARRAY_SIZE(p3450_0000_gpio_inits)); -+ -+ pinmux_config_pingrp_table(p3450_0000_pingrps, -+ ARRAY_SIZE(p3450_0000_pingrps)); -+ -+ pinmux_config_drvgrp_table(p3450_0000_drvgrps, -+ ARRAY_SIZE(p3450_0000_drvgrps)); -+} -+ -+#ifdef CONFIG_PCI_TEGRA -+int tegra_pcie_board_init(void) -+{ -+ struct udevice *dev; -+ uchar val; -+ int ret; -+ -+ /* Turn on MAX77620 LDO1 to 1.05V for PEX power */ -+ debug("%s: Set LDO1 for PEX power to 1.05V\n", __func__); -+ ret = i2c_get_chip_for_busnum(0, MAX77620_I2C_ADDR_7BIT, 1, &dev); -+ if (ret) { -+ printf("%s: Cannot find MAX77620 I2C chip\n", __func__); -+ return -1; -+ } -+ /* 0xCA for 1.05v, enabled: bit7:6 = 11 = enable, bit5:0 = voltage */ -+ val = 0xCA; -+ ret = dm_i2c_write(dev, MAX77620_CNFG1_L1_REG, &val, 1); -+ if (ret) -+ printf("i2c_write 0 0x3c 0x25 failed: %d\n", ret); -+ -+ return 0; -+} -+#endif /* PCI */ -+ -+int ft_board_setup(void *fdt, bd_t *bd) -+{ -+ const void *cboot_fdt = (const void *)cboot_boot_x0; -+ uint8_t mac[ETH_ALEN], local_mac[ETH_ALEN]; -+ const char *path; -+ int offset, err; -+ -+ err = cboot_get_ethaddr(cboot_fdt, local_mac); -+ if (err < 0) -+ memset(local_mac, 0, ETH_ALEN); -+ -+ path = fdt_get_alias(fdt, "ethernet"); -+ if (!path) -+ return 0; -+ -+ debug("ethernet alias found: %s\n", path); -+ -+ offset = fdt_path_offset(fdt, path); -+ if (offset < 0) -+ return 0; -+ -+ debug("PCI ethernet device tree node found\n"); -+ -+ if (is_valid_ethaddr(local_mac)) { -+ err = fdt_setprop(fdt, offset, "local-mac-address", local_mac, -+ ETH_ALEN); -+ if (!err) -+ debug("Local MAC address set: %pM\n", local_mac); -+ } -+ -+ if (eth_env_get_enetaddr("ethaddr", mac)) { -+ if (memcmp(local_mac, mac, ETH_ALEN) != 0) { -+ err = fdt_setprop(fdt, offset, "mac-address", mac, -+ ETH_ALEN); -+ if (!err) -+ debug("MAC address set: %pM\n", mac); -+ } -+ } -+ -+ return 0; -+} -diff --git a/board/nvidia/p3450-0000/pinmux-config-p3450-0000.h b/board/nvidia/p3450-0000/pinmux-config-p3450-0000.h -new file mode 100644 -index 000000000000..d491bffccd72 ---- /dev/null -+++ b/board/nvidia/p3450-0000/pinmux-config-p3450-0000.h -@@ -0,0 +1,257 @@ -+/* -+ * Copyright (c) 2018-2019, NVIDIA CORPORATION. All rights reserved. -+ * -+ * SPDX-License-Identifier: GPL-2.0+ -+ */ -+ -+/* -+ * THIS FILE IS AUTO-GENERATED - DO NOT EDIT! -+ * -+ * To generate this file, use the tegra-pinmux-scripts tool available from -+ * https://github.com/NVIDIA/tegra-pinmux-scripts -+ * Run "board-to-uboot.py p3450-0000". -+ */ -+ -+#ifndef _PINMUX_CONFIG_P3450_0000_H_ -+#define _PINMUX_CONFIG_P3450_0000_H_ -+ -+#define GPIO_INIT(_port, _gpio, _init) \ -+ { \ -+ .gpio = TEGRA_GPIO(_port, _gpio), \ -+ .init = TEGRA_GPIO_INIT_##_init, \ -+ } -+ -+static const struct tegra_gpio_config p3450_0000_gpio_inits[] = { -+ /* port, pin, init_val */ -+ GPIO_INIT(A, 5, IN), -+ GPIO_INIT(A, 6, OUT0), -+ GPIO_INIT(B, 4, IN), -+ GPIO_INIT(B, 5, IN), -+ GPIO_INIT(B, 6, IN), -+ GPIO_INIT(B, 7, IN), -+ GPIO_INIT(C, 0, IN), -+ GPIO_INIT(C, 1, IN), -+ GPIO_INIT(C, 2, IN), -+ GPIO_INIT(C, 3, IN), -+ GPIO_INIT(C, 4, IN), -+ GPIO_INIT(E, 6, IN), -+ GPIO_INIT(G, 2, IN), -+ GPIO_INIT(G, 3, IN), -+ GPIO_INIT(H, 0, OUT0), -+ GPIO_INIT(H, 2, IN), -+ GPIO_INIT(H, 3, OUT0), -+ GPIO_INIT(H, 4, OUT0), -+ GPIO_INIT(H, 5, IN), -+ GPIO_INIT(H, 6, IN), -+ GPIO_INIT(H, 7, OUT0), -+ GPIO_INIT(I, 0, OUT0), -+ GPIO_INIT(I, 1, IN), -+ GPIO_INIT(I, 2, OUT0), -+ GPIO_INIT(J, 4, IN), -+ GPIO_INIT(J, 5, IN), -+ GPIO_INIT(J, 6, IN), -+ GPIO_INIT(J, 7, IN), -+ GPIO_INIT(S, 5, IN), -+ GPIO_INIT(S, 7, OUT0), -+ GPIO_INIT(T, 0, OUT0), -+ GPIO_INIT(V, 0, IN), -+ GPIO_INIT(V, 1, IN), -+ GPIO_INIT(X, 3, OUT1), -+ GPIO_INIT(X, 4, IN), -+ GPIO_INIT(X, 5, IN), -+ GPIO_INIT(X, 6, IN), -+ GPIO_INIT(Y, 1, IN), -+ GPIO_INIT(Y, 2, IN), -+ GPIO_INIT(Z, 0, IN), -+ GPIO_INIT(Z, 2, IN), -+ GPIO_INIT(Z, 3, OUT0), -+ GPIO_INIT(BB, 0, IN), -+ GPIO_INIT(CC, 4, IN), -+ GPIO_INIT(DD, 0, IN), -+}; -+ -+#define PINCFG(_pingrp, _mux, _pull, _tri, _io, _od, _e_io_hv) \ -+ { \ -+ .pingrp = PMUX_PINGRP_##_pingrp, \ -+ .func = PMUX_FUNC_##_mux, \ -+ .pull = PMUX_PULL_##_pull, \ -+ .tristate = PMUX_TRI_##_tri, \ -+ .io = PMUX_PIN_##_io, \ -+ .od = PMUX_PIN_OD_##_od, \ -+ .e_io_hv = PMUX_PIN_E_IO_HV_##_e_io_hv, \ -+ .lock = PMUX_PIN_LOCK_DEFAULT, \ -+ } -+ -+static const struct pmux_pingrp_config p3450_0000_pingrps[] = { -+ /* pingrp, mux, pull, tri, e_input, od, e_io_hv */ -+ PINCFG(PEX_L0_RST_N_PA0, PE0, NORMAL, NORMAL, OUTPUT, DISABLE, NORMAL), -+ PINCFG(PEX_L0_CLKREQ_N_PA1, PE0, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(PEX_WAKE_N_PA2, PE, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(PEX_L1_RST_N_PA3, PE1, NORMAL, NORMAL, OUTPUT, DISABLE, NORMAL), -+ PINCFG(PEX_L1_CLKREQ_N_PA4, PE1, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(SATA_LED_ACTIVE_PA5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PA6, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SPI2_MOSI_PB4, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI2_MISO_PB5, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI2_SCK_PB6, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI2_CS0_PB7, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI1_MOSI_PC0, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI1_MISO_PC1, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI1_SCK_PC2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI1_CS0_PC3, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI1_CS1_PC4, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SPI4_SCK_PC5, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SPI4_CS0_PC6, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SPI4_MOSI_PC7, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SPI4_MISO_PD0, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART3_TX_PD1, UARTC, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART3_RX_PD2, UARTC, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(UART3_RTS_PD3, UARTC, UP, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART3_CTS_PD4, UARTC, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DMIC1_CLK_PE0, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DMIC1_DAT_PE1, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DMIC2_CLK_PE2, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DMIC2_DAT_PE3, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DMIC3_CLK_PE4, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(DMIC3_DAT_PE5, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PE6, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PE7, PWM3, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(GEN3_I2C_SCL_PF0, I2C3, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(GEN3_I2C_SDA_PF1, I2C3, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(UART2_TX_PG0, UARTB, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART2_RX_PG1, UARTB, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(UART2_RTS_PG2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(UART2_CTS_PG3, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(WIFI_EN_PH0, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(WIFI_RST_PH1, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(WIFI_WAKE_AP_PH2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(AP_WAKE_BT_PH3, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(BT_RST_PH4, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(BT_WAKE_AP_PH5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PH6, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(AP_WAKE_NFC_PH7, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(NFC_EN_PI0, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(NFC_INT_PI1, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(GPS_EN_PI2, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(GPS_RST_PI3, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART4_TX_PI4, UARTD, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART4_RX_PI5, UARTD, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(UART4_RTS_PI6, UARTD, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART4_CTS_PI7, UARTD, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(GEN1_I2C_SDA_PJ0, I2C1, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(GEN1_I2C_SCL_PJ1, I2C1, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(GEN2_I2C_SCL_PJ2, I2C2, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(GEN2_I2C_SDA_PJ3, I2C2, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(PK0, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK1, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK2, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK3, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK4, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK5, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK6, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PK7, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PL0, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PL1, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC1_CLK_PM0, SDMMC1, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC1_CMD_PM1, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC1_DAT3_PM2, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC1_DAT2_PM3, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC1_DAT1_PM4, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC1_DAT0_PM5, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC3_CLK_PP0, SDMMC3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC3_CMD_PP1, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC3_DAT3_PP2, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC3_DAT2_PP3, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC3_DAT1_PP4, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(SDMMC3_DAT0_PP5, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(CAM1_MCLK_PS0, EXTPERIPH3, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CAM2_MCLK_PS1, EXTPERIPH3, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CAM_I2C_SCL_PS2, I2CVI, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(CAM_I2C_SDA_PS3, I2CVI, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(CAM_RST_PS4, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CAM_AF_EN_PS5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(CAM_FLASH_EN_PS6, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CAM1_PWDN_PS7, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CAM2_PWDN_PT0, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CAM1_STROBE_PT1, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART1_TX_PU0, UARTA, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART1_RX_PU1, UARTA, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(UART1_RTS_PU2, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(UART1_CTS_PU3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(LCD_BL_PWM_PV0, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(LCD_BL_EN_PV1, DEFAULT, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(LCD_RST_PV2, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(LCD_GPIO1_PV3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(LCD_GPIO2_PV4, PWM1, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(AP_READY_PV5, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(TOUCH_RST_PV6, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(TOUCH_CLK_PV7, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(MODEM_WAKE_AP_PX0, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(TOUCH_INT_PX1, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(MOTION_INT_PX2, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(ALS_PROX_INT_PX3, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(TEMP_ALERT_PX4, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(BUTTON_POWER_ON_PX5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(BUTTON_VOL_UP_PX6, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(BUTTON_VOL_DOWN_PX7, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(BUTTON_SLIDE_SW_PY0, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(BUTTON_HOME_PY1, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(LCD_TE_PY2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PWR_I2C_SCL_PY3, I2CPMU, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(PWR_I2C_SDA_PY4, I2CPMU, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(CLK_32K_OUT_PY5, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PZ0, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PZ1, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PZ2, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PZ3, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PZ4, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PZ5, SOC, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DAP2_FS_PAA0, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DAP2_SCLK_PAA1, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DAP2_DIN_PAA2, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DAP2_DOUT_PAA3, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(AUD_MCLK_PBB0, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(DVFS_PWM_PBB1, CLDVFS, NORMAL, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(DVFS_CLK_PBB2, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(GPIO_X1_AUD_PBB3, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(GPIO_X3_AUD_PBB4, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(HDMI_CEC_PCC0, CEC, NORMAL, NORMAL, INPUT, DISABLE, HIGH), -+ PINCFG(HDMI_INT_DP_HPD_PCC1, DP, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(SPDIF_OUT_PCC2, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SPDIF_IN_PCC3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(USB_VBUS_EN0_PCC4, DEFAULT, UP, NORMAL, INPUT, DISABLE, NORMAL), -+ PINCFG(USB_VBUS_EN1_PCC5, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, NORMAL), -+ PINCFG(DP_HPD0_PCC6, DP, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(PCC7, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, NORMAL), -+ PINCFG(SPI2_CS1_PDD0, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(QSPI_SCK_PEE0, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(QSPI_CS_N_PEE1, QSPI, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(QSPI_IO0_PEE2, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(QSPI_IO1_PEE3, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(QSPI_IO2_PEE4, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(QSPI_IO3_PEE5, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(CORE_PWR_REQ, CORE, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CPU_PWR_REQ, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(PWR_INT_N, PMI, UP, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(CLK_32K_IN, CLK, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), -+ PINCFG(JTAG_RTCK, JTAG, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(CLK_REQ, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), -+ PINCFG(SHUTDOWN, SHUTDOWN, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), -+}; -+ -+#define DRVCFG(_drvgrp, _slwf, _slwr, _drvup, _drvdn, _lpmd, _schmt, _hsm) \ -+ { \ -+ .drvgrp = PMUX_DRVGRP_##_drvgrp, \ -+ .slwf = _slwf, \ -+ .slwr = _slwr, \ -+ .drvup = _drvup, \ -+ .drvdn = _drvdn, \ -+ .lpmd = PMUX_LPMD_##_lpmd, \ -+ .schmt = PMUX_SCHMT_##_schmt, \ -+ .hsm = PMUX_HSM_##_hsm, \ -+ } -+ -+static const struct pmux_drvgrp_config p3450_0000_drvgrps[] = { -+}; -+ -+#endif /* PINMUX_CONFIG_P3450_0000_H */ -diff --git a/configs/p3450-0000_defconfig b/configs/p3450-0000_defconfig -new file mode 100644 -index 000000000000..32c2b65a2979 ---- /dev/null -+++ b/configs/p3450-0000_defconfig -@@ -0,0 +1,54 @@ -+CONFIG_ARM=y -+CONFIG_TEGRA=y -+CONFIG_SYS_TEXT_BASE=0x80110000 -+CONFIG_POSITION_INDEPENDENT=y -+CONFIG_TEGRA210=y -+CONFIG_TARGET_P3450_0000=y -+CONFIG_NR_DRAM_BANKS=2 -+CONFIG_OF_SYSTEM_SETUP=y -+CONFIG_OF_BOARD_SETUP=y -+CONFIG_CONSOLE_MUX=y -+CONFIG_SYS_STDIO_DEREGISTER=y -+CONFIG_SYS_PROMPT="Tegra210 (P3450-0000) # " -+# CONFIG_CMD_IMI is not set -+CONFIG_CMD_DFU=y -+# CONFIG_CMD_FLASH is not set -+CONFIG_CMD_GPIO=y -+CONFIG_CMD_I2C=y -+CONFIG_CMD_MMC=y -+CONFIG_CMD_PCI=y -+CONFIG_CMD_SF=y -+CONFIG_CMD_SPI=y -+CONFIG_CMD_USB=y -+CONFIG_CMD_USB_MASS_STORAGE=y -+# CONFIG_CMD_SETEXPR is not set -+# CONFIG_CMD_NFS is not set -+CONFIG_CMD_EXT4_WRITE=y -+CONFIG_OF_LIVE=y -+CONFIG_DEFAULT_DEVICE_TREE="tegra210-p3450-0000" -+CONFIG_DFU_MMC=y -+CONFIG_DFU_RAM=y -+CONFIG_DFU_SF=y -+CONFIG_SYS_I2C_TEGRA=y -+CONFIG_SPI_FLASH=y -+CONFIG_SPI_FLASH_WINBOND=y -+CONFIG_RTL8169=y -+CONFIG_PCI=y -+CONFIG_DM_PCI=y -+CONFIG_DM_PCI_COMPAT=y -+CONFIG_PCI_TEGRA=y -+CONFIG_SYS_NS16550=y -+CONFIG_TEGRA114_SPI=y -+CONFIG_USB=y -+CONFIG_DM_USB=y -+CONFIG_USB_EHCI_HCD=y -+CONFIG_USB_EHCI_TEGRA=y -+CONFIG_USB_GADGET=y -+CONFIG_USB_GADGET_MANUFACTURER="NVIDIA" -+CONFIG_USB_GADGET_VENDOR_NUM=0x0955 -+CONFIG_USB_GADGET_PRODUCT_NUM=0x701a -+CONFIG_CI_UDC=y -+CONFIG_USB_GADGET_DOWNLOAD=y -+CONFIG_USB_HOST_ETHER=y -+CONFIG_USB_ETHER_ASIX=y -+# CONFIG_ENV_IS_IN_MMC is not set -diff --git a/include/configs/p3450-0000.h b/include/configs/p3450-0000.h -new file mode 100644 -index 000000000000..37c71421acbb ---- /dev/null -+++ b/include/configs/p3450-0000.h -@@ -0,0 +1,44 @@ -+/* SPDX-License-Identifier: GPL-2.0+ */ -+/* -+ * (C) Copyright 2018-2019 NVIDIA Corporation. All rights reserved. -+ */ -+ -+#ifndef _P3450_0000_H -+#define _P3450_0000_H -+ -+#include -+ -+#include "tegra210-common.h" -+ -+/* High-level configuration options */ -+#define CONFIG_TEGRA_BOARD_STRING "NVIDIA P3450-0000" -+ -+/* Board-specific serial config */ -+#define CONFIG_TEGRA_ENABLE_UARTA -+ -+/* Only MMC1/PXE/DHCP for now, add USB back in later when supported */ -+#define BOOT_TARGET_DEVICES(func) \ -+ func(MMC, mmc, 0) \ -+ func(PXE, pxe, na) \ -+ func(DHCP, dhcp, na) -+ -+/* SPI */ -+#define CONFIG_SF_DEFAULT_MODE SPI_MODE_0 -+#define CONFIG_SF_DEFAULT_SPEED 24000000 -+#define CONFIG_SPI_FLASH_SIZE (4 << 20) -+ -+#define CONFIG_PREBOOT -+ -+#define BOARD_EXTRA_ENV_SETTINGS \ -+ "preboot=if test -e mmc 1:1 /u-boot-preboot.scr; then " \ -+ "load mmc 1:1 ${scriptaddr} /u-boot-preboot.scr; " \ -+ "source ${scriptaddr}; " \ -+ "fi\0" -+ -+#include "tegra-common-usb-gadget.h" -+#include "tegra-common-post.h" -+ -+/* Crystal is 38.4MHz. clk_m runs at half that rate */ -+#define COUNTER_FREQUENCY 19200000 -+ -+#endif /* _P3450_0000_H */ diff --git a/ARM-tegra-Add-support-for-framebuffer-carveouts.patch b/ARM-tegra-Add-support-for-framebuffer-carveouts.patch index 3e1dc09..5672527 100644 --- a/ARM-tegra-Add-support-for-framebuffer-carveouts.patch +++ b/ARM-tegra-Add-support-for-framebuffer-carveouts.patch @@ -1,20 +1,75 @@ -From patchwork Thu Mar 21 18:09:58 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,01/13] libfdt: Add phandle generation helper -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060358 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-2-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:09:58 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 87409c02ff1cc7249f0fdccbb44c607931cb9bb2 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Fri, 1 Mar 2019 19:20:48 +0100 +Subject: [PATCH 01/12] fdt: Remove duplicate code + +Commit 6d29cc7dcf2d ("fdt: Fixup only valid memory banks") ended up +being merged twice, first as: + + commit 6d29cc7dcf2d35966aa0b6119fd1cbca0d21d5e6 + Author: Thierry Reding + AuthorDate: Tue Jan 30 11:34:17 2018 +0100 + Commit: Simon Glass + CommitDate: Sun Feb 18 12:53:38 2018 -0700 + + fdt: Fixup only valid memory banks + + Memory banks with address 0 and size 0 are empty and should not be + passed to the OS via device tree. + + Signed-off-by: Thierry Reding + Acked-by: Stephen Warren + +and later again, though this time it was v2: + + commit ed5af03f9bb8905f1e94d68ab49f22d7f061d75f + Author: Thierry Reding + AuthorDate: Thu Feb 15 19:05:59 2018 +0100 + Commit: Tom Rini + CommitDate: Fri Feb 23 10:40:50 2018 -0500 + + fdt: Fixup only valid memory banks + + Memory banks with address 0 and size 0 are empty and should not be + passed to the OS via device tree. + + Acked-by: Stephen Warren + Signed-off-by: Thierry Reding + +The second version was slightly different, so the main hunk of the patch +was applied twice. This isn't harmful because the code is idempotent, +but it's wasteful to run the same code twice. + +Signed-off-by: Thierry Reding +Reviewed-by: Simon Glass +--- + common/fdt_support.c | 6 ------ + 1 file changed, 6 deletions(-) + +diff --git a/common/fdt_support.c b/common/fdt_support.c +index 42583e3ed8..ab08a0114f 100644 +--- a/common/fdt_support.c ++++ b/common/fdt_support.c +@@ -456,12 +456,6 @@ int fdt_fixup_memory_banks(void *blob, u64 start[], u64 size[], int banks) + if (!banks) + return 0; + +- for (i = 0; i < banks; i++) +- if (start[i] == 0 && size[i] == 0) +- break; +- +- banks = i; +- + len = fdt_pack_reg(blob, tmp, start, size, banks); + + err = fdt_setprop(blob, nodeoffset, "reg", tmp, len); +-- +2.21.0 + +From abf9afc43916b5e16972bd595d2d34c3abff3613 Mon Sep 17 00:00:00 2001 +From: Thierry Reding +Date: Thu, 21 Mar 2019 19:09:58 +0100 +Subject: [PATCH 02/12] libfdt: Add phandle generation helper The new fdt_generate_phandle() function can be used to generate a new, unused phandle given a specific device tree blob. The implementation is @@ -30,9 +85,6 @@ are indeed unique. Signed-off-by: Thierry Reding Reviewed-by: Simon Glass --- -Changes in v3: -- update to latest upstream commit - lib/libfdt/fdt_ro.c | 31 +++++++++++++++++++++++++++++++ scripts/dtc/libfdt/fdt_ro.c | 31 +++++++++++++++++++++++++++++++ scripts/dtc/libfdt/libfdt.h | 19 +++++++++++++++++++ @@ -40,7 +92,7 @@ Changes in v3: 4 files changed, 82 insertions(+) diff --git a/lib/libfdt/fdt_ro.c b/lib/libfdt/fdt_ro.c -index b6ca4e0b0c30..693de9aa5ad8 100644 +index b6ca4e0b0c..693de9aa5a 100644 --- a/lib/libfdt/fdt_ro.c +++ b/lib/libfdt/fdt_ro.c @@ -73,6 +73,37 @@ uint32_t fdt_get_max_phandle(const void *fdt) @@ -82,7 +134,7 @@ index b6ca4e0b0c30..693de9aa5ad8 100644 { FDT_CHECK_HEADER(fdt); diff --git a/scripts/dtc/libfdt/fdt_ro.c b/scripts/dtc/libfdt/fdt_ro.c -index dfb3236da388..dc499884e4d1 100644 +index dfb3236da3..dc499884e4 100644 --- a/scripts/dtc/libfdt/fdt_ro.c +++ b/scripts/dtc/libfdt/fdt_ro.c @@ -115,6 +115,37 @@ uint32_t fdt_get_max_phandle(const void *fdt) @@ -124,7 +176,7 @@ index dfb3236da388..dc499884e4d1 100644 { FDT_CHECK_HEADER(fdt); diff --git a/scripts/dtc/libfdt/libfdt.h b/scripts/dtc/libfdt/libfdt.h -index fd73688f9e9f..cf86ddba8811 100644 +index fd73688f9e..cf86ddba88 100644 --- a/scripts/dtc/libfdt/libfdt.h +++ b/scripts/dtc/libfdt/libfdt.h @@ -139,6 +139,10 @@ @@ -161,7 +213,7 @@ index fd73688f9e9f..cf86ddba8811 100644 * fdt_num_mem_rsv - retrieve the number of memory reserve map entries * @fdt: pointer to the device tree blob diff --git a/scripts/dtc/libfdt/libfdt_env.h b/scripts/dtc/libfdt/libfdt_env.h -index bd2474628775..3ff9e2863075 100644 +index bd24746287..3ff9e28630 100644 --- a/scripts/dtc/libfdt/libfdt_env.h +++ b/scripts/dtc/libfdt/libfdt_env.h @@ -52,6 +52,7 @@ @@ -172,24 +224,13 @@ index bd2474628775..3ff9e2863075 100644 #include #include #include +-- +2.21.0 -From patchwork Thu Mar 21 18:09:59 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,02/13] fdtdec: Add cpu_to_fdt_{addr, size}() macros -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060376 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-3-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:09:59 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 57d9e1ba51831b787ac114c8b5ab17cc44a22977 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:09:59 +0100 +Subject: [PATCH 03/12] fdtdec: Add cpu_to_fdt_{addr, size}() macros These macros are useful for converting the endianness of variables of type fdt_addr_t and fdt_size_t. @@ -197,14 +238,11 @@ type fdt_addr_t and fdt_size_t. Reviewed-by: Simon Glass Signed-off-by: Thierry Reding --- -Changes in v2: -- add Reviewed-by from Simon - include/fdtdec.h | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/include/fdtdec.h b/include/fdtdec.h -index b7e35cd87c55..a965c33157c9 100644 +index b7e35cd87c..a965c33157 100644 --- a/include/fdtdec.h +++ b/include/fdtdec.h @@ -27,11 +27,15 @@ typedef phys_size_t fdt_size_t; @@ -223,24 +261,13 @@ index b7e35cd87c55..a965c33157c9 100644 typedef fdt32_t fdt_val_t; #endif +-- +2.21.0 -From patchwork Thu Mar 21 18:10:00 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,03/13] fdtdec: Add fdt_{addr, size}_unpack() helpers -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060360 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-4-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:00 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 30086fd2012b1f00cc1d4d11e962634236277d17 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:00 +0100 +Subject: [PATCH 04/12] fdtdec: Add fdt_{addr, size}_unpack() helpers These helpers can be used to unpack variables of type fdt_addr_t and fdt_size_t into a pair of 32-bit variables. This is useful in cases @@ -249,14 +276,11 @@ of a device tree node where they need to be split into cells. Signed-off-by: Thierry Reding --- -Changes in v2: -- new patch - include/fdtdec.h | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/include/fdtdec.h b/include/fdtdec.h -index a965c33157c9..a0ba57c6318b 100644 +index a965c33157..a0ba57c631 100644 --- a/include/fdtdec.h +++ b/include/fdtdec.h @@ -23,6 +23,31 @@ @@ -291,38 +315,24 @@ index a965c33157c9..a0ba57c6318b 100644 #ifdef CONFIG_PHYS_64BIT #define FDT_ADDR_T_NONE (-1U) #define fdt_addr_to_cpu(reg) be64_to_cpu(reg) +-- +2.21.0 -From patchwork Thu Mar 21 18:10:01 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,04/13] fdtdec: Implement fdtdec_set_phandle() -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060366 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-5-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:01 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 33c157fbae9cf088c8374543daf012487e3d3c07 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:01 +0100 +Subject: [PATCH 05/12] fdtdec: Implement fdtdec_set_phandle() This function can be used to set a phandle for a given node. Signed-off-by: Thierry Reding --- -Changes in v2: -- don't emit deprecated linux,phandle property - include/fdtdec.h | 11 +++++++++++ lib/fdtdec.c | 7 +++++++ 2 files changed, 18 insertions(+) diff --git a/include/fdtdec.h b/include/fdtdec.h -index a0ba57c6318b..55600026c488 100644 +index a0ba57c631..55600026c4 100644 --- a/include/fdtdec.h +++ b/include/fdtdec.h @@ -981,6 +981,17 @@ int fdtdec_setup_mem_size_base(void); @@ -344,7 +354,7 @@ index a0ba57c6318b..55600026c488 100644 * Set up the device tree ready for use */ diff --git a/lib/fdtdec.c b/lib/fdtdec.c -index 09a7e133a539..00db90e3cdfd 100644 +index 09a7e133a5..00db90e3cd 100644 --- a/lib/fdtdec.c +++ b/lib/fdtdec.c @@ -1243,6 +1243,13 @@ __weak void *board_fdt_blob_setup(void) @@ -361,43 +371,19 @@ index 09a7e133a539..00db90e3cdfd 100644 int fdtdec_setup(void) { #if CONFIG_IS_ENABLED(OF_CONTROL) +-- +2.21.0 -From patchwork Thu Mar 21 18:10:02 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,05/13] fdtdec: Implement fdtdec_add_reserved_memory() -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060362 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-6-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:02 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 9c2ed8c44b3d62e01e2885f0e2b077407bf6056b Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:02 +0100 +Subject: [PATCH 06/12] fdtdec: Implement fdtdec_add_reserved_memory() This function can be used to add subnodes in the /reserved-memory node. Reviewed-by: Simon Glass Signed-off-by: Thierry Reding --- -Changes in v3: -- use fdt_generate_phandle() instead of fdtdec_generate_phandle() -- add device tree bindings for /reserved-memory -- add examples to code comments - -Changes in v2: -- split fdt_{addr,size}_unpack() helpers into separate patch -- use name@x,y notation only if the upper cell is > 0 -- use debug() instead of printf() to save code size -- properly compute number of cells in reg property -- fix carveout size computations, was off by one -- use #size-cells where appropriate - .../reserved-memory/reserved-memory.txt | 136 ++++++++++++++++++ include/fdtdec.h | 48 +++++++ lib/fdtdec.c | 131 +++++++++++++++++ @@ -406,7 +392,7 @@ Changes in v2: diff --git a/Documentation/devicetree/bindings/reserved-memory/reserved-memory.txt b/Documentation/devicetree/bindings/reserved-memory/reserved-memory.txt new file mode 100644 -index 000000000000..bac4afa3b197 +index 0000000000..bac4afa3b1 --- /dev/null +++ b/Documentation/devicetree/bindings/reserved-memory/reserved-memory.txt @@ -0,0 +1,136 @@ @@ -547,7 +533,7 @@ index 000000000000..bac4afa3b197 + }; +}; diff --git a/include/fdtdec.h b/include/fdtdec.h -index 55600026c488..b54ed38fb362 100644 +index 55600026c4..b54ed38fb3 100644 --- a/include/fdtdec.h +++ b/include/fdtdec.h @@ -992,6 +992,54 @@ int fdtdec_setup_memory_banksize(void); @@ -606,7 +592,7 @@ index 55600026c488..b54ed38fb362 100644 * Set up the device tree ready for use */ diff --git a/lib/fdtdec.c b/lib/fdtdec.c -index 00db90e3cdfd..be54ad5bd092 100644 +index 00db90e3cd..be54ad5bd0 100644 --- a/lib/fdtdec.c +++ b/lib/fdtdec.c @@ -1250,6 +1250,137 @@ int fdtdec_set_phandle(void *blob, int node, uint32_t phandle) @@ -747,24 +733,13 @@ index 00db90e3cdfd..be54ad5bd092 100644 int fdtdec_setup(void) { #if CONFIG_IS_ENABLED(OF_CONTROL) +-- +2.21.0 -From patchwork Thu Mar 21 18:10:03 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,06/13] fdtdec: Implement carveout support functions -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060373 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-7-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:03 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 58eb0f1af300064b91809e52d96479fd02ce9091 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:03 +0100 +Subject: [PATCH 07/12] fdtdec: Implement carveout support functions The fdtdec_get_carveout() and fdtdec_set_carveout() function can be used to read a carveout from a given node or add a carveout to a given node @@ -774,20 +749,12 @@ and the memory-region property). Reviewed-by: Simon Glass Signed-off-by: Thierry Reding --- -Changes in v3: -- add examples to code comments - -Changes in v2: -- use debug() instead of printf() to save code size -- fix carveout size computations, was off by one -- use fdtdec_get_addr_size_auto_noparent() - include/fdtdec.h | 81 ++++++++++++++++++++++++++++++++++++++++++++ lib/fdtdec.c | 87 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 168 insertions(+) diff --git a/include/fdtdec.h b/include/fdtdec.h -index b54ed38fb362..13b743f59ab1 100644 +index b54ed38fb3..13b743f59a 100644 --- a/include/fdtdec.h +++ b/include/fdtdec.h @@ -1030,6 +1030,8 @@ int fdtdec_set_phandle(void *blob, int node, uint32_t phandle); @@ -886,7 +853,7 @@ index b54ed38fb362..13b743f59ab1 100644 * Set up the device tree ready for use */ diff --git a/lib/fdtdec.c b/lib/fdtdec.c -index be54ad5bd092..bd05ab90fce1 100644 +index be54ad5bd0..bd05ab90fc 100644 --- a/lib/fdtdec.c +++ b/lib/fdtdec.c @@ -1381,6 +1381,93 @@ int fdtdec_add_reserved_memory(void *blob, const char *basename, @@ -983,24 +950,13 @@ index be54ad5bd092..bd05ab90fce1 100644 int fdtdec_setup(void) { #if CONFIG_IS_ENABLED(OF_CONTROL) +-- +2.21.0 -From patchwork Thu Mar 21 18:10:04 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,07/13] fdtdec: Add Kconfig symbol for tests -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060374 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-8-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:04 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 1c1d7d2d6d85003ac2df657588a2c5a78f7db8ad Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:04 +0100 +Subject: [PATCH 08/12] fdtdec: Add Kconfig symbol for tests Runtime tests are provided as a test_fdtdec command implementation. Add a Kconfig symbol that allows this command to be built so that the tests @@ -1009,14 +965,11 @@ can be used. Signed-off-by: Thierry Reding Reviewed-by: Simon Glass --- -Changes in v2: -- new patch - lib/Kconfig | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/lib/Kconfig b/lib/Kconfig -index 366d164cd760..b1fccf7e8dff 100644 +index 366d164cd7..b1fccf7e8d 100644 --- a/lib/Kconfig +++ b/lib/Kconfig @@ -423,4 +423,8 @@ source lib/efi/Kconfig @@ -1028,24 +981,13 @@ index 366d164cd760..b1fccf7e8dff 100644 + depends on OF_LIBFDT + endmenu +-- +2.21.0 -From patchwork Thu Mar 21 18:10:05 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,08/13] fdtdec: test: Fix build warning -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060368 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-9-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:05 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From aa6715267b997d800b7934ce14cf4e5cc6f9bcf9 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:05 +0100 +Subject: [PATCH 09/12] fdtdec: test: Fix build warning Hide the declaration of the "fd" variable When not building a DEBUG configuration, to avoid the variable being unused. @@ -1053,14 +995,11 @@ configuration, to avoid the variable being unused. Signed-off-by: Thierry Reding Reviewed-by: Simon Glass --- -Changes in v2: -- new patch - lib/fdtdec_test.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/fdtdec_test.c b/lib/fdtdec_test.c -index a82e27de942f..065fed278cf3 100644 +index a82e27de94..065fed278c 100644 --- a/lib/fdtdec_test.c +++ b/lib/fdtdec_test.c @@ -79,7 +79,9 @@ static int make_fdt(void *fdt, int size, const char *aliases, @@ -1073,24 +1012,13 @@ index a82e27de942f..065fed278cf3 100644 CHECK(fdt_create(fdt, size)); CHECK(fdt_finish_reservemap(fdt)); +-- +2.21.0 -From patchwork Thu Mar 21 18:10:06 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,09/13] fdtdec: test: Use compound statement macros -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060361 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-10-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:06 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From 952f7a32bc2249e28e0dc08890d663a3b55f74b8 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:06 +0100 +Subject: [PATCH 10/12] fdtdec: test: Use compound statement macros This eliminates the need for intermediate helper functions and allow the macros to return a value so that it can be used subsequently. @@ -1098,14 +1026,11 @@ macros to return a value so that it can be used subsequently. Signed-off-by: Thierry Reding Reviewed-by: Simon Glass --- -Changes in v2: -- new patch - lib/fdtdec_test.c | 64 ++++++++++++++++------------------------------- 1 file changed, 22 insertions(+), 42 deletions(-) diff --git a/lib/fdtdec_test.c b/lib/fdtdec_test.c -index 065fed278cf3..928950918413 100644 +index 065fed278c..9289509184 100644 --- a/lib/fdtdec_test.c +++ b/lib/fdtdec_test.c @@ -15,48 +15,28 @@ @@ -1187,38 +1112,24 @@ index 065fed278cf3..928950918413 100644 /* Check we got the right ones */ for (i = 0, s = expect; *s; s++, i++) { +-- +2.21.0 -From patchwork Thu Mar 21 18:10:07 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,10/13] fdtdec: test: Add carveout tests -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060375 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-11-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:07 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From cd380b7093b9a342244a1cd732621cb960bc1668 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:07 +0100 +Subject: [PATCH 11/12] fdtdec: test: Add carveout tests Implement carveout tests for 32-bit and 64-bit builds. Signed-off-by: Thierry Reding Reviewed-by: Simon Glass --- -Changes in v2: -- new patch - lib/fdtdec_test.c | 152 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 152 insertions(+) diff --git a/lib/fdtdec_test.c b/lib/fdtdec_test.c -index 928950918413..f6defe16c5a6 100644 +index 9289509184..f6defe16c5 100644 --- a/lib/fdtdec_test.c +++ b/lib/fdtdec_test.c @@ -141,6 +141,156 @@ static int run_test(const char *aliases, const char *nodes, const char *expect) @@ -1387,24 +1298,13 @@ index 928950918413..f6defe16c5a6 100644 printf("Test passed\n"); return 0; } +-- +2.21.0 -From patchwork Thu Mar 21 18:10:08 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,11/13] sandbox: Enable fdtdec tests -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060364 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-12-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:08 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - +From ac9681d2d1fa09977106a32c1e2194c7bc6b5c80 Mon Sep 17 00:00:00 2001 From: Thierry Reding +Date: Thu, 21 Mar 2019 19:10:08 +0100 +Subject: [PATCH 12/12] sandbox: Enable fdtdec tests Enable fdtdec tests on sandbox configurations so that they can be run to validate the fdtdec implementation. @@ -1412,15 +1312,12 @@ validate the fdtdec implementation. Signed-off-by: Thierry Reding Reviewed-by: Simon Glass --- -Changes in v2: -- new patch - configs/sandbox64_defconfig | 1 + configs/sandbox_defconfig | 1 + 2 files changed, 2 insertions(+) diff --git a/configs/sandbox64_defconfig b/configs/sandbox64_defconfig -index da4bdced3105..c04ecd915ae7 100644 +index da4bdced31..c04ecd915a 100644 --- a/configs/sandbox64_defconfig +++ b/configs/sandbox64_defconfig @@ -194,6 +194,7 @@ CONFIG_CMD_DHRYSTONE=y @@ -1432,7 +1329,7 @@ index da4bdced3105..c04ecd915ae7 100644 CONFIG_UT_TIME=y CONFIG_UT_DM=y diff --git a/configs/sandbox_defconfig b/configs/sandbox_defconfig -index 193e41896cb7..bb508a8d02e2 100644 +index 193e41896c..bb508a8d02 100644 --- a/configs/sandbox_defconfig +++ b/configs/sandbox_defconfig @@ -215,6 +215,7 @@ CONFIG_CMD_DHRYSTONE=y @@ -1443,243 +1340,193 @@ index 193e41896cb7..bb508a8d02e2 100644 CONFIG_UNIT_TEST=y CONFIG_UT_TIME=y CONFIG_UT_DM=y +-- +2.21.0 -From patchwork Thu Mar 21 18:10:09 2019 +From patchwork Mon Apr 15 08:08:20 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,12/13] p2371-2180: Add support for framebuffer carveouts +Subject: [U-Boot,1/2] fdtdec: Use fdt_setprop_u32() for fdtdec_set_phandle() X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060367 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-13-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:09 +0100 +X-Patchwork-Id: 1085479 +X-Patchwork-Delegate: sjg@chromium.org +Message-Id: <20190415080821.441-1-thierry.reding@gmail.com> +To: Simon Glass +Cc: u-boot@lists.denx.de +Date: Mon, 15 Apr 2019 10:08:20 +0200 From: Thierry Reding List-Id: U-Boot discussion From: Thierry Reding -If early firmware initialized the display hardware and the display -controllers are scanning out a framebuffer (e.g. a splash screen), make -sure to pass information about the memory location of that framebuffer -to the kernel before booting to avoid the kernel from using that memory -for the buddy allocator. - -This same mechanism can also be used in the kernel to set up early SMMU -mappings and avoid SMMU faults caused by the display controller reading -from memory for which it has no mapping. +The fdt_setprop_u32() function does everything that we need, so we +really only use the function as a convenience wrapper, in which case it +can simply be a static inline function. Signed-off-by: Thierry Reding -Reviewed-by: Simon Glass --- - board/nvidia/p2371-2180/p2371-2180.c | 47 ++++++++++++++++++++++++++++ - 1 file changed, 47 insertions(+) + include/fdtdec.h | 5 ++++- + lib/fdtdec.c | 7 ------- + 2 files changed, 4 insertions(+), 8 deletions(-) -diff --git a/board/nvidia/p2371-2180/p2371-2180.c b/board/nvidia/p2371-2180/p2371-2180.c -index a444d692d7ea..4985302d6bc2 100644 ---- a/board/nvidia/p2371-2180/p2371-2180.c -+++ b/board/nvidia/p2371-2180/p2371-2180.c -@@ -6,6 +6,7 @@ - - #include - #include -+#include - #include - #include - #include -@@ -138,9 +139,55 @@ static void ft_mac_address_setup(void *fdt) - } - } - -+static int ft_copy_carveout(void *dst, const void *src, const char *node) +diff --git a/include/fdtdec.h b/include/fdtdec.h +index 266c58271f0b..110aa6ab6dea 100644 +--- a/include/fdtdec.h ++++ b/include/fdtdec.h +@@ -1029,7 +1029,10 @@ int fdtdec_setup_memory_banksize(void); + * @param phandle phandle to set for the given node + * @return 0 on success or a negative error code on failure + */ +-int fdtdec_set_phandle(void *blob, int node, uint32_t phandle); ++static inline int fdtdec_set_phandle(void *blob, int node, uint32_t phandle) +{ -+ struct fdt_memory fb; -+ int err; -+ -+ err = fdtdec_get_carveout(src, node, "memory-region", 0, &fb); -+ if (err < 0) { -+ if (err != -FDT_ERR_NOTFOUND) -+ printf("failed to get carveout for %s: %d\n", node, -+ err); -+ -+ return err; -+ } -+ -+ err = fdtdec_set_carveout(dst, node, "memory-region", 0, "framebuffer", -+ &fb); -+ if (err < 0) { -+ printf("failed to set carveout for %s: %d\n", node, err); -+ return err; -+ } -+ -+ return 0; ++ return fdt_setprop_u32(blob, node, "phandle", phandle); +} -+ -+static void ft_carveout_setup(void *fdt) -+{ -+ const void *cboot_fdt = (const void *)cboot_boot_x0; -+ static const char * const nodes[] = { -+ "/host1x@50000000/dc@54200000", -+ "/host1x@50000000/dc@54240000", -+ }; -+ unsigned int i; -+ int err; -+ -+ for (i = 0; i < ARRAY_SIZE(nodes); i++) { -+ err = ft_copy_carveout(fdt, cboot_fdt, nodes[i]); -+ if (err < 0) { -+ if (err != -FDT_ERR_NOTFOUND) -+ printf("failed to copy carveout for %s: %d\n", -+ nodes[i], err); -+ continue; -+ } -+ } -+} -+ - int ft_board_setup(void *fdt, bd_t *bd) - { - ft_mac_address_setup(fdt); -+ ft_carveout_setup(fdt); - return 0; - } - -From patchwork Thu Mar 21 18:10:10 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v3,13/13] p2771-0000: Add support for framebuffer carveouts -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1060363 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190321181010.27005-14-thierry.reding@gmail.com> -To: Tom Warren , - Simon Glass -Cc: u-boot@lists.denx.de, Stephen Warren -Date: Thu, 21 Mar 2019 19:10:10 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - -From: Thierry Reding - -If early firmware initialized the display hardware and the display -controllers are scanning out a framebuffer (e.g. a splash screen), make -sure to pass information about the memory location of that framebuffer -to the kernel before booting to avoid the kernel from using that memory -for the buddy allocator. - -This same mechanism can also be used in the kernel to set up early SMMU -mappings and avoid SMMU faults caused by the display controller reading -from memory for which it has no mapping. - -Signed-off-by: Thierry Reding -Reviewed-by: Simon Glass ---- - board/nvidia/p2771-0000/p2771-0000.c | 66 ++++++++++++++++++++++++++-- - 1 file changed, 62 insertions(+), 4 deletions(-) - -diff --git a/board/nvidia/p2771-0000/p2771-0000.c b/board/nvidia/p2771-0000/p2771-0000.c -index fe22067f6571..d294c7ae0136 100644 ---- a/board/nvidia/p2771-0000/p2771-0000.c -+++ b/board/nvidia/p2771-0000/p2771-0000.c -@@ -5,6 +5,7 @@ - - #include - #include -+#include - #include - #include - #include -@@ -56,7 +57,7 @@ int tegra_pcie_board_init(void) + /** + * fdtdec_add_reserved_memory() - add or find a reserved-memory node +diff --git a/lib/fdtdec.c b/lib/fdtdec.c +index 9c9c30234732..fea44a9a8c65 100644 +--- a/lib/fdtdec.c ++++ b/lib/fdtdec.c +@@ -1261,13 +1261,6 @@ __weak void *board_fdt_blob_setup(void) } #endif --int ft_board_setup(void *fdt, bd_t *bd) -+static void ft_mac_address_setup(void *fdt) +-int fdtdec_set_phandle(void *blob, int node, uint32_t phandle) +-{ +- fdt32_t value = cpu_to_fdt32(phandle); +- +- return fdt_setprop(blob, node, "phandle", &value, sizeof(value)); +-} +- + static int fdtdec_init_reserved_memory(void *blob) { - const void *cboot_fdt = (const void *)cboot_boot_x0; - uint8_t mac[ETH_ALEN], local_mac[ETH_ALEN]; -@@ -69,13 +70,15 @@ int ft_board_setup(void *fdt, bd_t *bd) + int na, ns, node, err; + +From patchwork Mon Apr 15 08:08:21 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot,2/2] fdtdec: Remove fdt_{addr,size}_unpack() +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085480 +X-Patchwork-Delegate: sjg@chromium.org +Message-Id: <20190415080821.441-2-thierry.reding@gmail.com> +To: Simon Glass +Cc: u-boot@lists.denx.de +Date: Mon, 15 Apr 2019 10:08:21 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +U-Boot already defines the {upper,lower}_32_bits() macros that have the +same purpose. Use the existing macros instead of defining new APIs. + +Signed-off-by: Thierry Reding +--- + include/fdtdec.h | 24 ------------------------ + lib/fdtdec.c | 8 ++++++-- + lib/fdtdec_test.c | 8 ++++++-- + 3 files changed, 12 insertions(+), 28 deletions(-) + +diff --git a/include/fdtdec.h b/include/fdtdec.h +index 110aa6ab6dea..fa8e34f6f960 100644 +--- a/include/fdtdec.h ++++ b/include/fdtdec.h +@@ -24,30 +24,6 @@ + typedef phys_addr_t fdt_addr_t; + typedef phys_size_t fdt_size_t; - path = fdt_get_alias(fdt, "ethernet"); - if (!path) -- return 0; -+ return; +-static inline fdt32_t fdt_addr_unpack(fdt_addr_t addr, fdt32_t *upper) +-{ +- if (upper) +-#ifdef CONFIG_PHYS_64BIT +- *upper = addr >> 32; +-#else +- *upper = 0; +-#endif +- +- return addr; +-} +- +-static inline fdt32_t fdt_size_unpack(fdt_size_t size, fdt32_t *upper) +-{ +- if (upper) +-#ifdef CONFIG_PHYS_64BIT +- *upper = size >> 32; +-#else +- *upper = 0; +-#endif +- +- return size; +-} +- + #ifdef CONFIG_PHYS_64BIT + #define FDT_ADDR_T_NONE (-1U) + #define fdt_addr_to_cpu(reg) be64_to_cpu(reg) +diff --git a/lib/fdtdec.c b/lib/fdtdec.c +index fea44a9a8c65..d0ba88897335 100644 +--- a/lib/fdtdec.c ++++ b/lib/fdtdec.c +@@ -1300,6 +1300,7 @@ int fdtdec_add_reserved_memory(void *blob, const char *basename, + fdt32_t cells[4] = {}, *ptr = cells; + uint32_t upper, lower, phandle; + int parent, node, na, ns, err; ++ fdt_size_t size; + char name[64]; - debug("ethernet alias found: %s\n", path); + /* create an empty /reserved-memory node if one doesn't exist */ +@@ -1340,7 +1341,8 @@ int fdtdec_add_reserved_memory(void *blob, const char *basename, + * Unpack the start address and generate the name of the new node + * base on the basename and the unit-address. + */ +- lower = fdt_addr_unpack(carveout->start, &upper); ++ upper = upper_32_bits(carveout->start); ++ lower = lower_32_bits(carveout->start); - offset = fdt_path_offset(fdt, path); -- if (offset < 0) -- return 0; -+ if (offset < 0) { -+ printf("ethernet alias points to absent node %s\n", path); -+ return; -+ } + if (na > 1 && upper > 0) + snprintf(name, sizeof(name), "%s@%x,%x", basename, upper, +@@ -1374,7 +1376,9 @@ int fdtdec_add_reserved_memory(void *blob, const char *basename, + *ptr++ = cpu_to_fdt32(lower); - if (is_valid_ethaddr(local_mac)) { - err = fdt_setprop(fdt, offset, "local-mac-address", local_mac, -@@ -92,6 +95,61 @@ int ft_board_setup(void *fdt, bd_t *bd) - debug("MAC address set: %pM\n", mac); - } - } -+} -+ -+static int ft_copy_carveout(void *dst, const void *src, const char *node) -+{ -+ struct fdt_memory fb; -+ int err; -+ -+ err = fdtdec_get_carveout(src, node, "memory-region", 0, &fb); -+ if (err < 0) { -+ if (err != -FDT_ERR_NOTFOUND) -+ printf("failed to get carveout for %s: %d\n", node, -+ err); -+ -+ return err; -+ } -+ -+ err = fdtdec_set_carveout(dst, node, "memory-region", 0, "framebuffer", -+ &fb); -+ if (err < 0) { -+ printf("failed to set carveout for %s: %d\n", node, err); -+ return err; -+ } -+ -+ return 0; -+} -+ -+static void ft_carveout_setup(void *fdt) -+{ -+ const void *cboot_fdt = (const void *)cboot_boot_x0; -+ static const char * const nodes[] = { -+ "/host1x@13e00000/display-hub@15200000/display@15200000", -+ "/host1x@13e00000/display-hub@15200000/display@15210000", -+ "/host1x@13e00000/display-hub@15200000/display@15220000", -+ }; -+ unsigned int i; -+ int err; -+ -+ for (i = 0; i < ARRAY_SIZE(nodes); i++) { -+ printf("copying carveout for %s...\n", nodes[i]); -+ -+ err = ft_copy_carveout(fdt, cboot_fdt, nodes[i]); -+ if (err < 0) { -+ if (err != -FDT_ERR_NOTFOUND) -+ printf("failed to copy carveout for %s: %d\n", -+ nodes[i], err); -+ -+ continue; -+ } -+ } -+} -+ -+int ft_board_setup(void *fdt, bd_t *bd) -+{ -+ ft_mac_address_setup(fdt); -+ ft_carveout_setup(fdt); + /* store one or two size cells */ +- lower = fdt_size_unpack(carveout->end - carveout->start + 1, &upper); ++ size = carveout->end - carveout->start + 1; ++ upper = upper_32_bits(size); ++ lower = lower_32_bits(size); - return 0; - } + if (ns > 1) + *ptr++ = cpu_to_fdt32(upper); +diff --git a/lib/fdtdec_test.c b/lib/fdtdec_test.c +index f6defe16c5a6..1f4f27054057 100644 +--- a/lib/fdtdec_test.c ++++ b/lib/fdtdec_test.c +@@ -155,11 +155,13 @@ static int make_fdt_carveout_device(void *fdt, uint32_t na, uint32_t ns) + }; + fdt32_t cells[4], *ptr = cells; + uint32_t upper, lower; ++ fdt_size_t size; + char name[32]; + int offset; + + /* store one or two address cells */ +- lower = fdt_addr_unpack(carveout.start, &upper); ++ upper = upper_32_bits(carveout.start); ++ lower = lower_32_bits(carveout.start); + + if (na > 1 && upper > 0) + snprintf(name, sizeof(name), "%s@%x,%x", basename, upper, +@@ -173,7 +175,9 @@ static int make_fdt_carveout_device(void *fdt, uint32_t na, uint32_t ns) + *ptr++ = cpu_to_fdt32(lower); + + /* store one or two size cells */ +- lower = fdt_size_unpack(carveout.end - carveout.start + 1, &upper); ++ size = carveout.end - carveout.start + 1; ++ upper = upper_32_bits(size); ++ lower = lower_32_bits(size); + + if (ns > 1) + *ptr++ = cpu_to_fdt32(upper); diff --git a/ARM-tegra-Miscellaneous-improvements.patch b/ARM-tegra-Miscellaneous-improvements.patch index f65ecd8..03d2da9 100644 --- a/ARM-tegra-Miscellaneous-improvements.patch +++ b/ARM-tegra-Miscellaneous-improvements.patch @@ -1,16 +1,303 @@ -From patchwork Thu Apr 4 11:59:24 2019 +From patchwork Mon Apr 15 09:32:13 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,01/19] ARM: tegra: Use common header for PMU declarations +Subject: [U-Boot,v5,01/27] fdtdec: Add fdtdec_set_ethernet_mac_address() X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077183 +X-Patchwork-Id: 1085515 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-2-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:24 +0200 +Message-Id: <20190415093239.27509-2-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:13 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +This function can be used to set the local MAC address for the default +Ethernet interface in its device tree node. The default interface is +identified by the "ethernet" alias. + +One case where this is useful is for devices that store their MAC +address in a custom location. Once extracted, board code can store the +MAC address in U-Boot's control DTB so that it will automatically be +used by the Ethernet uclass. + +Signed-off-by: Thierry Reding +--- + include/fdtdec.h | 24 ++++++++++++++++++++++++ + lib/fdtdec.c | 29 +++++++++++++++++++++++++++++ + 2 files changed, 53 insertions(+) + +diff --git a/include/fdtdec.h b/include/fdtdec.h +index fa8e34f6f960..e6c22dd5cd5c 100644 +--- a/include/fdtdec.h ++++ b/include/fdtdec.h +@@ -996,6 +996,30 @@ int fdtdec_setup_memory_banksize_fdt(const void *blob); + */ + int fdtdec_setup_memory_banksize(void); + ++/** ++ * fdtdec_set_ethernet_mac_address() - set MAC address for default interface ++ * ++ * Looks up the default interface via the "ethernet" alias (in the /aliases ++ * node) and stores the given MAC in its "local-mac-address" property. This ++ * is useful on platforms that store the MAC address in a custom location. ++ * Board code can call this in the late init stage to make sure that the ++ * interface device tree node has the right MAC address configured for the ++ * Ethernet uclass to pick it up. ++ * ++ * Typically the FDT passed into this function will be U-Boot's control DTB. ++ * Given that a lot of code may be holding offsets to various nodes in that ++ * tree, this code will only set the "local-mac-address" property in-place, ++ * which means that it needs to exist and have space for the 6-byte address. ++ * This ensures that the operation is non-destructive and does not invalidate ++ * offsets that other drivers may be using. ++ * ++ * @param fdt FDT blob ++ * @param mac buffer containing the MAC address to set ++ * @param size size of MAC address ++ * @return 0 on success or a negative error code on failure ++ */ ++int fdtdec_set_ethernet_mac_address(void *fdt, const u8 *mac, size_t size); ++ + /** + * fdtdec_set_phandle() - sets the phandle of a given node + * +diff --git a/lib/fdtdec.c b/lib/fdtdec.c +index d0ba88897335..3ee786b57940 100644 +--- a/lib/fdtdec.c ++++ b/lib/fdtdec.c +@@ -1261,6 +1261,35 @@ __weak void *board_fdt_blob_setup(void) + } + #endif + ++int fdtdec_set_ethernet_mac_address(void *fdt, const u8 *mac, size_t size) ++{ ++ const char *path; ++ int offset, err; ++ ++ if (!is_valid_ethaddr(mac)) ++ return -EINVAL; ++ ++ path = fdt_get_alias(fdt, "ethernet"); ++ if (!path) ++ return 0; ++ ++ debug("ethernet alias found: %s\n", path); ++ ++ offset = fdt_path_offset(fdt, path); ++ if (offset < 0) { ++ debug("ethernet alias points to absent node %s\n", path); ++ return -ENOENT; ++ } ++ ++ err = fdt_setprop_inplace(fdt, offset, "local-mac-address", mac, size); ++ if (err < 0) ++ return err; ++ ++ debug("MAC address: %pM\n", mac); ++ ++ return 0; ++} ++ + static int fdtdec_init_reserved_memory(void *blob) + { + int na, ns, node, err; + +From patchwork Mon Apr 15 09:32:14 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot,v5,02/27] lib: Implement strndup() +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085516 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-3-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:14 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +Signed-off-by: Thierry Reding +--- + include/linux/string.h | 1 + + lib/string.c | 23 +++++++++++++++++++++++ + 2 files changed, 24 insertions(+) + +diff --git a/include/linux/string.h b/include/linux/string.h +index 36066207392e..5d63be4ce5b0 100644 +--- a/include/linux/string.h ++++ b/include/linux/string.h +@@ -94,6 +94,7 @@ size_t strcspn(const char *s, const char *reject); + #ifndef __HAVE_ARCH_STRDUP + extern char * strdup(const char *); + #endif ++extern char * strndup(const char *, size_t); + #ifndef __HAVE_ARCH_STRSWAB + extern char * strswab(const char *); + #endif +diff --git a/lib/string.c b/lib/string.c +index af17c16f616d..9b779ddc3bbe 100644 +--- a/lib/string.c ++++ b/lib/string.c +@@ -326,6 +326,29 @@ char * strdup(const char *s) + } + #endif + ++char * strndup(const char *s, size_t n) ++{ ++ size_t len; ++ char *new; ++ ++ if (s == NULL) ++ return NULL; ++ ++ len = strlen(s); ++ ++ if (n < len) ++ len = n; ++ ++ new = malloc(len + 1); ++ if (new == NULL) ++ return NULL; ++ ++ strncpy(new, s, len); ++ new[len] = '\0'; ++ ++ return new; ++} ++ + #ifndef __HAVE_ARCH_STRSPN + /** + * strspn - Calculate the length of the initial substring of @s which only + +From patchwork Mon Apr 15 09:32:15 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, v5, + 03/27] ARM: tegra: Fix mux type for disp1 and disp2 clocks on Tegra210 +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085517 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-4-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:15 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +On Tegra210 the parents for the disp1 and disp2 clocks are slightly +different from earlier chips. Only pll_p, pll_d_out0, pll_d2_out0 and +clk_m are valid parents (technically pll_d_out is as well, but U-Boot +doesn't know anything about it). Fix up the type name and the mux +definition. + +Signed-off-by: Thierry Reding +--- + arch/arm/mach-tegra/tegra210/clock.c | 10 +++++----- + 1 file changed, 5 insertions(+), 5 deletions(-) + +diff --git a/arch/arm/mach-tegra/tegra210/clock.c b/arch/arm/mach-tegra/tegra210/clock.c +index 06068c4b7b8d..0d7cafea2017 100644 +--- a/arch/arm/mach-tegra/tegra210/clock.c ++++ b/arch/arm/mach-tegra/tegra210/clock.c +@@ -40,7 +40,7 @@ enum clock_type_id { + CLOCK_TYPE_PDCT, + CLOCK_TYPE_ACPT, + CLOCK_TYPE_ASPTE, +- CLOCK_TYPE_PMDACD2T, ++ CLOCK_TYPE_PDD2T, + CLOCK_TYPE_PCST, + CLOCK_TYPE_DP, + +@@ -97,8 +97,8 @@ static enum clock_id clock_source[CLOCK_TYPE_COUNT][CLOCK_MAX_MUX+1] = { + { CLK(AUDIO), CLK(SFROM32KHZ), CLK(PERIPH), CLK(OSC), + CLK(EPCI), CLK(NONE), CLK(NONE), CLK(NONE), + MASK_BITS_31_29}, +- { CLK(PERIPH), CLK(MEMORY), CLK(DISPLAY), CLK(AUDIO), +- CLK(CGENERAL), CLK(DISPLAY2), CLK(OSC), CLK(NONE), ++ { CLK(PERIPH), CLK(NONE), CLK(DISPLAY), CLK(NONE), ++ CLK(NONE), CLK(DISPLAY2), CLK(OSC), CLK(NONE), + MASK_BITS_31_29}, + { CLK(PERIPH), CLK(CGENERAL), CLK(SFROM32KHZ), CLK(OSC), + CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE), +@@ -174,8 +174,8 @@ static enum clock_type_id clock_periph_type[PERIPHC_COUNT] = { + TYPE(PERIPHC_0bh, CLOCK_TYPE_NONE), + TYPE(PERIPHC_0ch, CLOCK_TYPE_NONE), + TYPE(PERIPHC_SBC1, CLOCK_TYPE_PC2CC3M_T), +- TYPE(PERIPHC_DISP1, CLOCK_TYPE_PMDACD2T), +- TYPE(PERIPHC_DISP2, CLOCK_TYPE_PMDACD2T), ++ TYPE(PERIPHC_DISP1, CLOCK_TYPE_PDD2T), ++ TYPE(PERIPHC_DISP2, CLOCK_TYPE_PDD2T), + + /* 0x10 */ + TYPE(PERIPHC_10h, CLOCK_TYPE_NONE), + +From patchwork Mon Apr 15 09:32:16 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, v5, + 04/27] ARM: tegra: Remove disp1 clock initialization on Tegra210 +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085526 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-5-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:16 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +pll_c is not a valid parent for the disp1 clock, so trying to set it +will fail. Given that display is not used in U-Boot, remove the init +table entry so that disp1 will keep its default parent (clk_m). + +Signed-off-by: Thierry Reding +--- + arch/arm/mach-tegra/tegra210/clock.c | 1 - + 1 file changed, 1 deletion(-) + +diff --git a/arch/arm/mach-tegra/tegra210/clock.c b/arch/arm/mach-tegra/tegra210/clock.c +index 0d7cafea2017..b240860f08cf 100644 +--- a/arch/arm/mach-tegra/tegra210/clock.c ++++ b/arch/arm/mach-tegra/tegra210/clock.c +@@ -1265,7 +1265,6 @@ struct periph_clk_init periph_clk_init_table[] = { + { PERIPH_ID_SBC5, CLOCK_ID_PERIPH }, + { PERIPH_ID_SBC6, CLOCK_ID_PERIPH }, + { PERIPH_ID_HOST1X, CLOCK_ID_PERIPH }, +- { PERIPH_ID_DISP1, CLOCK_ID_CGENERAL }, + { PERIPH_ID_SDMMC1, CLOCK_ID_PERIPH }, + { PERIPH_ID_SDMMC2, CLOCK_ID_PERIPH }, + { PERIPH_ID_SDMMC3, CLOCK_ID_PERIPH }, + +From patchwork Mon Apr 15 09:32:17 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot,v5,05/27] ARM: tegra: Use common header for PMU declarations +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085523 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-6-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:17 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -167,19 +454,19 @@ index 6697909d9a3e..66628933b653 100644 DECLARE_GLOBAL_DATA_PTR; -From patchwork Thu Apr 4 11:59:25 2019 +From patchwork Mon Apr 15 09:32:18 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,02/19] ARM: tegra: Guard clock code with a Kconfig symbol +Subject: [U-Boot,v5,06/27] ARM: tegra: Guard clock code with a Kconfig symbol X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077185 +X-Patchwork-Id: 1085522 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-3-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:25 +0200 +Message-Id: <20190415093239.27509-7-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:18 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -309,20 +596,20 @@ index b8d5ef0322cb..b94077221f77 100644 pinmux_init(); board_init_uart_f(); -From patchwork Thu Apr 4 11:59:26 2019 +From patchwork Mon Apr 15 09:32:19 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 03/19] ARM: tegra: Guard GP pad control code with a Kconfig symbol +Subject: [U-Boot, v5, + 07/27] ARM: tegra: Guard GP pad control code with a Kconfig symbol X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077187 +X-Patchwork-Id: 1085520 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-4-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:26 +0200 +Message-Id: <20190415093239.27509-8-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:19 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -400,20 +687,20 @@ index be414e4e4aca..d7063490e222 100644 #ifndef CONFIG_ARM64 void config_cache(void) -From patchwork Thu Apr 4 11:59:27 2019 +From patchwork Mon Apr 15 09:32:20 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 04/19] ARM: tegra: Guard memory controller code with a Kconfig symbol +Subject: [U-Boot, v5, + 08/27] ARM: tegra: Guard memory controller code with a Kconfig symbol X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077188 +X-Patchwork-Id: 1085531 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-5-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:27 +0200 +Message-Id: <20190415093239.27509-9-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:20 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -501,20 +788,20 @@ index ecd5001de4c5..7ef5a67edd1f 100644 } -From patchwork Thu Apr 4 11:59:28 2019 +From patchwork Mon Apr 15 09:32:21 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 05/19] ARM: tegra: Guard pin controller code with a Kconfig symbol +Subject: [U-Boot, v5, + 09/27] ARM: tegra: Guard pin controller code with a Kconfig symbol X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077207 +X-Patchwork-Id: 1085527 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-6-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:28 +0200 +Message-Id: <20190415093239.27509-10-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:21 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -636,20 +923,20 @@ index b94077221f77..ce1c9346959d 100644 #ifdef CONFIG_TEGRA_CLOCK_SCALING #include -From patchwork Thu Apr 4 11:59:29 2019 +From patchwork Mon Apr 15 09:32:22 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 06/19] ARM: tegra: Guard powergate code with a Kconfig symbol +Subject: [U-Boot, v5, + 10/27] ARM: tegra: Guard powergate code with a Kconfig symbol X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077193 +X-Patchwork-Id: 1085529 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-7-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:29 +0200 +Message-Id: <20190415093239.27509-11-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:22 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -712,19 +999,19 @@ index 395e0191a458..517be21ee5f5 100644 endif -From patchwork Thu Apr 4 11:59:30 2019 +From patchwork Mon Apr 15 09:32:23 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,07/19] ARM: tegra: Fix save_boot_params() prototype +Subject: [U-Boot,v5,11/27] ARM: tegra: Fix save_boot_params() prototype X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077195 +X-Patchwork-Id: 1085528 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-8-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:30 +0200 +Message-Id: <20190415093239.27509-12-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:23 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -758,20 +1045,20 @@ index b65bdde5a78d..59d2f347485d 100644 from_spl = r0 != UBOOT_NOT_LOADED_FROM_SPL; save_boot_params_ret(); -From patchwork Thu Apr 4 11:59:31 2019 +From patchwork Mon Apr 15 09:32:24 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 08/19] ARM: tegra: Allow boards to override boot target devices +Subject: [U-Boot, v5, + 12/27] ARM: tegra: Allow boards to override boot target devices X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077192 +X-Patchwork-Id: 1085524 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-9-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:31 +0200 +Message-Id: <20190415093239.27509-13-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:24 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -806,19 +1093,19 @@ index e54428ba43e2..9685ee5059ab 100644 #else #define BOOTENV -From patchwork Thu Apr 4 11:59:32 2019 +From patchwork Mon Apr 15 09:32:25 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,09/19] ARM: tegra: Support TZ-only access to PMC +Subject: [U-Boot,v5,13/27] ARM: tegra: Support TZ-only access to PMC X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077197 +X-Patchwork-Id: 1085544 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-10-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:32 +0200 +Message-Id: <20190415093239.27509-14-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:25 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -1266,20 +1553,20 @@ index e45f0961b242..761c9ef19e3b 100644 return 0; } -From patchwork Thu Apr 4 11:59:33 2019 +From patchwork Mon Apr 15 09:32:26 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 10/19] ARM: tegra: Workaround UDC boot issues only if necessary +Subject: [U-Boot, v5, + 14/27] ARM: tegra: Workaround UDC boot issues only if necessary X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077191 +X-Patchwork-Id: 1085541 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-11-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:33 +0200 +Message-Id: <20190415093239.27509-15-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:26 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -1310,19 +1597,19 @@ index 28914a34a1b5..faa73559fd42 100644 help When loading U-Boot into RAM over USB protocols using tools such as -From patchwork Thu Apr 4 11:59:34 2019 +From patchwork Mon Apr 15 09:32:27 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,11/19] ARM: tegra: Restore DRAM bank count +Subject: [U-Boot,v5,15/27] ARM: tegra: Restore DRAM bank count X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077194 +X-Patchwork-Id: 1085532 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-12-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:34 +0200 +Message-Id: <20190415093239.27509-16-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:27 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -1373,19 +1660,19 @@ index df4d914d85cf..459b67fd195f 100644 CONFIG_CONSOLE_MUX=y CONFIG_SYS_STDIO_DEREGISTER=y -From patchwork Thu Apr 4 11:59:35 2019 +From patchwork Mon Apr 15 09:32:28 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,12/19] ARM: tegra: Unify Tegra186 builds +Subject: [U-Boot,v5,16/27] ARM: tegra: Unify Tegra186 builds X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077204 +X-Patchwork-Id: 1085533 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-13-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:35 +0200 +Message-Id: <20190415093239.27509-17-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:28 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -2198,20 +2485,20 @@ index 496e8a02111e..6f88010c18c3 100644 } +#endif -From patchwork Thu Apr 4 11:59:36 2019 +From patchwork Mon Apr 15 09:32:29 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 13/19] ARM: tegra: Implement cboot_save_boot_params() in C +Subject: [U-Boot, v5, + 17/27] ARM: tegra: Implement cboot_save_boot_params() in C X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077211 +X-Patchwork-Id: 1085530 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-14-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:36 +0200 +Message-Id: <20190415093239.27509-18-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:29 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -2291,27 +2578,27 @@ index 4c9ddacc2b39..000000000000 - b save_boot_params_ret -ENDPROC(cboot_save_boot_params) -From patchwork Thu Apr 4 11:59:37 2019 +From patchwork Mon Apr 15 09:32:30 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,14/19] ARM: tegra: Implement cboot_get_ethaddr() +Subject: [U-Boot,v5,18/27] ARM: tegra: Implement cboot_get_ethaddr() X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077213 +X-Patchwork-Id: 1085543 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-15-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:37 +0200 +Message-Id: <20190415093239.27509-19-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:30 +0200 From: Thierry Reding List-Id: U-Boot discussion From: Thierry Reding -This function will attempt to look up an ethernet address in the DTB +This function will attempt to look up an Ethernet address in the DTB that was passed in from cboot. It does so by first trying to locate the -primary ethernet device for the board (identified by the "ethernet" +default Ethernet device for the board (identified by the "ethernet" alias) and if found, reads the "local-mac-address" property. If the "ethernet" alias does not exist, or if it points to a device tree node that doesn't exist, or if the device tree node that it points to does @@ -2320,8 +2607,16 @@ will fall back to the legacy mechanism of looking for the MAC address stored in the "nvidia,ethernet-mac" or "nvidia,ether-mac" properties of the "/chosen" node. +The MAC address is then written to the default Ethernet device for the +board (again identified by the "ethernet" alias) in U-Boot's control +DTB. This allows the device driver for that device to read the MAC +address from the standard location in device tree. + Signed-off-by: Thierry Reding --- +Changes in v5: +- write MAC to DT rather than an environment variable + Changes in v4: - also check the /chosen/nvidia,ethernet-mac property for compatibility with Tegra210 @@ -2330,8 +2625,8 @@ Changes in v2: - make dummy static inline to avoid duplicate definitions arch/arm/include/asm/arch-tegra/cboot.h | 6 ++ - arch/arm/mach-tegra/cboot.c | 92 ++++++++++++++++++++----- - 2 files changed, 81 insertions(+), 17 deletions(-) + arch/arm/mach-tegra/cboot.c | 97 ++++++++++++++++++++----- + 2 files changed, 86 insertions(+), 17 deletions(-) diff --git a/arch/arm/include/asm/arch-tegra/cboot.h b/arch/arm/include/asm/arch-tegra/cboot.h index b3441ec178b3..021c24617575 100644 @@ -2358,7 +2653,7 @@ index b3441ec178b3..021c24617575 100644 #endif diff --git a/arch/arm/mach-tegra/cboot.c b/arch/arm/mach-tegra/cboot.c -index a302ca45f39b..6c6d06d89a5d 100644 +index a302ca45f39b..628909f29137 100644 --- a/arch/arm/mach-tegra/cboot.c +++ b/arch/arm/mach-tegra/cboot.c @@ -4,6 +4,7 @@ @@ -2369,7 +2664,7 @@ index a302ca45f39b..6c6d06d89a5d 100644 #include #include #include -@@ -465,46 +466,103 @@ static int set_fdt_addr(void) +@@ -465,46 +466,108 @@ static int set_fdt_addr(void) * Attempt to use /chosen/nvidia,ether-mac in the cboot DTB to U-Boot's * ethaddr environment variable if possible. */ @@ -2485,26 +2780,134 @@ index a302ca45f39b..6c6d06d89a5d 100644 /* Ignore errors here; not all cases care about Ethernet addresses */ - set_ethaddr_from_cboot(); + err = cboot_get_ethaddr(fdt, mac); -+ if (!err) -+ eth_env_set_enetaddr("ethaddr", mac); ++ if (!err) { ++ void *blob = (void *)gd->fdt_blob; ++ ++ err = fdtdec_set_ethernet_mac_address(blob, mac, sizeof(mac)); ++ if (err < 0) ++ printf("failed to set MAC address %pM: %d\n", mac, err); ++ } return 0; } -From patchwork Thu Apr 4 11:59:38 2019 +From patchwork Mon Apr 15 09:32:31 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, v4, - 15/19] ARM: tegra: Enable position independent build for 64-bit +Subject: [U-Boot,v5,19/27] ARM: tegra: Import cbootargs value from cboot DTB X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077212 +X-Patchwork-Id: 1085534 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-16-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:38 +0200 +Message-Id: <20190415093239.27509-20-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:31 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +Read the boot arguments passed by cboot via the /chosen/bootargs +property and store it in the cbootargs environment variable. + +Signed-off-by: Thierry Reding +--- + arch/arm/mach-tegra/cboot.c | 47 +++++++++++++++++++++++++++++++++++++ + 1 file changed, 47 insertions(+) + +diff --git a/arch/arm/mach-tegra/cboot.c b/arch/arm/mach-tegra/cboot.c +index 628909f29137..a829ef794f2d 100644 +--- a/arch/arm/mach-tegra/cboot.c ++++ b/arch/arm/mach-tegra/cboot.c +@@ -8,7 +8,9 @@ + #include + #include + #include ++#include + ++#include + #include + + #include +@@ -546,10 +548,49 @@ out: + return err; + } + ++static char *strip(const char *ptr) ++{ ++ const char *end; ++ ++ while (*ptr && isblank(*ptr)) ++ ptr++; ++ ++ /* empty string */ ++ if (*ptr == '\0') ++ return strdup(ptr); ++ ++ end = ptr; ++ ++ while (end[1]) ++ end++; ++ ++ while (isblank(*end)) ++ end--; ++ ++ return strndup(ptr, end - ptr + 1); ++} ++ ++static char *cboot_get_bootargs(const void *fdt) ++{ ++ const char *args; ++ int offset, len; ++ ++ offset = fdt_path_offset(fdt, "/chosen"); ++ if (offset < 0) ++ return NULL; ++ ++ args = fdt_getprop(fdt, offset, "bootargs", &len); ++ if (!args) ++ return NULL; ++ ++ return strip(args); ++} ++ + int cboot_late_init(void) + { + const void *fdt = (const void *)cboot_boot_x0; + uint8_t mac[ETH_ALEN]; ++ char *bootargs; + int err; + + set_calculated_env_vars(); +@@ -569,5 +610,11 @@ int cboot_late_init(void) + printf("failed to set MAC address %pM: %d\n", mac, err); + } + ++ bootargs = cboot_get_bootargs(fdt); ++ if (bootargs) { ++ env_set("cbootargs", bootargs); ++ free(bootargs); ++ } ++ + return 0; + } + +From patchwork Mon Apr 15 09:32:32 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, v5, + 20/27] ARM: tegra: Enable position independent build for 64-bit +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085539 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-21-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:32 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -2587,19 +2990,19 @@ index e48e0a1a14ec..8e9c45690dce 100644 CONFIG_TARGET_P2571=y CONFIG_NR_DRAM_BANKS=2 -From patchwork Thu Apr 4 11:59:39 2019 +From patchwork Mon Apr 15 09:32:33 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,16/19] p2371-2180: Pass Ethernet MAC to the kernel +Subject: [U-Boot,v5,21/27] p2371-2180: Pass Ethernet MAC to the kernel X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077196 +X-Patchwork-Id: 1085536 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-17-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:39 +0200 +Message-Id: <20190415093239.27509-22-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:33 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -2698,19 +3101,19 @@ index 4923d330de6c..0ee4913a0469 100644 CONFIG_SYS_STDIO_DEREGISTER=y CONFIG_SYS_PROMPT="Tegra210 (P2371-2180) # " -From patchwork Thu Apr 4 11:59:40 2019 +From patchwork Mon Apr 15 09:32:34 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,17/19] p2771-0000: Pass Ethernet MAC to the kernel +Subject: [U-Boot,v5,22/27] p2771-0000: Pass Ethernet MAC to the kernel X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077208 +X-Patchwork-Id: 1085542 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-18-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:40 +0200 +Message-Id: <20190415093239.27509-23-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:34 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -2813,176 +3216,1410 @@ index 459b67fd195f..20d4393838d6 100644 CONFIG_SYS_STDIO_DEREGISTER=y CONFIG_SYS_PROMPT="Tegra186 (P2771-0000-500) # " -From patchwork Thu Apr 4 11:59:41 2019 +From patchwork Mon Apr 15 09:32:35 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,18/19] lib: Implement strndup() +Subject: [U-Boot,v5,23/27] p2371-2180: Add support for framebuffer carveouts X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077221 +X-Patchwork-Id: 1085537 X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-19-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:41 +0200 +Message-Id: <20190415093239.27509-24-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:35 +0200 From: Thierry Reding List-Id: U-Boot discussion From: Thierry Reding +If early firmware initialized the display hardware and the display +controllers are scanning out a framebuffer (e.g. a splash screen), make +sure to pass information about the memory location of that framebuffer +to the kernel before booting to avoid the kernel from using that memory +for the buddy allocator. + +This same mechanism can also be used in the kernel to set up early SMMU +mappings and avoid SMMU faults caused by the display controller reading +from memory for which it has no mapping. + +Reviewed-by: Simon Glass Signed-off-by: Thierry Reding --- - include/linux/string.h | 1 + - lib/string.c | 23 +++++++++++++++++++++++ - 2 files changed, 24 insertions(+) +Changes in v4: +- add reviewed-by from Simon -diff --git a/include/linux/string.h b/include/linux/string.h -index 36066207392e..5d63be4ce5b0 100644 ---- a/include/linux/string.h -+++ b/include/linux/string.h -@@ -94,6 +94,7 @@ size_t strcspn(const char *s, const char *reject); - #ifndef __HAVE_ARCH_STRDUP - extern char * strdup(const char *); - #endif -+extern char * strndup(const char *, size_t); - #ifndef __HAVE_ARCH_STRSWAB - extern char * strswab(const char *); - #endif -diff --git a/lib/string.c b/lib/string.c -index af17c16f616d..9b779ddc3bbe 100644 ---- a/lib/string.c -+++ b/lib/string.c -@@ -326,6 +326,29 @@ char * strdup(const char *s) - } - #endif - -+char * strndup(const char *s, size_t n) -+{ -+ size_t len; -+ char *new; -+ -+ if (s == NULL) -+ return NULL; -+ -+ len = strlen(s); -+ -+ if (n < len) -+ len = n; -+ -+ new = malloc(len + 1); -+ if (new == NULL) -+ return NULL; -+ -+ strncpy(new, s, len); -+ new[len] = '\0'; -+ -+ return new; -+} -+ - #ifndef __HAVE_ARCH_STRSPN - /** - * strspn - Calculate the length of the initial substring of @s which only - -From patchwork Thu Apr 4 11:59:42 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,v4,19/19] ARM: tegra: Import cbootargs value from cboot DTB -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1077205 -X-Patchwork-Delegate: twarren@nvidia.com -Message-Id: <20190404115942.17947-20-thierry.reding@gmail.com> -To: Tom Warren -Cc: u-boot@lists.denx.de, Stephen Warren , - Jonathan Hunter -Date: Thu, 4 Apr 2019 13:59:42 +0200 -From: Thierry Reding -List-Id: U-Boot discussion - -From: Thierry Reding - -Read the boot arguments passed by cboot via the /chosen/bootargs -property and store it in the cbootargs environment variable. - -Signed-off-by: Thierry Reding ---- - arch/arm/mach-tegra/cboot.c | 47 +++++++++++++++++++++++++++++++++++++ + board/nvidia/p2371-2180/p2371-2180.c | 47 ++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) -diff --git a/arch/arm/mach-tegra/cboot.c b/arch/arm/mach-tegra/cboot.c -index 6c6d06d89a5d..3f42ffeb73c0 100644 ---- a/arch/arm/mach-tegra/cboot.c -+++ b/arch/arm/mach-tegra/cboot.c -@@ -8,7 +8,9 @@ - #include - #include - #include -+#include +diff --git a/board/nvidia/p2371-2180/p2371-2180.c b/board/nvidia/p2371-2180/p2371-2180.c +index a444d692d7ea..4985302d6bc2 100644 +--- a/board/nvidia/p2371-2180/p2371-2180.c ++++ b/board/nvidia/p2371-2180/p2371-2180.c +@@ -6,6 +6,7 @@ -+#include - #include - - #include -@@ -546,10 +548,49 @@ out: - return err; + #include + #include ++#include + #include + #include + #include +@@ -138,9 +139,55 @@ static void ft_mac_address_setup(void *fdt) + } } -+static char *strip(const char *ptr) ++static int ft_copy_carveout(void *dst, const void *src, const char *node) +{ -+ const char *end; ++ struct fdt_memory fb; ++ int err; + -+ while (*ptr && isblank(*ptr)) -+ ptr++; ++ err = fdtdec_get_carveout(src, node, "memory-region", 0, &fb); ++ if (err < 0) { ++ if (err != -FDT_ERR_NOTFOUND) ++ printf("failed to get carveout for %s: %d\n", node, ++ err); + -+ /* empty string */ -+ if (*ptr == '\0') -+ return strdup(ptr); -+ -+ end = ptr; -+ -+ while (end[1]) -+ end++; -+ -+ while (isblank(*end)) -+ end--; -+ -+ return strndup(ptr, end - ptr + 1); -+} -+ -+static char *cboot_get_bootargs(const void *fdt) -+{ -+ const char *args; -+ int offset, len; -+ -+ offset = fdt_path_offset(fdt, "/chosen"); -+ if (offset < 0) -+ return NULL; -+ -+ args = fdt_getprop(fdt, offset, "bootargs", &len); -+ if (!args) -+ return NULL; -+ -+ return strip(args); -+} -+ - int cboot_late_init(void) - { - const void *fdt = (const void *)cboot_boot_x0; - uint8_t mac[ETH_ALEN]; -+ char *bootargs; - int err; - - set_calculated_env_vars(); -@@ -564,5 +605,11 @@ int cboot_late_init(void) - if (!err) - eth_env_set_enetaddr("ethaddr", mac); - -+ bootargs = cboot_get_bootargs(fdt); -+ if (bootargs) { -+ env_set("cbootargs", bootargs); -+ free(bootargs); ++ return err; + } + ++ err = fdtdec_set_carveout(dst, node, "memory-region", 0, "framebuffer", ++ &fb); ++ if (err < 0) { ++ printf("failed to set carveout for %s: %d\n", node, err); ++ return err; ++ } ++ ++ return 0; ++} ++ ++static void ft_carveout_setup(void *fdt) ++{ ++ const void *cboot_fdt = (const void *)cboot_boot_x0; ++ static const char * const nodes[] = { ++ "/host1x@50000000/dc@54200000", ++ "/host1x@50000000/dc@54240000", ++ }; ++ unsigned int i; ++ int err; ++ ++ for (i = 0; i < ARRAY_SIZE(nodes); i++) { ++ err = ft_copy_carveout(fdt, cboot_fdt, nodes[i]); ++ if (err < 0) { ++ if (err != -FDT_ERR_NOTFOUND) ++ printf("failed to copy carveout for %s: %d\n", ++ nodes[i], err); ++ continue; ++ } ++ } ++} ++ + int ft_board_setup(void *fdt, bd_t *bd) + { + ft_mac_address_setup(fdt); ++ ft_carveout_setup(fdt); + return 0; } + +From patchwork Mon Apr 15 09:32:36 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot,v5,24/27] p2771-0000: Add support for framebuffer carveouts +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085535 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-25-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:36 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +If early firmware initialized the display hardware and the display +controllers are scanning out a framebuffer (e.g. a splash screen), make +sure to pass information about the memory location of that framebuffer +to the kernel before booting to avoid the kernel from using that memory +for the buddy allocator. + +This same mechanism can also be used in the kernel to set up early SMMU +mappings and avoid SMMU faults caused by the display controller reading +from memory for which it has no mapping. + +Reviewed-by: Simon Glass +Signed-off-by: Thierry Reding +--- +Changes in v4: +- add reviewed-by from Simon + + board/nvidia/p2771-0000/p2771-0000.c | 66 ++++++++++++++++++++++++++-- + 1 file changed, 62 insertions(+), 4 deletions(-) + +diff --git a/board/nvidia/p2771-0000/p2771-0000.c b/board/nvidia/p2771-0000/p2771-0000.c +index fe22067f6571..d294c7ae0136 100644 +--- a/board/nvidia/p2771-0000/p2771-0000.c ++++ b/board/nvidia/p2771-0000/p2771-0000.c +@@ -5,6 +5,7 @@ + + #include + #include ++#include + #include + #include + #include +@@ -56,7 +57,7 @@ int tegra_pcie_board_init(void) + } + #endif + +-int ft_board_setup(void *fdt, bd_t *bd) ++static void ft_mac_address_setup(void *fdt) + { + const void *cboot_fdt = (const void *)cboot_boot_x0; + uint8_t mac[ETH_ALEN], local_mac[ETH_ALEN]; +@@ -69,13 +70,15 @@ int ft_board_setup(void *fdt, bd_t *bd) + + path = fdt_get_alias(fdt, "ethernet"); + if (!path) +- return 0; ++ return; + + debug("ethernet alias found: %s\n", path); + + offset = fdt_path_offset(fdt, path); +- if (offset < 0) +- return 0; ++ if (offset < 0) { ++ printf("ethernet alias points to absent node %s\n", path); ++ return; ++ } + + if (is_valid_ethaddr(local_mac)) { + err = fdt_setprop(fdt, offset, "local-mac-address", local_mac, +@@ -92,6 +95,61 @@ int ft_board_setup(void *fdt, bd_t *bd) + debug("MAC address set: %pM\n", mac); + } + } ++} ++ ++static int ft_copy_carveout(void *dst, const void *src, const char *node) ++{ ++ struct fdt_memory fb; ++ int err; ++ ++ err = fdtdec_get_carveout(src, node, "memory-region", 0, &fb); ++ if (err < 0) { ++ if (err != -FDT_ERR_NOTFOUND) ++ printf("failed to get carveout for %s: %d\n", node, ++ err); ++ ++ return err; ++ } ++ ++ err = fdtdec_set_carveout(dst, node, "memory-region", 0, "framebuffer", ++ &fb); ++ if (err < 0) { ++ printf("failed to set carveout for %s: %d\n", node, err); ++ return err; ++ } ++ ++ return 0; ++} ++ ++static void ft_carveout_setup(void *fdt) ++{ ++ const void *cboot_fdt = (const void *)cboot_boot_x0; ++ static const char * const nodes[] = { ++ "/host1x@13e00000/display-hub@15200000/display@15200000", ++ "/host1x@13e00000/display-hub@15200000/display@15210000", ++ "/host1x@13e00000/display-hub@15200000/display@15220000", ++ }; ++ unsigned int i; ++ int err; ++ ++ for (i = 0; i < ARRAY_SIZE(nodes); i++) { ++ printf("copying carveout for %s...\n", nodes[i]); ++ ++ err = ft_copy_carveout(fdt, cboot_fdt, nodes[i]); ++ if (err < 0) { ++ if (err != -FDT_ERR_NOTFOUND) ++ printf("failed to copy carveout for %s: %d\n", ++ nodes[i], err); ++ ++ continue; ++ } ++ } ++} ++ ++int ft_board_setup(void *fdt, bd_t *bd) ++{ ++ ft_mac_address_setup(fdt); ++ ft_carveout_setup(fdt); + + return 0; + } + +From patchwork Mon Apr 15 09:32:37 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot,v5,25/27] ARM: tegra: Rename pcie-controller to pcie +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085545 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-26-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:37 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +Recent versions of DTC have checks for PCI host bridge device tree nodes +that are named something other than "pci" or "pcie". Fix all occurrences +of such nodes for Tegra boards to avoid potential warnings from DTC. + +Signed-off-by: Thierry Reding +--- + arch/arm/dts/tegra124-apalis.dts | 2 +- + arch/arm/dts/tegra124-cei-tk1-som.dts | 2 +- + arch/arm/dts/tegra124-jetson-tk1.dts | 2 +- + arch/arm/dts/tegra124.dtsi | 2 +- + arch/arm/dts/tegra186-p2771-0000-000.dts | 2 +- + arch/arm/dts/tegra186-p2771-0000-500.dts | 2 +- + arch/arm/dts/tegra186.dtsi | 2 +- + arch/arm/dts/tegra20-harmony.dts | 2 +- + arch/arm/dts/tegra20-trimslice.dts | 2 +- + arch/arm/dts/tegra20.dtsi | 2 +- + arch/arm/dts/tegra210-p2371-2180.dts | 2 +- + arch/arm/dts/tegra210.dtsi | 2 +- + arch/arm/dts/tegra30-apalis.dts | 2 +- + arch/arm/dts/tegra30-beaver.dts | 2 +- + arch/arm/dts/tegra30-cardhu.dts | 2 +- + arch/arm/dts/tegra30.dtsi | 2 +- + 16 files changed, 16 insertions(+), 16 deletions(-) + +diff --git a/arch/arm/dts/tegra124-apalis.dts b/arch/arm/dts/tegra124-apalis.dts +index fe08d3ea7304..a962c0a2f0ae 100644 +--- a/arch/arm/dts/tegra124-apalis.dts ++++ b/arch/arm/dts/tegra124-apalis.dts +@@ -77,7 +77,7 @@ + reg = <0x0 0x80000000 0x0 0x80000000>; + }; + +- pcie-controller@01003000 { ++ pcie@1003000 { + status = "okay"; + avddio-pex-supply = <&vdd_1v05>; + avdd-pex-pll-supply = <&vdd_1v05>; +diff --git a/arch/arm/dts/tegra124-cei-tk1-som.dts b/arch/arm/dts/tegra124-cei-tk1-som.dts +index b1dd4181ac03..e5b41f3183cd 100644 +--- a/arch/arm/dts/tegra124-cei-tk1-som.dts ++++ b/arch/arm/dts/tegra124-cei-tk1-som.dts +@@ -29,7 +29,7 @@ + reg = <0x80000000 0x80000000>; + }; + +- pcie-controller@01003000 { ++ pcie@1003000 { + status = "okay"; + + avddio-pex-supply = <&vdd_1v05_run>; +diff --git a/arch/arm/dts/tegra124-jetson-tk1.dts b/arch/arm/dts/tegra124-jetson-tk1.dts +index d6420436cde8..59e080a8af6f 100644 +--- a/arch/arm/dts/tegra124-jetson-tk1.dts ++++ b/arch/arm/dts/tegra124-jetson-tk1.dts +@@ -29,7 +29,7 @@ + reg = <0x80000000 0x80000000>; + }; + +- pcie-controller@01003000 { ++ pcie@1003000 { + status = "okay"; + + avddio-pex-supply = <&vdd_1v05_run>; +diff --git a/arch/arm/dts/tegra124.dtsi b/arch/arm/dts/tegra124.dtsi +index 83d63480471b..f473ba28e4a6 100644 +--- a/arch/arm/dts/tegra124.dtsi ++++ b/arch/arm/dts/tegra124.dtsi +@@ -14,7 +14,7 @@ + interrupt-parent = <&lic>; + + +- pcie-controller@01003000 { ++ pcie@1003000 { + compatible = "nvidia,tegra124-pcie"; + device_type = "pci"; + reg = <0x01003000 0x00000800 /* PADS registers */ +diff --git a/arch/arm/dts/tegra186-p2771-0000-000.dts b/arch/arm/dts/tegra186-p2771-0000-000.dts +index d97c6fd3d09a..84e850d6fca6 100644 +--- a/arch/arm/dts/tegra186-p2771-0000-000.dts ++++ b/arch/arm/dts/tegra186-p2771-0000-000.dts +@@ -11,7 +11,7 @@ + power-gpios = <&gpio_main TEGRA_MAIN_GPIO(P, 5) GPIO_ACTIVE_HIGH>; + }; + +- pcie-controller@10003000 { ++ pcie@10003000 { + status = "okay"; + + pci@1,0 { +diff --git a/arch/arm/dts/tegra186-p2771-0000-500.dts b/arch/arm/dts/tegra186-p2771-0000-500.dts +index 393a8b246a0b..1ac8ab431e90 100644 +--- a/arch/arm/dts/tegra186-p2771-0000-500.dts ++++ b/arch/arm/dts/tegra186-p2771-0000-500.dts +@@ -11,7 +11,7 @@ + power-gpios = <&gpio_main TEGRA_MAIN_GPIO(P, 6) GPIO_ACTIVE_HIGH>; + }; + +- pcie-controller@10003000 { ++ pcie@10003000 { + status = "okay"; + + pci@1,0 { +diff --git a/arch/arm/dts/tegra186.dtsi b/arch/arm/dts/tegra186.dtsi +index dd9e3b869de7..0a9db9825b85 100644 +--- a/arch/arm/dts/tegra186.dtsi ++++ b/arch/arm/dts/tegra186.dtsi +@@ -217,7 +217,7 @@ + #interrupt-cells = <2>; + }; + +- pcie-controller@10003000 { ++ pcie@10003000 { + compatible = "nvidia,tegra186-pcie"; + device_type = "pci"; + reg = <0x0 0x10003000 0x0 0x00000800 /* PADS registers */ +diff --git a/arch/arm/dts/tegra20-harmony.dts b/arch/arm/dts/tegra20-harmony.dts +index 0c907054dbd4..7fe7d52096c4 100644 +--- a/arch/arm/dts/tegra20-harmony.dts ++++ b/arch/arm/dts/tegra20-harmony.dts +@@ -599,7 +599,7 @@ + nvidia,sys-clock-req-active-high; + }; + +- pcie-controller@80003000 { ++ pcie@80003000 { + status = "okay"; + + avdd-pex-supply = <&pci_vdd_reg>; +diff --git a/arch/arm/dts/tegra20-trimslice.dts b/arch/arm/dts/tegra20-trimslice.dts +index 31f509ab12c8..e19001ee2bdf 100644 +--- a/arch/arm/dts/tegra20-trimslice.dts ++++ b/arch/arm/dts/tegra20-trimslice.dts +@@ -30,7 +30,7 @@ + spi-max-frequency = <25000000>; + }; + +- pcie-controller@80003000 { ++ pcie@80003000 { + status = "okay"; + + avdd-pex-supply = <&pci_vdd_reg>; +diff --git a/arch/arm/dts/tegra20.dtsi b/arch/arm/dts/tegra20.dtsi +index e21ee258b378..275b3432bd88 100644 +--- a/arch/arm/dts/tegra20.dtsi ++++ b/arch/arm/dts/tegra20.dtsi +@@ -580,7 +580,7 @@ + reset-names = "fuse"; + }; + +- pcie-controller@80003000 { ++ pcie@80003000 { + compatible = "nvidia,tegra20-pcie"; + device_type = "pci"; + reg = <0x80003000 0x00000800 /* PADS registers */ +diff --git a/arch/arm/dts/tegra210-p2371-2180.dts b/arch/arm/dts/tegra210-p2371-2180.dts +index da4349bd039f..c2f497c524af 100644 +--- a/arch/arm/dts/tegra210-p2371-2180.dts ++++ b/arch/arm/dts/tegra210-p2371-2180.dts +@@ -21,7 +21,7 @@ + reg = <0x0 0x80000000 0x0 0xc0000000>; + }; + +- pcie-controller@01003000 { ++ pcie@1003000 { + status = "okay"; + + pci@1,0 { +diff --git a/arch/arm/dts/tegra210.dtsi b/arch/arm/dts/tegra210.dtsi +index 229fed04529a..3ec54b11c43f 100644 +--- a/arch/arm/dts/tegra210.dtsi ++++ b/arch/arm/dts/tegra210.dtsi +@@ -11,7 +11,7 @@ + #address-cells = <2>; + #size-cells = <2>; + +- pcie-controller@01003000 { ++ pcie@1003000 { + compatible = "nvidia,tegra210-pcie"; + device_type = "pci"; + reg = <0x0 0x01003000 0x0 0x00000800 /* PADS registers */ +diff --git a/arch/arm/dts/tegra30-apalis.dts b/arch/arm/dts/tegra30-apalis.dts +index 1a9ce2720acd..77502dfdb478 100644 +--- a/arch/arm/dts/tegra30-apalis.dts ++++ b/arch/arm/dts/tegra30-apalis.dts +@@ -32,7 +32,7 @@ + reg = <0x80000000 0x40000000>; + }; + +- pcie-controller@00003000 { ++ pcie@3000 { + status = "okay"; + avdd-pexa-supply = <&vdd2_reg>; + vdd-pexa-supply = <&vdd2_reg>; +diff --git a/arch/arm/dts/tegra30-beaver.dts b/arch/arm/dts/tegra30-beaver.dts +index f5fbbe849e26..9bb097b08136 100644 +--- a/arch/arm/dts/tegra30-beaver.dts ++++ b/arch/arm/dts/tegra30-beaver.dts +@@ -28,7 +28,7 @@ + reg = <0x80000000 0x7ff00000>; + }; + +- pcie-controller@00003000 { ++ pcie@3000 { + status = "okay"; + + avdd-pexa-supply = <&ldo1_reg>; +diff --git a/arch/arm/dts/tegra30-cardhu.dts b/arch/arm/dts/tegra30-cardhu.dts +index 5b9798c5a874..7534861e40d9 100644 +--- a/arch/arm/dts/tegra30-cardhu.dts ++++ b/arch/arm/dts/tegra30-cardhu.dts +@@ -27,7 +27,7 @@ + reg = <0x80000000 0x40000000>; + }; + +- pcie-controller@00003000 { ++ pcie@3000 { + status = "okay"; + + /* AVDD_PEXA and VDD_PEXA inputs are grounded on Cardhu. */ +diff --git a/arch/arm/dts/tegra30.dtsi b/arch/arm/dts/tegra30.dtsi +index 5030065cbdfe..f198bc0edbe8 100644 +--- a/arch/arm/dts/tegra30.dtsi ++++ b/arch/arm/dts/tegra30.dtsi +@@ -10,7 +10,7 @@ + compatible = "nvidia,tegra30"; + interrupt-parent = <&lic>; + +- pcie-controller@00003000 { ++ pcie@3000 { + compatible = "nvidia,tegra30-pcie"; + device_type = "pci"; + reg = <0x00003000 0x00000800 /* PADS registers */ + +From patchwork Mon Apr 15 09:32:38 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, v5, + 26/27] ARM: tegra: Mark built-in Ethernet as default on Jetson TX2 +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085540 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-27-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:38 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +Add an "ethernet" alias that points to the default network interface, +which is the built-in EQoS on Jetson TX2. + +Signed-off-by: Thierry Reding +--- + arch/arm/dts/tegra186-p2771-0000.dtsi | 2 ++ + 1 file changed, 2 insertions(+) + +diff --git a/arch/arm/dts/tegra186-p2771-0000.dtsi b/arch/arm/dts/tegra186-p2771-0000.dtsi +index a1319dc4936f..7cda0b41f74b 100644 +--- a/arch/arm/dts/tegra186-p2771-0000.dtsi ++++ b/arch/arm/dts/tegra186-p2771-0000.dtsi +@@ -9,6 +9,7 @@ + }; + + aliases { ++ ethernet = "/ethernet@2490000"; + mmc0 = "/sdhci@3460000"; + mmc1 = "/sdhci@3400000"; + i2c0 = "/bpmp/i2c"; +@@ -28,6 +29,7 @@ + ethernet@2490000 { + status = "okay"; + phy-reset-gpios = <&gpio_main TEGRA_MAIN_GPIO(M, 4) GPIO_ACTIVE_LOW>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; + }; + + i2c@3160000 { + +From patchwork Mon Apr 15 09:32:39 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, v5, + 27/27] ARM: tegra: Add NVIDIA Jetson Nano Developer Kit support +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1085538 +X-Patchwork-Delegate: twarren@nvidia.com +Message-Id: <20190415093239.27509-28-thierry.reding@gmail.com> +To: Tom Warren , + Simon Glass +Cc: u-boot@lists.denx.de, Jon Hunter +Date: Mon, 15 Apr 2019 11:32:39 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +The Jetson Nano Developer Kit is a Tegra X1 based development board. It +is similar to Jetson TX1 but it is not pin compatible. It features 4 GB +of LPDDR4, an SPI NOR flash for early boot firmware and an SD card slot +used for storage. + +HDMI 2.0 or DP 1.2 are available for display, four USB ports (3 USB 2.0 +and 1 USB 3.0) can be used to attach a variety of peripherals and a PCI +Ethernet controller provides onboard network connectivity. + +A 40-pin header on the board can be used to extend the capabilities and +exposed interfaces of the Jetson Nano. + +Signed-off-by: Thierry Reding +--- +Changes in v5: +- add "ethernet" alias and store an empty MAC address as placeholder + +Changes in v3: +- rename "Development Kit" to "Developer Kit" +- drop alias for non-existent eMMC interface +- import pinmux from A02 spreadsheet +- drop preboot support for now +- fixup text base + + arch/arm/dts/Makefile | 3 +- + arch/arm/dts/tegra210-p3450-0000.dts | 135 +++++++++ + arch/arm/mach-tegra/tegra210/Kconfig | 7 + + board/nvidia/p3450-0000/Kconfig | 12 + + board/nvidia/p3450-0000/MAINTAINERS | 6 + + board/nvidia/p3450-0000/Makefile | 8 + + board/nvidia/p3450-0000/p3450-0000.c | 198 +++++++++++++ + .../p3450-0000/pinmux-config-p3450-0000.h | 265 ++++++++++++++++++ + configs/p3450-0000_defconfig | 55 ++++ + include/configs/p3450-0000.h | 34 +++ + 10 files changed, 722 insertions(+), 1 deletion(-) + create mode 100644 arch/arm/dts/tegra210-p3450-0000.dts + create mode 100644 board/nvidia/p3450-0000/Kconfig + create mode 100644 board/nvidia/p3450-0000/MAINTAINERS + create mode 100644 board/nvidia/p3450-0000/Makefile + create mode 100644 board/nvidia/p3450-0000/p3450-0000.c + create mode 100644 board/nvidia/p3450-0000/pinmux-config-p3450-0000.h + create mode 100644 configs/p3450-0000_defconfig + create mode 100644 include/configs/p3450-0000.h + +diff --git a/arch/arm/dts/Makefile b/arch/arm/dts/Makefile +index 8167cdb4e856..f8d3441663c0 100644 +--- a/arch/arm/dts/Makefile ++++ b/arch/arm/dts/Makefile +@@ -127,7 +127,8 @@ dtb-$(CONFIG_TEGRA) += tegra20-harmony.dtb \ + tegra210-e2220-1170.dtb \ + tegra210-p2371-0000.dtb \ + tegra210-p2371-2180.dtb \ +- tegra210-p2571.dtb ++ tegra210-p2571.dtb \ ++ tegra210-p3450-0000.dtb + + dtb-$(CONFIG_ARCH_MVEBU) += \ + armada-3720-db.dtb \ +diff --git a/arch/arm/dts/tegra210-p3450-0000.dts b/arch/arm/dts/tegra210-p3450-0000.dts +new file mode 100644 +index 000000000000..d45ee9afc016 +--- /dev/null ++++ b/arch/arm/dts/tegra210-p3450-0000.dts +@@ -0,0 +1,135 @@ ++/dts-v1/; ++ ++#include "tegra210.dtsi" ++ ++/ { ++ model = "NVIDIA Jetson Nano Developer Kit"; ++ compatible = "nvidia,p3450-0000", "nvidia,tegra210"; ++ ++ chosen { ++ stdout-path = &uarta; ++ }; ++ ++ aliases { ++ ethernet = "/pcie@1003000/pci@2,0/ethernet@0,0"; ++ i2c0 = "/i2c@7000d000"; ++ i2c2 = "/i2c@7000c400"; ++ i2c3 = "/i2c@7000c500"; ++ i2c4 = "/i2c@7000c700"; ++ sdhci0 = "/sdhci@700b0000"; ++ spi0 = "/spi@70410000"; ++ usb0 = "/usb@7d000000"; ++ }; ++ ++ memory { ++ reg = <0x0 0x80000000 0x0 0xc0000000>; ++ }; ++ ++ pcie@1003000 { ++ status = "okay"; ++ ++ pci@1,0 { ++ status = "okay"; ++ }; ++ ++ pci@2,0 { ++ status = "okay"; ++ ++ ethernet@0,0 { ++ reg = <0x000000 0 0 0 0>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ }; ++ }; ++ }; ++ ++ serial@70006000 { ++ status = "okay"; ++ }; ++ ++ padctl@7009f000 { ++ pinctrl-0 = <&padctl_default>; ++ pinctrl-names = "default"; ++ ++ padctl_default: pinmux { ++ xusb { ++ nvidia,lanes = "otg-1", "otg-2"; ++ nvidia,function = "xusb"; ++ nvidia,iddq = <0>; ++ }; ++ ++ usb3 { ++ nvidia,lanes = "pcie-5", "pcie-6"; ++ nvidia,function = "usb3"; ++ nvidia,iddq = <0>; ++ }; ++ ++ pcie-x1 { ++ nvidia,lanes = "pcie-0"; ++ nvidia,function = "pcie-x1"; ++ nvidia,iddq = <0>; ++ }; ++ ++ pcie-x4 { ++ nvidia,lanes = "pcie-1", "pcie-2", ++ "pcie-3", "pcie-4"; ++ nvidia,function = "pcie-x4"; ++ nvidia,iddq = <0>; ++ }; ++ ++ sata { ++ nvidia,lanes = "sata-0"; ++ nvidia,function = "sata"; ++ nvidia,iddq = <0>; ++ }; ++ }; ++ }; ++ ++ sdhci@700b0000 { ++ status = "okay"; ++ cd-gpios = <&gpio TEGRA_GPIO(Z, 1) GPIO_ACTIVE_LOW>; ++ power-gpios = <&gpio TEGRA_GPIO(Z, 3) GPIO_ACTIVE_HIGH>; ++ bus-width = <4>; ++ }; ++ ++ i2c@7000c400 { ++ status = "okay"; ++ clock-frequency = <400000>; ++ }; ++ ++ i2c@7000c500 { ++ status = "okay"; ++ clock-frequency = <400000>; ++ }; ++ ++ i2c@7000c700 { ++ status = "okay"; ++ clock-frequency = <400000>; ++ }; ++ ++ i2c@7000d000 { ++ status = "okay"; ++ clock-frequency = <400000>; ++ }; ++ ++ spi@70410000 { ++ status = "okay"; ++ }; ++ ++ usb@7d000000 { ++ status = "okay"; ++ dr_mode = "peripheral"; ++ }; ++ ++ clocks { ++ compatible = "simple-bus"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ clk32k_in: clock@0 { ++ compatible = "fixed-clock"; ++ reg = <0>; ++ #clock-cells = <0>; ++ clock-frequency = <32768>; ++ }; ++ }; ++}; +diff --git a/arch/arm/mach-tegra/tegra210/Kconfig b/arch/arm/mach-tegra/tegra210/Kconfig +index 250738aed312..ea28392c0f3a 100644 +--- a/arch/arm/mach-tegra/tegra210/Kconfig ++++ b/arch/arm/mach-tegra/tegra210/Kconfig +@@ -35,6 +35,12 @@ config TARGET_P2571 + help + P2571 is a P2530 married to a P1963 I/O board + ++config TARGET_P3450_0000 ++ bool "NVIDIA Jetson Nano Developer Kit" ++ select BOARD_LATE_INIT ++ help ++ P3450-0000 is a P3448 CPU board married to a P3449 I/O board. ++ + endchoice + + config SYS_SOC +@@ -47,5 +53,6 @@ source "board/nvidia/e2220-1170/Kconfig" + source "board/nvidia/p2371-0000/Kconfig" + source "board/nvidia/p2371-2180/Kconfig" + source "board/nvidia/p2571/Kconfig" ++source "board/nvidia/p3450-0000/Kconfig" + + endif +diff --git a/board/nvidia/p3450-0000/Kconfig b/board/nvidia/p3450-0000/Kconfig +new file mode 100644 +index 000000000000..7a08cd88675f +--- /dev/null ++++ b/board/nvidia/p3450-0000/Kconfig +@@ -0,0 +1,12 @@ ++if TARGET_P3450_0000 ++ ++config SYS_BOARD ++ default "p3450-0000" ++ ++config SYS_VENDOR ++ default "nvidia" ++ ++config SYS_CONFIG_NAME ++ default "p3450-0000" ++ ++endif +diff --git a/board/nvidia/p3450-0000/MAINTAINERS b/board/nvidia/p3450-0000/MAINTAINERS +new file mode 100644 +index 000000000000..40700066bf39 +--- /dev/null ++++ b/board/nvidia/p3450-0000/MAINTAINERS +@@ -0,0 +1,6 @@ ++P3450-0000 BOARD ++M: Tom Warren ++S: Maintained ++F: board/nvidia/p3450-0000/ ++F: include/configs/p3450-0000.h ++F: configs/p3450-0000_defconfig +diff --git a/board/nvidia/p3450-0000/Makefile b/board/nvidia/p3450-0000/Makefile +new file mode 100644 +index 000000000000..993c506d8200 +--- /dev/null ++++ b/board/nvidia/p3450-0000/Makefile +@@ -0,0 +1,8 @@ ++# ++# (C) Copyright 2018 ++# NVIDIA Corporation ++# ++# SPDX-License-Identifier: GPL-2.0+ ++# ++ ++obj-y += p3450-0000.o +diff --git a/board/nvidia/p3450-0000/p3450-0000.c b/board/nvidia/p3450-0000/p3450-0000.c +new file mode 100644 +index 000000000000..432179e92605 +--- /dev/null ++++ b/board/nvidia/p3450-0000/p3450-0000.c +@@ -0,0 +1,198 @@ ++/* ++ * (C) Copyright 2018 ++ * NVIDIA Corporation ++ * ++ * SPDX-License-Identifier: GPL-2.0+ ++ */ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include "../p2571/max77620_init.h" ++#include "pinmux-config-p3450-0000.h" ++ ++void pin_mux_mmc(void) ++{ ++ struct udevice *dev; ++ uchar val; ++ int ret; ++ ++ /* Turn on MAX77620 LDO2 to 3.3V for SD card power */ ++ debug("%s: Set LDO2 for VDDIO_SDMMC_AP power to 3.3V\n", __func__); ++ ret = i2c_get_chip_for_busnum(0, MAX77620_I2C_ADDR_7BIT, 1, &dev); ++ if (ret) { ++ printf("%s: Cannot find MAX77620 I2C chip\n", __func__); ++ return; ++ } ++ /* 0xF2 for 3.3v, enabled: bit7:6 = 11 = enable, bit5:0 = voltage */ ++ val = 0xF2; ++ ret = dm_i2c_write(dev, MAX77620_CNFG1_L2_REG, &val, 1); ++ if (ret) ++ printf("i2c_write 0 0x3c 0x27 failed: %d\n", ret); ++ ++ /* Disable LDO4 discharge */ ++ ret = dm_i2c_read(dev, MAX77620_CNFG2_L4_REG, &val, 1); ++ if (ret) { ++ printf("i2c_read 0 0x3c 0x2c failed: %d\n", ret); ++ } else { ++ val &= ~BIT(1); /* ADE */ ++ ret = dm_i2c_write(dev, MAX77620_CNFG2_L4_REG, &val, 1); ++ if (ret) ++ printf("i2c_write 0 0x3c 0x2c failed: %d\n", ret); ++ } ++ ++ /* Set MBLPD */ ++ ret = dm_i2c_read(dev, MAX77620_CNFGGLBL1_REG, &val, 1); ++ if (ret) { ++ printf("i2c_write 0 0x3c 0x00 failed: %d\n", ret); ++ } else { ++ val |= BIT(6); /* MBLPD */ ++ ret = dm_i2c_write(dev, MAX77620_CNFGGLBL1_REG, &val, 1); ++ if (ret) ++ printf("i2c_write 0 0x3c 0x00 failed: %d\n", ret); ++ } ++} ++ ++/* ++ * Routine: pinmux_init ++ * Description: Do individual peripheral pinmux configs ++ */ ++void pinmux_init(void) ++{ ++ pinmux_clear_tristate_input_clamping(); ++ ++ gpio_config_table(p3450_0000_gpio_inits, ++ ARRAY_SIZE(p3450_0000_gpio_inits)); ++ ++ pinmux_config_pingrp_table(p3450_0000_pingrps, ++ ARRAY_SIZE(p3450_0000_pingrps)); ++ ++ pinmux_config_drvgrp_table(p3450_0000_drvgrps, ++ ARRAY_SIZE(p3450_0000_drvgrps)); ++} ++ ++#ifdef CONFIG_PCI_TEGRA ++int tegra_pcie_board_init(void) ++{ ++ struct udevice *dev; ++ uchar val; ++ int ret; ++ ++ /* Turn on MAX77620 LDO1 to 1.05V for PEX power */ ++ debug("%s: Set LDO1 for PEX power to 1.05V\n", __func__); ++ ret = i2c_get_chip_for_busnum(0, MAX77620_I2C_ADDR_7BIT, 1, &dev); ++ if (ret) { ++ printf("%s: Cannot find MAX77620 I2C chip\n", __func__); ++ return -1; ++ } ++ /* 0xCA for 1.05v, enabled: bit7:6 = 11 = enable, bit5:0 = voltage */ ++ val = 0xCA; ++ ret = dm_i2c_write(dev, MAX77620_CNFG1_L1_REG, &val, 1); ++ if (ret) ++ printf("i2c_write 0 0x3c 0x25 failed: %d\n", ret); ++ ++ return 0; ++} ++#endif /* PCI */ ++ ++static void ft_mac_address_setup(void *fdt) ++{ ++ const void *cboot_fdt = (const void *)cboot_boot_x0; ++ uint8_t mac[ETH_ALEN], local_mac[ETH_ALEN]; ++ const char *path; ++ int offset, err; ++ ++ err = cboot_get_ethaddr(cboot_fdt, local_mac); ++ if (err < 0) ++ memset(local_mac, 0, ETH_ALEN); ++ ++ path = fdt_get_alias(fdt, "ethernet"); ++ if (!path) ++ return; ++ ++ debug("ethernet alias found: %s\n", path); ++ ++ offset = fdt_path_offset(fdt, path); ++ if (offset < 0) { ++ printf("ethernet alias points to absent node %s\n", path); ++ return; ++ } ++ ++ if (is_valid_ethaddr(local_mac)) { ++ err = fdt_setprop(fdt, offset, "local-mac-address", local_mac, ++ ETH_ALEN); ++ if (!err) ++ debug("Local MAC address set: %pM\n", local_mac); ++ } ++ ++ if (eth_env_get_enetaddr("ethaddr", mac)) { ++ if (memcmp(local_mac, mac, ETH_ALEN) != 0) { ++ err = fdt_setprop(fdt, offset, "mac-address", mac, ++ ETH_ALEN); ++ if (!err) ++ debug("MAC address set: %pM\n", mac); ++ } ++ } ++} ++ ++static int ft_copy_carveout(void *dst, const void *src, const char *node) ++{ ++ struct fdt_memory fb; ++ int err; ++ ++ err = fdtdec_get_carveout(src, node, "memory-region", 0, &fb); ++ if (err < 0) { ++ if (err != -FDT_ERR_NOTFOUND) ++ printf("failed to get carveout for %s: %d\n", node, ++ err); ++ ++ return err; ++ } ++ ++ err = fdtdec_set_carveout(dst, node, "memory-region", 0, "framebuffer", ++ &fb); ++ if (err < 0) { ++ printf("failed to set carveout for %s: %d\n", node, err); ++ return err; ++ } ++ ++ return 0; ++} ++ ++static void ft_carveout_setup(void *fdt) ++{ ++ const void *cboot_fdt = (const void *)cboot_boot_x0; ++ static const char * const nodes[] = { ++ "/host1x@50000000/dc@54200000", ++ "/host1x@50000000/dc@54240000", ++ }; ++ unsigned int i; ++ int err; ++ ++ for (i = 0; i < ARRAY_SIZE(nodes); i++) { ++ printf("copying carveout for %s...\n", nodes[i]); ++ ++ err = ft_copy_carveout(fdt, cboot_fdt, nodes[i]); ++ if (err < 0) { ++ if (err != -FDT_ERR_NOTFOUND) ++ printf("failed to copy carveout for %s: %d\n", ++ nodes[i], err); ++ ++ continue; ++ } ++ } ++} ++ ++int ft_board_setup(void *fdt, bd_t *bd) ++{ ++ ft_mac_address_setup(fdt); ++ ft_carveout_setup(fdt); ++ ++ return 0; ++} +diff --git a/board/nvidia/p3450-0000/pinmux-config-p3450-0000.h b/board/nvidia/p3450-0000/pinmux-config-p3450-0000.h +new file mode 100644 +index 000000000000..722da4973542 +--- /dev/null ++++ b/board/nvidia/p3450-0000/pinmux-config-p3450-0000.h +@@ -0,0 +1,265 @@ ++/* ++ * Copyright (c) 2019, NVIDIA CORPORATION. All rights reserved. ++ * ++ * SPDX-License-Identifier: GPL-2.0+ ++ */ ++ ++/* ++ * THIS FILE IS AUTO-GENERATED - DO NOT EDIT! ++ * ++ * To generate this file, use the tegra-pinmux-scripts tool available from ++ * https://github.com/NVIDIA/tegra-pinmux-scripts ++ * Run "board-to-uboot.py p3450-0000". ++ */ ++ ++#ifndef _PINMUX_CONFIG_P3450_0000_H_ ++#define _PINMUX_CONFIG_P3450_0000_H_ ++ ++#define GPIO_INIT(_port, _gpio, _init) \ ++ { \ ++ .gpio = TEGRA_GPIO(_port, _gpio), \ ++ .init = TEGRA_GPIO_INIT_##_init, \ ++ } ++ ++static const struct tegra_gpio_config p3450_0000_gpio_inits[] = { ++ /* port, pin, init_val */ ++ GPIO_INIT(A, 5, IN), ++ GPIO_INIT(A, 6, OUT1), ++ GPIO_INIT(B, 4, IN), ++ GPIO_INIT(B, 5, IN), ++ GPIO_INIT(B, 6, IN), ++ GPIO_INIT(B, 7, IN), ++ GPIO_INIT(C, 0, IN), ++ GPIO_INIT(C, 1, IN), ++ GPIO_INIT(C, 2, IN), ++ GPIO_INIT(C, 3, IN), ++ GPIO_INIT(C, 4, IN), ++ GPIO_INIT(E, 6, IN), ++ GPIO_INIT(G, 2, IN), ++ GPIO_INIT(G, 3, IN), ++ GPIO_INIT(H, 0, OUT0), ++ GPIO_INIT(H, 2, IN), ++ GPIO_INIT(H, 3, OUT0), ++ GPIO_INIT(H, 4, OUT0), ++ GPIO_INIT(H, 5, IN), ++ GPIO_INIT(H, 6, IN), ++ GPIO_INIT(H, 7, OUT0), ++ GPIO_INIT(I, 0, OUT0), ++ GPIO_INIT(I, 1, IN), ++ GPIO_INIT(I, 2, OUT0), ++ GPIO_INIT(J, 4, IN), ++ GPIO_INIT(J, 5, IN), ++ GPIO_INIT(J, 6, IN), ++ GPIO_INIT(J, 7, IN), ++ GPIO_INIT(S, 5, IN), ++ GPIO_INIT(S, 7, OUT0), ++ GPIO_INIT(T, 0, OUT0), ++ GPIO_INIT(V, 0, IN), ++ GPIO_INIT(V, 1, IN), ++ GPIO_INIT(X, 3, OUT1), ++ GPIO_INIT(X, 4, IN), ++ GPIO_INIT(X, 5, IN), ++ GPIO_INIT(X, 6, IN), ++ GPIO_INIT(Y, 1, IN), ++ GPIO_INIT(Y, 2, IN), ++ GPIO_INIT(Z, 0, IN), ++ GPIO_INIT(Z, 2, IN), ++ GPIO_INIT(Z, 3, OUT0), ++ GPIO_INIT(BB, 0, IN), ++ GPIO_INIT(CC, 4, IN), ++ GPIO_INIT(DD, 0, IN), ++}; ++ ++#define PINCFG(_pingrp, _mux, _pull, _tri, _io, _od, _e_io_hv) \ ++ { \ ++ .pingrp = PMUX_PINGRP_##_pingrp, \ ++ .func = PMUX_FUNC_##_mux, \ ++ .pull = PMUX_PULL_##_pull, \ ++ .tristate = PMUX_TRI_##_tri, \ ++ .io = PMUX_PIN_##_io, \ ++ .od = PMUX_PIN_OD_##_od, \ ++ .e_io_hv = PMUX_PIN_E_IO_HV_##_e_io_hv, \ ++ .lock = PMUX_PIN_LOCK_DEFAULT, \ ++ } ++ ++static const struct pmux_pingrp_config p3450_0000_pingrps[] = { ++ /* pingrp, mux, pull, tri, e_input, od, e_io_hv */ ++ PINCFG(PEX_L0_RST_N_PA0, PE0, NORMAL, NORMAL, OUTPUT, DISABLE, HIGH), ++ PINCFG(PEX_L0_CLKREQ_N_PA1, PE0, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(PEX_WAKE_N_PA2, PE, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(PEX_L1_RST_N_PA3, PE1, NORMAL, NORMAL, OUTPUT, DISABLE, HIGH), ++ PINCFG(PEX_L1_CLKREQ_N_PA4, PE1, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(SATA_LED_ACTIVE_PA5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PA6, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(DAP1_FS_PB0, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(DAP1_DIN_PB1, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(DAP1_DOUT_PB2, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(DAP1_SCLK_PB3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SPI2_MOSI_PB4, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI2_MISO_PB5, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI2_SCK_PB6, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI2_CS0_PB7, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI1_MOSI_PC0, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI1_MISO_PC1, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI1_SCK_PC2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI1_CS0_PC3, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI1_CS1_PC4, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SPI4_SCK_PC5, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SPI4_CS0_PC6, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SPI4_MOSI_PC7, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SPI4_MISO_PD0, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART3_TX_PD1, UARTC, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART3_RX_PD2, UARTC, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(UART3_RTS_PD3, UARTC, UP, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART3_CTS_PD4, UARTC, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DMIC1_CLK_PE0, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DMIC1_DAT_PE1, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DMIC2_CLK_PE2, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DMIC2_DAT_PE3, I2S3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DMIC3_CLK_PE4, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(DMIC3_DAT_PE5, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PE6, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PE7, PWM3, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(GEN3_I2C_SCL_PF0, I2C3, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), ++ PINCFG(GEN3_I2C_SDA_PF1, I2C3, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), ++ PINCFG(UART2_TX_PG0, UARTB, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART2_RX_PG1, UARTB, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(UART2_RTS_PG2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(UART2_CTS_PG3, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(WIFI_EN_PH0, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(WIFI_RST_PH1, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(WIFI_WAKE_AP_PH2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(AP_WAKE_BT_PH3, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(BT_RST_PH4, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(BT_WAKE_AP_PH5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PH6, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(AP_WAKE_NFC_PH7, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(NFC_EN_PI0, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(NFC_INT_PI1, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(GPS_EN_PI2, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(GPS_RST_PI3, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART4_TX_PI4, UARTD, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART4_RX_PI5, UARTD, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(UART4_RTS_PI6, UARTD, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART4_CTS_PI7, UARTD, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(GEN1_I2C_SDA_PJ0, I2C1, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(GEN1_I2C_SCL_PJ1, I2C1, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(GEN2_I2C_SCL_PJ2, I2C2, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(GEN2_I2C_SDA_PJ3, I2C2, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(DAP4_FS_PJ4, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP4_DIN_PJ5, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP4_DOUT_PJ6, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP4_SCLK_PJ7, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PK0, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK1, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK2, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK3, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK4, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK5, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK6, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PK7, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PL0, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PL1, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC1_CLK_PM0, SDMMC1, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC1_CMD_PM1, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC1_DAT3_PM2, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC1_DAT2_PM3, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC1_DAT1_PM4, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC1_DAT0_PM5, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC3_CLK_PP0, SDMMC3, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC3_CMD_PP1, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC3_DAT3_PP2, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC3_DAT2_PP3, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC3_DAT1_PP4, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(SDMMC3_DAT0_PP5, SDMMC3, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(CAM1_MCLK_PS0, EXTPERIPH3, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CAM2_MCLK_PS1, EXTPERIPH3, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CAM_I2C_SCL_PS2, I2CVI, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(CAM_I2C_SDA_PS3, I2CVI, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(CAM_RST_PS4, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CAM_AF_EN_PS5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(CAM_FLASH_EN_PS6, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CAM1_PWDN_PS7, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CAM2_PWDN_PT0, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CAM1_STROBE_PT1, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART1_TX_PU0, UARTA, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART1_RX_PU1, UARTA, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(UART1_RTS_PU2, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(UART1_CTS_PU3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(LCD_BL_PWM_PV0, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(LCD_BL_EN_PV1, DEFAULT, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(LCD_RST_PV2, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(LCD_GPIO1_PV3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(LCD_GPIO2_PV4, PWM1, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(AP_READY_PV5, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(TOUCH_RST_PV6, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(TOUCH_CLK_PV7, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(MODEM_WAKE_AP_PX0, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(TOUCH_INT_PX1, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(MOTION_INT_PX2, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(ALS_PROX_INT_PX3, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(TEMP_ALERT_PX4, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(BUTTON_POWER_ON_PX5, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(BUTTON_VOL_UP_PX6, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(BUTTON_VOL_DOWN_PX7, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(BUTTON_SLIDE_SW_PY0, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(BUTTON_HOME_PY1, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(LCD_TE_PY2, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PWR_I2C_SCL_PY3, I2CPMU, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), ++ PINCFG(PWR_I2C_SDA_PY4, I2CPMU, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), ++ PINCFG(CLK_32K_OUT_PY5, RSVD2, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PZ0, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PZ1, SDMMC1, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PZ2, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PZ3, DEFAULT, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PZ4, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PZ5, SOC, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP2_FS_PAA0, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP2_SCLK_PAA1, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP2_DIN_PAA2, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DAP2_DOUT_PAA3, I2S2, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(AUD_MCLK_PBB0, DEFAULT, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(DVFS_PWM_PBB1, CLDVFS, NORMAL, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(DVFS_CLK_PBB2, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(GPIO_X1_AUD_PBB3, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(GPIO_X3_AUD_PBB4, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(HDMI_CEC_PCC0, CEC, NORMAL, NORMAL, INPUT, DISABLE, HIGH), ++ PINCFG(HDMI_INT_DP_HPD_PCC1, DP, NORMAL, NORMAL, INPUT, DISABLE, NORMAL), ++ PINCFG(SPDIF_OUT_PCC2, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SPDIF_IN_PCC3, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(USB_VBUS_EN0_PCC4, DEFAULT, UP, NORMAL, INPUT, DISABLE, NORMAL), ++ PINCFG(USB_VBUS_EN1_PCC5, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, NORMAL), ++ PINCFG(DP_HPD0_PCC6, DP, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(PCC7, RSVD0, DOWN, TRISTATE, OUTPUT, DISABLE, NORMAL), ++ PINCFG(SPI2_CS1_PDD0, DEFAULT, DOWN, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(QSPI_SCK_PEE0, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(QSPI_CS_N_PEE1, QSPI, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(QSPI_IO0_PEE2, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(QSPI_IO1_PEE3, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(QSPI_IO2_PEE4, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(QSPI_IO3_PEE5, QSPI, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(CORE_PWR_REQ, CORE, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CPU_PWR_REQ, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(PWR_INT_N, PMI, UP, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(CLK_32K_IN, CLK, NORMAL, NORMAL, INPUT, DISABLE, DEFAULT), ++ PINCFG(JTAG_RTCK, JTAG, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(CLK_REQ, RSVD1, DOWN, TRISTATE, OUTPUT, DISABLE, DEFAULT), ++ PINCFG(SHUTDOWN, SHUTDOWN, NORMAL, NORMAL, OUTPUT, DISABLE, DEFAULT), ++}; ++ ++#define DRVCFG(_drvgrp, _slwf, _slwr, _drvup, _drvdn, _lpmd, _schmt, _hsm) \ ++ { \ ++ .drvgrp = PMUX_DRVGRP_##_drvgrp, \ ++ .slwf = _slwf, \ ++ .slwr = _slwr, \ ++ .drvup = _drvup, \ ++ .drvdn = _drvdn, \ ++ .lpmd = PMUX_LPMD_##_lpmd, \ ++ .schmt = PMUX_SCHMT_##_schmt, \ ++ .hsm = PMUX_HSM_##_hsm, \ ++ } ++ ++static const struct pmux_drvgrp_config p3450_0000_drvgrps[] = { ++}; ++ ++#endif /* PINMUX_CONFIG_P3450_0000_H */ +diff --git a/configs/p3450-0000_defconfig b/configs/p3450-0000_defconfig +new file mode 100644 +index 000000000000..3a95028279d3 +--- /dev/null ++++ b/configs/p3450-0000_defconfig +@@ -0,0 +1,55 @@ ++CONFIG_ARM=y ++CONFIG_TEGRA=y ++CONFIG_SYS_TEXT_BASE=0x80080000 ++CONFIG_TEGRA210=y ++CONFIG_TARGET_P3450_0000=y ++CONFIG_NR_DRAM_BANKS=2 ++CONFIG_OF_SYSTEM_SETUP=y ++CONFIG_OF_BOARD_SETUP=y ++CONFIG_CONSOLE_MUX=y ++CONFIG_SYS_STDIO_DEREGISTER=y ++CONFIG_SYS_PROMPT="Tegra210 (P3450-0000) # " ++# CONFIG_CMD_IMI is not set ++CONFIG_CMD_DFU=y ++# CONFIG_CMD_FLASH is not set ++CONFIG_CMD_GPIO=y ++CONFIG_CMD_I2C=y ++CONFIG_CMD_MMC=y ++CONFIG_CMD_PCI=y ++CONFIG_CMD_SF=y ++CONFIG_CMD_SPI=y ++CONFIG_CMD_USB=y ++CONFIG_CMD_USB_MASS_STORAGE=y ++# CONFIG_CMD_SETEXPR is not set ++# CONFIG_CMD_NFS is not set ++CONFIG_CMD_EXT4_WRITE=y ++CONFIG_OF_LIVE=y ++CONFIG_DEFAULT_DEVICE_TREE="tegra210-p3450-0000" ++CONFIG_DFU_MMC=y ++CONFIG_DFU_RAM=y ++CONFIG_DFU_SF=y ++CONFIG_SYS_I2C_TEGRA=y ++CONFIG_SPI_FLASH=y ++CONFIG_SF_DEFAULT_MODE=0 ++CONFIG_SF_DEFAULT_SPEED=24000000 ++CONFIG_SPI_FLASH_WINBOND=y ++CONFIG_RTL8169=y ++CONFIG_PCI=y ++CONFIG_DM_PCI=y ++CONFIG_DM_PCI_COMPAT=y ++CONFIG_PCI_TEGRA=y ++CONFIG_SYS_NS16550=y ++CONFIG_TEGRA114_SPI=y ++CONFIG_USB=y ++CONFIG_DM_USB=y ++CONFIG_USB_EHCI_HCD=y ++CONFIG_USB_EHCI_TEGRA=y ++CONFIG_USB_GADGET=y ++CONFIG_USB_GADGET_MANUFACTURER="NVIDIA" ++CONFIG_USB_GADGET_VENDOR_NUM=0x0955 ++CONFIG_USB_GADGET_PRODUCT_NUM=0x701a ++CONFIG_CI_UDC=y ++CONFIG_USB_GADGET_DOWNLOAD=y ++CONFIG_USB_HOST_ETHER=y ++CONFIG_USB_ETHER_ASIX=y ++# CONFIG_ENV_IS_IN_MMC is not set +diff --git a/include/configs/p3450-0000.h b/include/configs/p3450-0000.h +new file mode 100644 +index 000000000000..ee819b7573b0 +--- /dev/null ++++ b/include/configs/p3450-0000.h +@@ -0,0 +1,34 @@ ++/* SPDX-License-Identifier: GPL-2.0+ */ ++/* ++ * (C) Copyright 2018-2019 NVIDIA Corporation. All rights reserved. ++ */ ++ ++#ifndef _P3450_0000_H ++#define _P3450_0000_H ++ ++#include ++ ++#include "tegra210-common.h" ++ ++/* High-level configuration options */ ++#define CONFIG_TEGRA_BOARD_STRING "NVIDIA P3450-0000" ++ ++/* Board-specific serial config */ ++#define CONFIG_TEGRA_ENABLE_UARTA ++ ++/* Only MMC1/PXE/DHCP for now, add USB back in later when supported */ ++#define BOOT_TARGET_DEVICES(func) \ ++ func(MMC, mmc, 0) \ ++ func(PXE, pxe, na) \ ++ func(DHCP, dhcp, na) ++ ++/* SPI */ ++#define CONFIG_SPI_FLASH_SIZE (4 << 20) ++ ++#include "tegra-common-usb-gadget.h" ++#include "tegra-common-post.h" ++ ++/* Crystal is 38.4MHz. clk_m runs at half that rate */ ++#define COUNTER_FREQUENCY 19200000 ++ ++#endif /* _P3450_0000_H */ diff --git a/arm-tegra-defaine-fdtfile-for-all-devices.patch b/arm-tegra-defaine-fdtfile-for-all-devices.patch new file mode 100644 index 0000000..50c1c1f --- /dev/null +++ b/arm-tegra-defaine-fdtfile-for-all-devices.patch @@ -0,0 +1,162 @@ +From 1e93c98419e6a1ea62ef697ed915617024eb6da0 Mon Sep 17 00:00:00 2001 +From: Peter Robinson +Date: Thu, 18 Apr 2019 14:03:33 +0100 +Subject: [PATCH] arm: tegra: defaine fdtfile for all devices + +Signed-off-by: Peter Robinson +--- + include/configs/tegra-common.h | 6 ++++++ + include/configs/tegra114-common.h | 1 + + include/configs/tegra124-common.h | 1 + + include/configs/tegra186-common.h | 1 + + include/configs/tegra20-common.h | 1 + + include/configs/tegra210-common.h | 1 + + include/configs/tegra30-common.h | 1 + + 7 files changed, 12 insertions(+) + +diff --git a/include/configs/tegra-common.h b/include/configs/tegra-common.h +index 84f671d00c..c3e16d8cfc 100644 +--- a/include/configs/tegra-common.h ++++ b/include/configs/tegra-common.h +@@ -56,6 +56,12 @@ + #define CONFIG_SYS_MEMTEST_START (NV_PA_SDRC_CS0 + 0x600000) + #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_MEMTEST_START + 0x100000) + ++#ifdef CONFIG_ARM64 ++#define FDTFILE "nvidia/" CONFIG_DEFAULT_DEVICE_TREE ".dtb" ++#else ++#define FDTFILE CONFIG_DEFAULT_DEVICE_TREE ".dtb" ++#endif ++ + /*----------------------------------------------------------------------- + * Physical Memory Map + */ +diff --git a/include/configs/tegra114-common.h b/include/configs/tegra114-common.h +index 1aa4412645..0c44a7673b 100644 +--- a/include/configs/tegra114-common.h ++++ b/include/configs/tegra114-common.h +@@ -50,6 +50,7 @@ + "scriptaddr=0x90000000\0" \ + "pxefile_addr_r=0x90100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ ++ "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x83000000\0" \ + "ramdisk_addr_r=0x83100000\0" + +diff --git a/include/configs/tegra124-common.h b/include/configs/tegra124-common.h +index 3530684164..29da06c8f7 100644 +--- a/include/configs/tegra124-common.h ++++ b/include/configs/tegra124-common.h +@@ -52,6 +52,7 @@ + "scriptaddr=0x90000000\0" \ + "pxefile_addr_r=0x90100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ ++ "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x83000000\0" \ + "ramdisk_addr_r=0x83100000\0" + +diff --git a/include/configs/tegra186-common.h b/include/configs/tegra186-common.h +index b4936cc731..5c3ad35c76 100644 +--- a/include/configs/tegra186-common.h ++++ b/include/configs/tegra186-common.h +@@ -49,6 +49,7 @@ + "scriptaddr=0x90000000\0" \ + "pxefile_addr_r=0x90100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ ++ "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x82000000\0" \ + "ramdisk_addr_r=0x82100000\0" + +diff --git a/include/configs/tegra20-common.h b/include/configs/tegra20-common.h +index e58477e289..73c94d993b 100644 +--- a/include/configs/tegra20-common.h ++++ b/include/configs/tegra20-common.h +@@ -51,6 +51,7 @@ + "scriptaddr=0x10000000\0" \ + "pxefile_addr_r=0x10100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ ++ "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x03000000\0" \ + "ramdisk_addr_r=0x03100000\0" + +diff --git a/include/configs/tegra210-common.h b/include/configs/tegra210-common.h +index 1c533118ad..69e446ed58 100644 +--- a/include/configs/tegra210-common.h ++++ b/include/configs/tegra210-common.h +@@ -46,6 +46,7 @@ + "scriptaddr=0x90000000\0" \ + "pxefile_addr_r=0x90100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ ++ "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x82000000\0" \ + "ramdisk_addr_r=0x82100000\0" + +diff --git a/include/configs/tegra30-common.h b/include/configs/tegra30-common.h +index 2d8948d9d9..27696009cd 100644 +--- a/include/configs/tegra30-common.h ++++ b/include/configs/tegra30-common.h +@@ -47,6 +47,7 @@ + "scriptaddr=0x90000000\0" \ + "pxefile_addr_r=0x90100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ ++ "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x83000000\0" \ + "ramdisk_addr_r=0x83100000\0" + +-- +2.21.0 +From 267dc15aa8f247362b04387d6a1ab01d94d41aef Mon Sep 17 00:00:00 2001 +From: Peter Robinson +Date: Thu, 18 Apr 2019 15:44:59 +0100 +Subject: [PATCH] add BOOTENV_EFI_SET_FDTFILE_FALLBACK for tegra186 because tx2 + variants + +Signed-off-by: Peter Robinson +--- + include/config_distro_bootcmd.h | 2 ++ + include/configs/tegra186-common.h | 7 ++++++- + 2 files changed, 8 insertions(+), 1 deletion(-) + +diff --git a/include/config_distro_bootcmd.h b/include/config_distro_bootcmd.h +index 4993303f4d..cd317bb457 100644 +--- a/include/config_distro_bootcmd.h ++++ b/include/config_distro_bootcmd.h +@@ -118,8 +118,10 @@ + "setenv efi_fdtfile ${soc}-${board}${boardver}.dtb; " \ + "fi; " + #else ++#ifndef BOOTENV_EFI_SET_FDTFILE_FALLBACK + #define BOOTENV_EFI_SET_FDTFILE_FALLBACK + #endif ++#endif + + + #define BOOTENV_SHARED_EFI \ +diff --git a/include/configs/tegra186-common.h b/include/configs/tegra186-common.h +index 5c3ad35c76..d5f21e0907 100644 +--- a/include/configs/tegra186-common.h ++++ b/include/configs/tegra186-common.h +@@ -20,6 +20,12 @@ + /* Generic Interrupt Controller */ + #define CONFIG_GICV2 + ++#undef FDTFILE ++#define BOOTENV_EFI_SET_FDTFILE_FALLBACK \ ++ "if test -z \"${fdtfile}\" -a -n \"${soc}\"; then " \ ++ "setenv efi_fdtfile ${vendor}/${soc}-${board}${boardver}.dtb; " \ ++ "fi; " ++ + /* + * Memory layout for where various images get loaded by boot scripts: + * +@@ -49,7 +55,6 @@ + "scriptaddr=0x90000000\0" \ + "pxefile_addr_r=0x90100000\0" \ + "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \ +- "fdtfile=" FDTFILE "\0" \ + "fdt_addr_r=0x82000000\0" \ + "ramdisk_addr_r=0x82100000\0" + +-- +2.21.0 + diff --git a/net-eth-uclass-Write-MAC-address-to-hardware-after-probe.patch b/net-eth-uclass-Write-MAC-address-to-hardware-after-probe.patch index 2896af8..237b4a6 100644 --- a/net-eth-uclass-Write-MAC-address-to-hardware-after-probe.patch +++ b/net-eth-uclass-Write-MAC-address-to-hardware-after-probe.patch @@ -1,16 +1,15 @@ -From patchwork Fri Mar 8 19:51:25 2019 +From patchwork Tue Apr 16 16:24:16 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot, - 1/3] net: eth-uclass: Write MAC address to hardware after probe +Subject: [U-Boot, v2, + 1/2] net: eth-uclass: Write MAC address to hardware after probe X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1053669 -Message-Id: <20190308195127.32711-1-thierry.reding@gmail.com> -To: Joe Hershberger -Cc: u-boot@lists.denx.de, Stephen Warren , - Tom Warren -Date: Fri, 8 Mar 2019 20:51:25 +0100 +X-Patchwork-Id: 1086417 +Message-Id: <20190416162417.25799-1-thierry.reding@gmail.com> +To: Simon Glass , Joe Hershberger +Cc: u-boot@lists.denx.de +Date: Tue, 16 Apr 2019 18:24:16 +0200 From: Thierry Reding List-Id: U-Boot discussion @@ -44,104 +43,155 @@ index 2ef20df19203..4225aabf1fa1 100644 } -From patchwork Fri Mar 8 19:51:26 2019 +From patchwork Tue Apr 16 16:24:17 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit -Subject: [U-Boot,2/3] net: rtl8169: Implement ->hwaddr_write() callback +Subject: [U-Boot,v2,2/2] net: eth-uclass: Support device tree MAC addresses X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1053670 -Message-Id: <20190308195127.32711-2-thierry.reding@gmail.com> -To: Joe Hershberger -Cc: u-boot@lists.denx.de, Stephen Warren , - Tom Warren -Date: Fri, 8 Mar 2019 20:51:26 +0100 +X-Patchwork-Id: 1086418 +Message-Id: <20190416162417.25799-2-thierry.reding@gmail.com> +To: Simon Glass , Joe Hershberger +Cc: u-boot@lists.denx.de +Date: Tue, 16 Apr 2019 18:24:17 +0200 From: Thierry Reding List-Id: U-Boot discussion From: Thierry Reding -Implement this callback that allows the MAC address to be set for the -Ethernet card. This is necessary in order for the device to be able to -receive packets for the MAC address that U-Boot advertises. +Add the standard Ethernet device tree bindings (imported from v5.0 of +the Linux kernel) and implement support for reading the MAC address for +Ethernet devices in the Ethernet uclass. If the "mac-address" property +exists, the MAC address will be parsed from that. If that property does +not exist, the "local-mac-address" property will be tried as fallback. +MAC addresses from device tree take precedence over the ones stored in +a network interface card's ROM. + +Acked-by: Joe Hershberger Signed-off-by: Thierry Reding --- - drivers/net/rtl8169.c | 18 ++++++++++++++++++ - 1 file changed, 18 insertions(+) +Changes in v2: +- use dev_read_u8_array_ptr() -diff --git a/drivers/net/rtl8169.c b/drivers/net/rtl8169.c -index a78f3d233f1a..27e27b34176b 100644 ---- a/drivers/net/rtl8169.c -+++ b/drivers/net/rtl8169.c -@@ -941,6 +941,23 @@ static void rtl_halt(struct eth_device *dev) + .../devicetree/bindings/net/ethernet.txt | 66 +++++++++++++++++++ + net/eth-uclass.c | 26 +++++++- + 2 files changed, 89 insertions(+), 3 deletions(-) + create mode 100644 Documentation/devicetree/bindings/net/ethernet.txt + +diff --git a/Documentation/devicetree/bindings/net/ethernet.txt b/Documentation/devicetree/bindings/net/ethernet.txt +new file mode 100644 +index 000000000000..cfc376bc977a +--- /dev/null ++++ b/Documentation/devicetree/bindings/net/ethernet.txt +@@ -0,0 +1,66 @@ ++The following properties are common to the Ethernet controllers: ++ ++NOTE: All 'phy*' properties documented below are Ethernet specific. For the ++generic PHY 'phys' property, see ++Documentation/devicetree/bindings/phy/phy-bindings.txt. ++ ++- local-mac-address: array of 6 bytes, specifies the MAC address that was ++ assigned to the network device; ++- mac-address: array of 6 bytes, specifies the MAC address that was last used by ++ the boot program; should be used in cases where the MAC address assigned to ++ the device by the boot program is different from the "local-mac-address" ++ property; ++- nvmem-cells: phandle, reference to an nvmem node for the MAC address; ++- nvmem-cell-names: string, should be "mac-address" if nvmem is to be used; ++- max-speed: number, specifies maximum speed in Mbit/s supported by the device; ++- max-frame-size: number, maximum transfer unit (IEEE defined MTU), rather than ++ the maximum frame size (there's contradiction in the Devicetree ++ Specification). ++- phy-mode: string, operation mode of the PHY interface. This is now a de-facto ++ standard property; supported values are: ++ * "internal" ++ * "mii" ++ * "gmii" ++ * "sgmii" ++ * "qsgmii" ++ * "tbi" ++ * "rev-mii" ++ * "rmii" ++ * "rgmii" (RX and TX delays are added by the MAC when required) ++ * "rgmii-id" (RGMII with internal RX and TX delays provided by the PHY, the ++ MAC should not add the RX or TX delays in this case) ++ * "rgmii-rxid" (RGMII with internal RX delay provided by the PHY, the MAC ++ should not add an RX delay in this case) ++ * "rgmii-txid" (RGMII with internal TX delay provided by the PHY, the MAC ++ should not add an TX delay in this case) ++ * "rtbi" ++ * "smii" ++ * "xgmii" ++ * "trgmii" ++ * "2000base-x", ++ * "2500base-x", ++ * "rxaui" ++ * "xaui" ++ * "10gbase-kr" (10GBASE-KR, XFI, SFI) ++- phy-connection-type: the same as "phy-mode" property but described in the ++ Devicetree Specification; ++- phy-handle: phandle, specifies a reference to a node representing a PHY ++ device; this property is described in the Devicetree Specification and so ++ preferred; ++- phy: the same as "phy-handle" property, not recommended for new bindings. ++- phy-device: the same as "phy-handle" property, not recommended for new ++ bindings. ++- rx-fifo-depth: the size of the controller's receive fifo in bytes. This ++ is used for components that can have configurable receive fifo sizes, ++ and is useful for determining certain configuration settings such as ++ flow control thresholds. ++- tx-fifo-depth: the size of the controller's transmit fifo in bytes. This ++ is used for components that can have configurable fifo sizes. ++- managed: string, specifies the PHY management type. Supported values are: ++ "auto", "in-band-status". "auto" is the default, it usess MDIO for ++ management if fixed-link is not specified. ++ ++Child nodes of the Ethernet controller are typically the individual PHY devices ++connected via the MDIO bus (sometimes the MDIO bus controller is separate). ++They are described in the phy.txt file in this same directory. ++For non-MDIO PHY management see fixed-link.txt. +diff --git a/net/eth-uclass.c b/net/eth-uclass.c +index 4225aabf1fa1..c6d5ec013bd8 100644 +--- a/net/eth-uclass.c ++++ b/net/eth-uclass.c +@@ -455,6 +455,23 @@ static int eth_pre_unbind(struct udevice *dev) + return 0; } - #endif -+#ifdef CONFIG_DM_ETH -+static int rtl8169_write_hwaddr(struct udevice *dev) ++static bool eth_dev_get_mac_address(struct udevice *dev, u8 mac[ARP_HLEN]) +{ -+ struct eth_pdata *plat = dev_get_platdata(dev); -+ unsigned int i; ++ const uint8_t *p; + -+ RTL_W8(Cfg9346, Cfg9346_Unlock); ++ p = dev_read_u8_array_ptr(dev, "mac-address", ARP_HLEN); ++ if (!p) ++ p = dev_read_u8_array_ptr(dev, "local-mac-address", ARP_HLEN); + -+ for (i = 0; i < MAC_ADDR_LEN; i++) -+ RTL_W8(MAC0 + i, plat->enetaddr[i]); ++ if (!p) { ++ memset(mac, 0, ARP_HLEN); ++ return false; ++ } + -+ RTL_W8(Cfg9346, Cfg9346_Lock); -+ -+ return 0; ++ memcpy(mac, p, ARP_HLEN); ++ return true; +} -+#endif + - /************************************************************************** - INIT - Look for an adapter, this routine's visible to the outside - ***************************************************************************/ -@@ -1195,6 +1212,7 @@ static const struct eth_ops rtl8169_eth_ops = { - .send = rtl8169_eth_send, - .recv = rtl8169_eth_recv, - .stop = rtl8169_eth_stop, -+ .write_hwaddr = rtl8169_write_hwaddr, - }; + static int eth_post_probe(struct udevice *dev) + { + struct eth_device_priv *priv = dev->uclass_priv; +@@ -489,9 +506,12 @@ static int eth_post_probe(struct udevice *dev) - static const struct udevice_id rtl8169_eth_ids[] = { - -From patchwork Fri Mar 8 19:51:27 2019 -Content-Type: text/plain; charset="utf-8" -MIME-Version: 1.0 -Content-Transfer-Encoding: 7bit -Subject: [U-Boot,3/3] net: rtl8169: Support RTL-8168h/8111h -X-Patchwork-Submitter: Thierry Reding -X-Patchwork-Id: 1053671 -Message-Id: <20190308195127.32711-3-thierry.reding@gmail.com> -To: Joe Hershberger -Cc: u-boot@lists.denx.de, Stephen Warren , - Tom Warren -Date: Fri, 8 Mar 2019 20:51:27 +0100 -From: Thierry Reding -List-Id: U-Boot discussion - -From: Thierry Reding - -This version of the RTL-8168 is present on some development boards and -is compatible with this driver. Add support for identifying this version -of the chip so that U-Boot won't complain about it being unknown. - -Signed-off-by: Thierry Reding ---- - drivers/net/rtl8169.c | 1 + - 1 file changed, 1 insertion(+) - -diff --git a/drivers/net/rtl8169.c b/drivers/net/rtl8169.c -index 27e27b34176b..bc052e72564b 100644 ---- a/drivers/net/rtl8169.c -+++ b/drivers/net/rtl8169.c -@@ -257,6 +257,7 @@ static struct { - {"RTL-8168/8111g", 0x4c, 0xff7e1880,}, - {"RTL-8101e", 0x34, 0xff7e1880,}, - {"RTL-8100e", 0x32, 0xff7e1880,}, -+ {"RTL-8168h/8111h", 0x54, 0xff7e1880,}, - }; + priv->state = ETH_STATE_INIT; - enum _DescStatusBit { +- /* Check if the device has a MAC address in ROM */ +- if (eth_get_ops(dev)->read_rom_hwaddr) +- eth_get_ops(dev)->read_rom_hwaddr(dev); ++ /* Check if the device has a MAC address in device tree */ ++ if (!eth_dev_get_mac_address(dev, pdata->enetaddr)) { ++ /* Check if the device has a MAC address in ROM */ ++ if (eth_get_ops(dev)->read_rom_hwaddr) ++ eth_get_ops(dev)->read_rom_hwaddr(dev); ++ } + + eth_env_get_enetaddr_by_index("eth", dev->seq, env_enetaddr); + if (!is_zero_ethaddr(env_enetaddr)) { diff --git a/net-rtl8169-Implement---hwaddr_write-callback.patch b/net-rtl8169-Implement---hwaddr_write-callback.patch new file mode 100644 index 0000000..984e860 --- /dev/null +++ b/net-rtl8169-Implement---hwaddr_write-callback.patch @@ -0,0 +1,102 @@ +From patchwork Tue Apr 16 16:20:29 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, RESEND, + 1/2] net: rtl8169: Implement ->hwaddr_write() callback +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1086411 +Message-Id: <20190416162030.13590-1-thierry.reding@gmail.com> +To: Joe Hershberger +Cc: u-boot@lists.denx.de +Date: Tue, 16 Apr 2019 18:20:29 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +Implement this callback that allows the MAC address to be set for the +Ethernet card. This is necessary in order for the device to be able to +receive packets for the MAC address that U-Boot advertises. + +Signed-off-by: Thierry Reding +Acked-by: Joe Hershberger +--- + drivers/net/rtl8169.c | 18 ++++++++++++++++++ + 1 file changed, 18 insertions(+) + +diff --git a/drivers/net/rtl8169.c b/drivers/net/rtl8169.c +index a78f3d233f1a..27e27b34176b 100644 +--- a/drivers/net/rtl8169.c ++++ b/drivers/net/rtl8169.c +@@ -941,6 +941,23 @@ static void rtl_halt(struct eth_device *dev) + } + #endif + ++#ifdef CONFIG_DM_ETH ++static int rtl8169_write_hwaddr(struct udevice *dev) ++{ ++ struct eth_pdata *plat = dev_get_platdata(dev); ++ unsigned int i; ++ ++ RTL_W8(Cfg9346, Cfg9346_Unlock); ++ ++ for (i = 0; i < MAC_ADDR_LEN; i++) ++ RTL_W8(MAC0 + i, plat->enetaddr[i]); ++ ++ RTL_W8(Cfg9346, Cfg9346_Lock); ++ ++ return 0; ++} ++#endif ++ + /************************************************************************** + INIT - Look for an adapter, this routine's visible to the outside + ***************************************************************************/ +@@ -1195,6 +1212,7 @@ static const struct eth_ops rtl8169_eth_ops = { + .send = rtl8169_eth_send, + .recv = rtl8169_eth_recv, + .stop = rtl8169_eth_stop, ++ .write_hwaddr = rtl8169_write_hwaddr, + }; + + static const struct udevice_id rtl8169_eth_ids[] = { + +From patchwork Tue Apr 16 16:20:30 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot,RESEND,2/2] net: rtl8169: Support RTL-8168h/8111h +X-Patchwork-Submitter: Thierry Reding +X-Patchwork-Id: 1086412 +Message-Id: <20190416162030.13590-2-thierry.reding@gmail.com> +To: Joe Hershberger +Cc: u-boot@lists.denx.de +Date: Tue, 16 Apr 2019 18:20:30 +0200 +From: Thierry Reding +List-Id: U-Boot discussion + +From: Thierry Reding + +This version of the RTL-8168 is present on some development boards and +is compatible with this driver. Add support for identifying this version +of the chip so that U-Boot won't complain about it being unknown. + +Signed-off-by: Thierry Reding +Acked-by: Joe Hershberger +--- + drivers/net/rtl8169.c | 1 + + 1 file changed, 1 insertion(+) + +diff --git a/drivers/net/rtl8169.c b/drivers/net/rtl8169.c +index 27e27b34176b..bc052e72564b 100644 +--- a/drivers/net/rtl8169.c ++++ b/drivers/net/rtl8169.c +@@ -257,6 +257,7 @@ static struct { + {"RTL-8168/8111g", 0x4c, 0xff7e1880,}, + {"RTL-8101e", 0x34, 0xff7e1880,}, + {"RTL-8100e", 0x32, 0xff7e1880,}, ++ {"RTL-8168h/8111h", 0x54, 0xff7e1880,}, + }; + + enum _DescStatusBit { diff --git a/sources b/sources index 71120c2..176ad87 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (u-boot-2019.04-rc4.tar.bz2) = 33a57e4acb51dbe04123055b159a5b3a933ea8340aa81a4148572ee5fc12288413a6c6c0b80b6fe099ac79ea6359be2d9034ead1edfcc0403895f3f8eb56746e +SHA512 (u-boot-2019.04.tar.bz2) = 357fe94b5b043885472ea1b7dcbbac601d0c1f7c64f71026b9e1279b53160847c6478d6ec98a2f678e562db21e39037d6e6fbc1e6b19beaac02ca14e93c5de0e diff --git a/uboot-tools.spec b/uboot-tools.spec index 688536a..83a5539 100644 --- a/uboot-tools.spec +++ b/uboot-tools.spec @@ -1,8 +1,8 @@ -%global candidate rc4 +#global candidate rc4 Name: uboot-tools Version: 2019.04 -Release: 0.9%{?candidate:.%{candidate}}%{?dist} +Release: 1%{?candidate:.%{candidate}}%{?dist} Summary: U-Boot utilities License: GPLv2+ BSD LGPL-2.1+ LGPL-2.0+ URL: http://www.denx.de/wiki/U-Boot @@ -18,17 +18,19 @@ Source5: 10-devicetree.install Patch1: uefi-use-Fedora-specific-path-name.patch # general fixes -Patch2: uefi-distro-load-FDT-from-any-partition-on-boot-device.patch -Patch3: usb-kbd-fixes.patch -Patch4: uefi-rc5-fixes.patch +Patch2: usb-kbd-fixes.patch +Patch3: uefi-distro-load-FDT-from-any-partition-on-boot-device.patch +Patch4: uefi-fix-memory-calculation-overflow-on-32-bit-systems.patch +Patch5: uefi-Change-FDT-memory-type-from-runtime-data-to-boot-services-data.patch # Board fixes and enablement Patch10: rpi-Enable-using-the-DT-provided-by-the-Raspberry-Pi.patch Patch11: dragonboard-fixes.patch -Patch12: ARM-tegra-Miscellaneous-improvements.patch -Patch13: ARM-tegra-Add-support-for-framebuffer-carveouts.patch -Patch14: ARM-tegra-Add-NVIDIA-Jetson-Nano-Developer-Kit-support.patch +Patch12: ARM-tegra-Add-support-for-framebuffer-carveouts.patch +Patch13: ARM-tegra-Miscellaneous-improvements.patch Patch15: net-eth-uclass-Write-MAC-address-to-hardware-after-probe.patch +Patch16: net-rtl8169-Implement---hwaddr_write-callback.patch +Patch17: arm-tegra-defaine-fdtfile-for-all-devices.patch BuildRequires: bc BuildRequires: dtc @@ -303,6 +305,10 @@ cp -p board/warp7/README builds/docs/README.warp7 %endif %changelog +* Sun Apr 14 2019 Peter Robinson 2019.04-1 +- 2019.04 +- Fixes for AllWinner and NVIDIA Jetson devices + * Thu Apr 4 2019 Peter Robinson 2019.04-0.9-rc4 - Latest Tegra patch revision diff --git a/uefi-Change-FDT-memory-type-from-runtime-data-to-boot-services-data.patch b/uefi-Change-FDT-memory-type-from-runtime-data-to-boot-services-data.patch new file mode 100644 index 0000000..33c93b6 --- /dev/null +++ b/uefi-Change-FDT-memory-type-from-runtime-data-to-boot-services-data.patch @@ -0,0 +1,54 @@ +From patchwork Fri Apr 12 18:26:28 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot, + U-boot] : Change FDT memory type from runtime data to boot services + data +X-Patchwork-Submitter: Ilias Apalodimas +X-Patchwork-Id: 1084888 +X-Patchwork-Delegate: xypron.glpk@gmx.de +Message-Id: <1555093588-21916-1-git-send-email-ilias.apalodimas@linaro.org> +To: u-boot@lists.denx.de, + xypron.glpk@gmx.de +Cc: Ilias Apalodimas , agraf@csgraf.de, + ard.biesheuvel@linaro.org +Date: Fri, 12 Apr 2019 21:26:28 +0300 +From: Ilias Apalodimas +List-Id: U-Boot discussion + +Following Ard's suggestion: +Runtime data sections are intended for data that is used by the runtime +services implementation. +Let's change the type to EFI_BOOT_SERVICES_DATA + +This also fixes booting of armv7 using efi and fdtcontroladdr + +Suggested-by: Ard Biesheuvel +Signed-off-by: Ilias Apalodimas +Acked-by: Ard Biesheuvel +Reviewed-by: Heinrich Schuchardt +--- + cmd/bootefi.c | 4 ++-- + 1 file changed, 2 insertions(+), 2 deletions(-) + +diff --git a/cmd/bootefi.c b/cmd/bootefi.c +index 3619a20e6433..15ee4af45667 100644 +--- a/cmd/bootefi.c ++++ b/cmd/bootefi.c +@@ -111,13 +111,13 @@ static efi_status_t copy_fdt(void **fdtp) + new_fdt_addr = (uintptr_t)map_sysmem(fdt_ram_start + 0x7f00000 + + fdt_size, 0); + ret = efi_allocate_pages(EFI_ALLOCATE_MAX_ADDRESS, +- EFI_RUNTIME_SERVICES_DATA, fdt_pages, ++ EFI_BOOT_SERVICES_DATA, fdt_pages, + &new_fdt_addr); + if (ret != EFI_SUCCESS) { + /* If we can't put it there, put it somewhere */ + new_fdt_addr = (ulong)memalign(EFI_PAGE_SIZE, fdt_size); + ret = efi_allocate_pages(EFI_ALLOCATE_MAX_ADDRESS, +- EFI_RUNTIME_SERVICES_DATA, fdt_pages, ++ EFI_BOOT_SERVICES_DATA, fdt_pages, + &new_fdt_addr); + if (ret != EFI_SUCCESS) { + printf("ERROR: Failed to reserve space for FDT\n"); diff --git a/uefi-fix-memory-calculation-overflow-on-32-bit-systems.patch b/uefi-fix-memory-calculation-overflow-on-32-bit-systems.patch new file mode 100644 index 0000000..bdb0108 --- /dev/null +++ b/uefi-fix-memory-calculation-overflow-on-32-bit-systems.patch @@ -0,0 +1,46 @@ +From patchwork Tue Apr 9 20:58:30 2019 +Content-Type: text/plain; charset="utf-8" +MIME-Version: 1.0 +Content-Transfer-Encoding: 7bit +Subject: [U-Boot] efi: fix memory calculation overflow on 32-bit systems +X-Patchwork-Submitter: Patrick Wildt +X-Patchwork-Id: 1082739 +X-Patchwork-Delegate: xypron.glpk@gmx.de +Message-Id: <20190409205830.GA5818@nyx.fritz.box> +To: u-boot@lists.denx.de +Date: Tue, 9 Apr 2019 22:58:30 +0200 +From: Patrick Wildt +List-Id: U-Boot discussion + +Hi, + +There are Cubox-i machines out there with nearly 4 GiB of RAM. The +RAM starts at 0x10000000 with a size of 0xf0000000. Thus the end +of RAM is at 0x100000000. This overflows a 32-bit integer, which +should be fine since in the EFI memory code the variables used are +all 64-bit with a fixed size. Unfortunately EFI_PAGE_MASK, which is +used in the EFI memory code to remove the lower bits, is based on +the EFI_PAGE_SIZE macro which, uses 1UL with a shift. This means +the resulting mask is UL, which is only 32-bit on ARMv7. Use ULL to +make sure that even on 32-bit platforms we use a 64-bit long mask. +Without this there will be no memory available in the EFI memory map +and bootefi will fail allocating pages. + +Best regards, +Patrick +Reviewed-by: Heinrich Schuchardt +Reviewed-by: Patrick Delaunay + +diff --git a/include/efi.h b/include/efi.h +index d98441ab19d..3c9d20f8c0b 100644 +--- a/include/efi.h ++++ b/include/efi.h +@@ -190,7 +190,7 @@ enum efi_mem_type { + #define EFI_MEM_DESC_VERSION 1 + + #define EFI_PAGE_SHIFT 12 +-#define EFI_PAGE_SIZE (1UL << EFI_PAGE_SHIFT) ++#define EFI_PAGE_SIZE (1ULL << EFI_PAGE_SHIFT) + #define EFI_PAGE_MASK (EFI_PAGE_SIZE - 1) + + struct efi_mem_desc { diff --git a/uefi-rc5-fixes.patch b/uefi-rc5-fixes.patch deleted file mode 100644 index fd36553..0000000 --- a/uefi-rc5-fixes.patch +++ /dev/null @@ -1,245 +0,0 @@ -From 306b16718edddd660b84bf3c6627ce5d41b53ce7 Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Mon, 18 Mar 2019 20:01:59 +0100 -Subject: [PATCH 01/25] efi_loader: correct parameter size in efi_allocate_pool - -efi_allocate_pages() expects a (uint64_t *) pointer to pass the address of -the assigned memory. If we pass the address of a pointer here, an illegal -memory access occurs on 32bit systems. - -Fixes: 282a06cbcae8 ("efi_loader: Expose U-Boot addresses in memory map -for sandbox") -Signed-off-by: Heinrich Schuchardt ---- - lib/efi_loader/efi_memory.c | 5 +++-- - 1 file changed, 3 insertions(+), 2 deletions(-) - -diff --git a/lib/efi_loader/efi_memory.c b/lib/efi_loader/efi_memory.c -index ebd2b36c03..55622d2fb4 100644 ---- a/lib/efi_loader/efi_memory.c -+++ b/lib/efi_loader/efi_memory.c -@@ -440,6 +440,7 @@ efi_status_t efi_free_pages(uint64_t memory, efi_uintn_t pages) - efi_status_t efi_allocate_pool(int pool_type, efi_uintn_t size, void **buffer) - { - efi_status_t r; -+ u64 addr; - struct efi_pool_allocation *alloc; - u64 num_pages = efi_size_in_pages(size + - sizeof(struct efi_pool_allocation)); -@@ -453,9 +454,9 @@ efi_status_t efi_allocate_pool(int pool_type, efi_uintn_t size, void **buffer) - } - - r = efi_allocate_pages(EFI_ALLOCATE_ANY_PAGES, pool_type, num_pages, -- (uint64_t *)&alloc); -- -+ &addr); - if (r == EFI_SUCCESS) { -+ alloc = (struct efi_pool_allocation *)(uintptr_t)addr; - alloc->num_pages = num_pages; - *buffer = alloc->data; - } --- -2.20.1 - -From bd3b7478d1e17b4d487d276f5cc0e4f4ef9fc4b7 Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Tue, 19 Mar 2019 12:30:27 +0100 -Subject: [PATCH 02/25] efi_loader: endless loop in add_strings_package() - -Avoid an endless loop in add_strings_package(). - -Suggested-by: Takahiro Akashi -Reported-by: Coverity (CID 185833) -Signed-off-by: Heinrich Schuchardt ---- - lib/efi_loader/efi_hii.c | 5 ++--- - 1 file changed, 2 insertions(+), 3 deletions(-) - -diff --git a/lib/efi_loader/efi_hii.c b/lib/efi_loader/efi_hii.c -index 3a966fa4df..61b71dec62 100644 ---- a/lib/efi_loader/efi_hii.c -+++ b/lib/efi_loader/efi_hii.c -@@ -227,9 +227,8 @@ out: - error: - if (stbl) { - free(stbl->language); -- if (idx > 0) -- while (--idx >= 0) -- free(stbl->strings[idx].string); -+ while (idx > 0) -+ free(stbl->strings[--idx].string); - free(stbl->strings); - } - free(stbl); --- -2.20.1 - -From e7dae584b05feaf507c5b85a704a2c1d25abffc9 Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Tue, 19 Mar 2019 18:36:21 +0100 -Subject: [PATCH 03/25] efi_loader: missing return in - efi_get_next_variable_name() - -Add a missing return statement in efi_get_next_variable_name(). - -Reported-by: Coverity (CID 185834) -Signed-off-by: Heinrich Schuchardt ---- - lib/efi_loader/efi_variable.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/lib/efi_loader/efi_variable.c b/lib/efi_loader/efi_variable.c -index e0d7f5736d..699f4184d9 100644 ---- a/lib/efi_loader/efi_variable.c -+++ b/lib/efi_loader/efi_variable.c -@@ -335,7 +335,7 @@ efi_status_t EFIAPI efi_get_next_variable_name(efi_uintn_t *variable_name_size, - EFI_ENTRY("%p \"%ls\" %pUl", variable_name_size, variable_name, vendor); - - if (!variable_name_size || !variable_name || !vendor) -- EFI_EXIT(EFI_INVALID_PARAMETER); -+ return EFI_EXIT(EFI_INVALID_PARAMETER); - - if (variable_name[0]) { - /* check null-terminated string */ --- -2.20.1 - -From 1fd7a4764103781e424ef687034da06de3cb60b7 Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Tue, 19 Mar 2019 18:44:05 +0100 -Subject: [PATCH 04/25] efi_loader: memory leak in efi_dump_single_var() - -A misplaced return statement lead to a memory leak in -efi_dump_single_var(). - -Reported-by: Coverity (CID 185829) -Signed-off-by: Heinrich Schuchardt ---- - cmd/nvedit_efi.c | 1 - - 1 file changed, 1 deletion(-) - -diff --git a/cmd/nvedit_efi.c b/cmd/nvedit_efi.c -index ca32566a61..e65b38dbf3 100644 ---- a/cmd/nvedit_efi.c -+++ b/cmd/nvedit_efi.c -@@ -80,7 +80,6 @@ static void efi_dump_single_var(u16 *name, efi_guid_t *guid) - printf(", DataSize = 0x%zx\n", size); - print_hex_dump(" ", DUMP_PREFIX_OFFSET, 16, 1, data, size, true); - -- return; - out: - free(data); - } --- -2.20.1 - -From d5974af7f7626777b5c41894f75c813ff35c1793 Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Tue, 19 Mar 2019 18:58:58 +0100 -Subject: [PATCH 05/25] efi_loader: remove superfluous check in - efi_setup_loaded_image() - -It does not make any sense to check if a pointer is NULL if we have -dereferenced it before. - -Reported-by: Coverity (CID 185827) -Signed-off-by: Heinrich Schuchardt ---- - lib/efi_loader/efi_boottime.c | 6 ++---- - 1 file changed, 2 insertions(+), 4 deletions(-) - -diff --git a/lib/efi_loader/efi_boottime.c b/lib/efi_loader/efi_boottime.c -index bd8b8a17ae..4fc550d9f3 100644 ---- a/lib/efi_loader/efi_boottime.c -+++ b/lib/efi_loader/efi_boottime.c -@@ -1581,10 +1581,8 @@ efi_status_t efi_setup_loaded_image(struct efi_device_path *device_path, - goto failure; - #endif - -- if (info_ptr) -- *info_ptr = info; -- if (handle_ptr) -- *handle_ptr = obj; -+ *info_ptr = info; -+ *handle_ptr = obj; - - return ret; - failure: --- -2.20.1 - -From 1646e0928c8eb052bfa2283a6ab8d9f2a92a10e9 Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Tue, 19 Mar 2019 19:16:23 +0100 -Subject: [PATCH 06/25] efi_loader: superfluous conversion in efi_file_open() - -printf("%ls", ..) expects u16 * as argument to print. There is not need for -a conversion to wchar_t *. - -Signed-off-by: Heinrich Schuchardt ---- - lib/efi_loader/efi_file.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/lib/efi_loader/efi_file.c b/lib/efi_loader/efi_file.c -index 3a7323765b..bc715218a1 100644 ---- a/lib/efi_loader/efi_file.c -+++ b/lib/efi_loader/efi_file.c -@@ -226,7 +226,7 @@ static efi_status_t EFIAPI efi_file_open(struct efi_file_handle *file, - efi_status_t ret; - - EFI_ENTRY("%p, %p, \"%ls\", %llx, %llu", file, new_handle, -- (wchar_t *)file_name, open_mode, attributes); -+ file_name, open_mode, attributes); - - /* Check parameters */ - if (!file || !new_handle || !file_name) { --- -2.20.1 - -From d0bd87612f410a723d5ddb3001e805485e3efb4f Mon Sep 17 00:00:00 2001 -From: Heinrich Schuchardt -Date: Tue, 19 Mar 2019 20:08:46 +0100 -Subject: [PATCH 07/25] efi_selftest: fix test_hii_string_get_string() - -The check testing the string result of get_string() returned the wrong -result. The result was ignored. - -Use efi_st_strcmp_16_8() for the string comparison. - -Signed-off-by: Heinrich Schuchardt ---- - lib/efi_selftest/efi_selftest_hii.c | 17 ++++------------- - 1 file changed, 4 insertions(+), 13 deletions(-) - -diff --git a/lib/efi_selftest/efi_selftest_hii.c b/lib/efi_selftest/efi_selftest_hii.c -index 8a0b3bc353..f4b70f7950 100644 ---- a/lib/efi_selftest/efi_selftest_hii.c -+++ b/lib/efi_selftest/efi_selftest_hii.c -@@ -783,19 +783,10 @@ static int test_hii_string_get_string(void) - goto out; - } - --#if 1 -- u16 *c1, *c2; -- -- for (c1 = string, c2 = L"Japanese"; *c1 == *c2; c1++, c2++) -- ; -- if (!*c1 && !*c2) -- result = EFI_ST_SUCCESS; -- else -- result = EFI_ST_FAILURE; --#else -- /* TODO: %ls */ -- efi_st_printf("got string is %s (can be wrong)\n", string); --#endif -+ if (efi_st_strcmp_16_8(string, "Japanese")) { -+ efi_st_error("get_string returned incorrect string\n"); -+ goto out; -+ } - - result = EFI_ST_SUCCESS; - --- -2.20.1 -