[openwrt/openwrt] uboot-mvebu: add support for MikroTik RB5009

LEDE Commits lede-commits at lists.infradead.org
Mon Jun 24 00:46:33 PDT 2024


robimarko pushed a commit to openwrt/openwrt.git, branch main:
https://git.openwrt.org/14bf60deb884b9466dc172ec5d12e5f515046a4a

commit 14bf60deb884b9466dc172ec5d12e5f515046a4a
Author: Robert Marko <robimarko at gmail.com>
AuthorDate: Sat Jun 8 10:25:29 2024 +0200

    uboot-mvebu: add support for MikroTik RB5009
    
    MikroTik RB5009 uses RouterBoot as its bootloader like all MikroTik devices
    running RouterOS, meaning that its not FIT compatible and can only boot
    ELF images.
    
    Now this is not so much of an issue on ARM or MIPS since kernel supports
    appending DTB-s to it (Or we patch the kernel to embed it), but on ARM64
    there is intentionally no such support.
    
    RouterBoot will pass a DTB, but its the broken MikroTik one which is a
    modified reference DTB and incorrect in more places than its valid so we
    cannot use it to boot our kernel.
    
    Thus, the solution is to use an intermediary loader and luckily for us
    Armada 7040 is well supported in U-Boot which makes it a great option since
    it supports anything that we will ever need to boot.
    
    Upstream U-Boot currently requires the Armada boards to be converted to
    OF_UPSTREAM before adding anything new and this requires updating all of
    the drivers to accomodate the Linux DTS, while I plan to do this eventually
    we will need to keep this board downstream for now.
    
    Most stuff is supported in U-Boot, including networking since the switch
    is preconfigured by RouterBoot.
    
    A custom environment is used to try and boot from the following devices:
    1. NAND (UBI)
    2. USB
    3. Networking
    
    If NAND boot fails then U-Boot will attempt to boot OpenWrt initramfs from
    USB or via networking.
    
    There is a manual recovery mechanism implemented where if the reset button
    is held when U-Boot is booting it will try to boot OpenWrt initramfs from:
    1. USB
    2. Networking
    
    When U-Boot is in recovery mode it will light all of the LED-s except the
    switch ones.
    
    Link: https://github.com/openwrt/openwrt/pull/15765
    Signed-off-by: Robert Marko <robimarko at gmail.com>
---
 package/boot/uboot-mvebu/Makefile                  |  11 +-
 ...-armada-8k-respect-CONFIG_DISTRO_DEFAULTS.patch |  38 ++
 .../101-net-mvpp2-fix-10GBase-R-support.patch      | 108 +++++
 ...bu-add-support-for-MikroTik-RB5009UG-S-IN.patch | 459 +++++++++++++++++++++
 4 files changed, 615 insertions(+), 1 deletion(-)

diff --git a/package/boot/uboot-mvebu/Makefile b/package/boot/uboot-mvebu/Makefile
index c92e7f4f19..535180f4c8 100644
--- a/package/boot/uboot-mvebu/Makefile
+++ b/package/boot/uboot-mvebu/Makefile
@@ -60,13 +60,22 @@ define U-Boot/eDPU
   BUILD_SUBTARGET:=cortexa53
 endef
 
+define U-Boot/rb5009
+  NAME:=MikroTik RB5009
+  BUILD_SUBTARGET:=cortexa72
+  BUILD_DEVICES:=mikrotik_rb5009
+  UBOOT_CONFIG:=mvebu_rb5009
+  UBOOT_IMAGE:=u-boot.elf
+endef
+
 UBOOT_TARGETS:= \
 	clearfog \
 	helios4 \
 	omnia \
 	espressobin \
 	uDPU \
-	eDPU
+	eDPU \
+	rb5009
 
 define Package/u-boot/install
 	$(if $(findstring cortexa53,$(BUILD_SUBTARGET)),,$(Package/u-boot/install/default))
diff --git a/package/boot/uboot-mvebu/patches/100-mvebu-armada-8k-respect-CONFIG_DISTRO_DEFAULTS.patch b/package/boot/uboot-mvebu/patches/100-mvebu-armada-8k-respect-CONFIG_DISTRO_DEFAULTS.patch
new file mode 100644
index 0000000000..f32f246022
--- /dev/null
+++ b/package/boot/uboot-mvebu/patches/100-mvebu-armada-8k-respect-CONFIG_DISTRO_DEFAULTS.patch
@@ -0,0 +1,38 @@
+From a322b1cbb3f3e606d33a11fd18df20811e5c16f2 Mon Sep 17 00:00:00 2001
+From: Robert Marko <robimarko at gmail.com>
+Date: Fri, 21 Jun 2024 11:41:30 +0200
+Subject: [PATCH 1/3] mvebu: armada-8k: respect CONFIG_DISTRO_DEFAULTS
+
+Currently, Armada 8k config header is setting boot devices and including
+<config_distro_bootcmd.h> regardless of the CONFIG_DISTRO_DEFAULTS being
+enabled or not, thus populating the environment for distro boot even on
+devices that have no need for it.
+
+So, lets simply respect the value of CONFIG_DISTRO_DEFAULTS.
+
+Signed-off-by: Robert Marko <robimarko at gmail.com>
+---
+ include/configs/mvebu_armada-8k.h | 5 ++++-
+ 1 file changed, 4 insertions(+), 1 deletion(-)
+
+--- a/include/configs/mvebu_armada-8k.h
++++ b/include/configs/mvebu_armada-8k.h
+@@ -30,7 +30,7 @@
+ /*
+  * PCI configuration
+  */
+-
++#ifdef CONFIG_DISTRO_DEFAULTS
+ #define BOOT_TARGET_DEVICES(func) \
+ 	func(MMC, mmc, 1) \
+ 	func(MMC, mmc, 0) \
+@@ -40,6 +40,9 @@
+ 	func(DHCP, dhcp, na)
+ 
+ #include <config_distro_bootcmd.h>
++#else
++#define BOOTENV
++#endif
+ 
+ #define CFG_EXTRA_ENV_SETTINGS	\
+ 	"scriptaddr=0x6d00000\0"	\
diff --git a/package/boot/uboot-mvebu/patches/101-net-mvpp2-fix-10GBase-R-support.patch b/package/boot/uboot-mvebu/patches/101-net-mvpp2-fix-10GBase-R-support.patch
new file mode 100644
index 0000000000..eb7bbdbf48
--- /dev/null
+++ b/package/boot/uboot-mvebu/patches/101-net-mvpp2-fix-10GBase-R-support.patch
@@ -0,0 +1,108 @@
+From 0de5d031f36bca4f7c2686287eff1ef0f5412367 Mon Sep 17 00:00:00 2001
+From: Sergey Sergeev <adron at yapic.net>
+Date: Sun, 16 Jan 2022 17:19:35 +0100
+Subject: [PATCH 2/3] net: mvpp2: fix 10GBase-R support
+
+Due to the lack of XPCS register initialization code and partially incorrect
+initialization of the MPCS network controler registers (tested on Mikrotik RB5009
+in conjunction with MV88E6393X) the network does not work correctly.
+The problem manifests itself as an arbitrary delay (0.4-4 sec) for the actual
+data transmission to the network! Accordingly, an almost completely non-working
+network for U-Boot is obtained. The code is backported from a similar Linux driver.
+
+Signed-off-by: Sergey Sergeev <adron at yapic.net>
+Signed-off-by: Robert Marko <robimarko at gmail.com>
+---
+ drivers/net/mvpp2.c | 73 +++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 73 insertions(+)
+
+--- a/drivers/net/mvpp2.c
++++ b/drivers/net/mvpp2.c
+@@ -3255,6 +3255,76 @@ static int gop_gpcs_reset(struct mvpp2_p
+ 	return 0;
+ }
+ 
++static void gop_pcs_reset_assert(struct mvpp2_port *port)
++{
++	u32 val;
++
++	if (port->priv->hw_version == MVPP21 || port->gop_id != 0)
++		return;
++
++	val = readl(port->priv->mpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		PCS_CLOCK_RESET);
++	val &= ~(MAC_CLK_RESET_MASK | RX_SD_CLK_RESET_MASK | TX_SD_CLK_RESET_MASK);
++	val |= CLK_DIV_PHASE_SET_MASK;
++	writel(val, port->priv->mpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		PCS_CLOCK_RESET);
++
++	val = readl(port->priv->xpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		MVPP22_XPCS_GLOBAL_CFG_0_REG);
++	val &= ~MVPP22_XPCS_PCSRESET;
++	writel(val,	port->priv->xpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		MVPP22_XPCS_GLOBAL_CFG_0_REG);
++}
++
++static void gps_pcs_reset_deassert(struct mvpp2_port *port)
++{
++	u32 val;
++
++	if (port->priv->hw_version == MVPP21 || port->gop_id != 0)
++		return;
++
++	/* this code is only for case of PHY_INTERFACE_MODE_10GBASER! */
++	val = readl(port->priv->mpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		PCS_CLOCK_RESET);
++	val |= MAC_CLK_RESET_MASK | RX_SD_CLK_RESET_MASK |
++	       TX_SD_CLK_RESET_MASK;
++	val &= ~CLK_DIV_PHASE_SET_MASK;
++	writel(val, port->priv->mpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		PCS_CLOCK_RESET);
++}
++
++/* Set the internal mux's to the required PCS in the PI */
++static int gop_xpcs_mode(struct mvpp2_port *port, int num_of_lanes)
++{
++	u32 val;
++	int lane;
++
++	switch (num_of_lanes) {
++	case 1:
++		lane = 0;
++		break;
++	case 2:
++		lane = 1;
++		break;
++	case 4:
++		lane = 2;
++		break;
++	default:
++		return -1;
++	}
++
++	/* configure XG MAC mode */
++	val = readl(port->priv->xpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		MVPP22_XPCS_GLOBAL_CFG_0_REG);
++	val &= ~MVPP22_XPCS_PCSMODE_MASK;
++	val &= ~MVPP22_XPCS_LANEACTIVE_MASK;
++	val |= (2 * lane) << MVPP22_XPCS_LANEACTIVE_OFFS;
++	writel(val, port->priv->xpcs_base + port->gop_id * MVPP22_PORT_OFFSET +
++		MVPP22_XPCS_GLOBAL_CFG_0_REG);
++
++	return 0;
++}
++
+ static int gop_mpcs_mode(struct mvpp2_port *port)
+ {
+ 	u32 val;
+@@ -3397,7 +3467,10 @@ static int gop_port_init(struct mvpp2_po
+ 		num_of_act_lanes = 2;
+ 		mac_num = 0;
+ 		/* configure PCS */
++		gop_pcs_reset_assert(port);
++		gop_xpcs_mode(port, num_of_act_lanes);
+ 		gop_mpcs_mode(port);
++		gps_pcs_reset_deassert(port);
+ 		/* configure MAC */
+ 		gop_xlg_mac_mode_cfg(port, num_of_act_lanes);
+ 
diff --git a/package/boot/uboot-mvebu/patches/102-arm-mvebu-add-support-for-MikroTik-RB5009UG-S-IN.patch b/package/boot/uboot-mvebu/patches/102-arm-mvebu-add-support-for-MikroTik-RB5009UG-S-IN.patch
new file mode 100644
index 0000000000..b1b94cc566
--- /dev/null
+++ b/package/boot/uboot-mvebu/patches/102-arm-mvebu-add-support-for-MikroTik-RB5009UG-S-IN.patch
@@ -0,0 +1,459 @@
+From 163b07bda901b728f4f208a296c15b513f9d5b49 Mon Sep 17 00:00:00 2001
+From: Robert Marko <robimarko at gmail.com>
+Date: Sun, 2 Jan 2022 15:10:34 +0100
+Subject: [PATCH 3/3] arm: mvebu: add support for MikroTik RB5009UG+S+IN
+
+Specifications:
+  - SoC: Marvell Armada 7040 (88F7040) - 4 cores, ARMv8, 1.4GHz, 64bit
+  - RAM: 1024MB DDR4
+  - Flash: 16MB SPI NOR flash, 1024MB NAND
+  - Ethernet: One Marvell 88E6393X - Amethyst: one 2.5G + seven 1G ports and one SFP+
+  - LED: User, SFP, Hdr1, Hdr2
+  - Buttons: Reset
+  - UART: 115200 8n1
+  - USB: One USB3 port
+
+This provides only the basic support required to boot OpenWrt, however
+networking via the switch also works since its preconfigured by MikroTik
+RouterBoot since we are using U-Boot as the secondary bootloader.
+
+Signed-off-by: Robert Marko <robimarko at gmail.com>
+---
+ arch/arm/dts/Makefile                         |   1 +
+ arch/arm/dts/armada-7040-rb5009.dts           | 241 ++++++++++++++++++
+ arch/arm/mach-mvebu/arm64-common.c            |  10 +-
+ .../mvebu_armada-8k/mikrotik-rb5009.env       |  52 ++++
+ configs/mvebu_rb5009_defconfig                |  97 +++++++
+ 5 files changed, 398 insertions(+), 3 deletions(-)
+ create mode 100644 arch/arm/dts/armada-7040-rb5009.dts
+ create mode 100644 board/Marvell/mvebu_armada-8k/mikrotik-rb5009.env
+ create mode 100644 configs/mvebu_rb5009_defconfig
+
+--- a/arch/arm/dts/Makefile
++++ b/arch/arm/dts/Makefile
+@@ -333,6 +333,7 @@ dtb-$(CONFIG_ARCH_MVEBU) +=			\
+ 	armada-3720-uDPU.dtb			\
+ 	armada-7040-db-nand.dtb			\
+ 	armada-7040-db.dtb			\
++	armada-7040-rb5009.dtb			\
+ 	armada-8040-clearfog-gt-8k.dtb		\
+ 	armada-8040-db.dtb			\
+ 	armada-8040-mcbin.dtb			\
+--- /dev/null
++++ b/arch/arm/dts/armada-7040-rb5009.dts
+@@ -0,0 +1,241 @@
++// SPDX-License-Identifier: GPL-2.0+
++/*
++ * Copyright (C) 2016- 2021 Marvell International Ltd.
++ */
++
++/*
++ * Device Tree file for MikroTik RB5009
++ * Boot device: SPI NOR, 0x0
++ */
++
++#include "armada-7040.dtsi"
++#include <dt-bindings/gpio/gpio.h>
++#include <dt-bindings/input/input.h>
++
++/ {
++	model = "MikroTik RB5009";
++	compatible = "mikrotik,rb5009", "marvell,armada7040",
++		     "marvell,armada-ap806-quad", "marvell,armada-ap806";
++
++	chosen {
++		stdout-path = "serial0:115200n8";
++	};
++
++	memory at 00000000 {
++		device_type = "memory";
++		reg = <0x0 0x0 0x0 0x40000000>;
++	};
++
++	leds {
++		compatible = "gpio-leds";
++
++		led_user: user {
++			label = "green:user";
++			gpios = <&cp0_gpio1 26 GPIO_ACTIVE_LOW>;
++			default-state = "on";
++		};
++
++		sfp {
++			label = "green:sfp";
++			gpios = <&cp0_gpio1 25 GPIO_ACTIVE_LOW>;
++		};
++
++		hdr1 {
++			label = "blue:hdr1";
++			gpios = <&cp0_gpio0 4 GPIO_ACTIVE_LOW>;
++		};
++
++		hdr2 {
++			label = "blue:hdr2";
++			gpios = <&cp0_gpio1 19 GPIO_ACTIVE_LOW>;
++		};
++	};
++
++	keys {
++		compatible = "gpio-keys";
++
++		reset {
++			label = "reset";
++			gpios = <&cp0_gpio0 28 GPIO_ACTIVE_LOW>;
++			linux,code = <KEY_RESTART>;
++		};
++	};
++};
++
++&ap_pinctl {
++	   /* MPP Bus:
++	    * SPI   [0-3]
++	    * UART0 [11,19]
++	    */
++		  /* 0 1 2 3 4 5 6 7 8 9 */
++	pin-func = < 3 3 3 3 0 0 0 0 0 0
++		     0 3 0 0 0 0 0 0 0 3 >;
++
++	ap_spi_pins: ap-spi-pins {
++		marvell,pins = < 0 1 2 3 >;
++		marvell,function = <3>;
++	};
++};
++
++&uart0 {
++	status = "okay";
++};
++
++&ap_spi0 {
++	status = "okay";
++	pinctrl-names = "default";
++	pinctrl-0 = <&ap_spi_pins>;
++
++	spi-flash at 0 {
++		#address-cells = <0x1>;
++		#size-cells = <0x1>;
++		compatible = "jedec,spi-nor";
++		reg = <0x0>;
++		spi-max-frequency = <20000000>;
++
++		partitions {
++			compatible = "fixed-partitions";
++			#address-cells = <1>;
++			#size-cells = <1>;
++
++			/* Empty space on NOR repurposed for U-Boot environment */
++			partition at fe0000 {
++				compatible = "u-boot,env";
++				label = "u-boot-env";
++				reg = <0xfe0000 0x20000>;
++			};
++		};
++	};
++};
++
++&cp0_pinctl {
++		/* MPP Bus:
++		 * NF_RBn  [13]
++		 * DEV_BUS [15-27]
++		 * UART0   [29,30]
++		 * SMI     [35,36]
++		 * I2C0    [37,38]
++		 * SPI1    [47-50]
++		 */
++		/*   0   1   2   3   4   5   6   7   8   9 */
++	pin-func = < 0   0   0   0   0   0   0   0   0   0
++		     0   0   0   2   0   1   1   1   1   1
++		     1   1   1   1   1   1   1   1   0   0xA
++		     0xA 0   0   0   0   8   8   2   2   0
++		     0   0   0   0   0   0   0   5   5   5
++		     5   0   0   0   0   0   0   0   0   0
++		     0   0   0 >;
++
++	cp0_nand_pins: cp0-nand-pins {
++		marvell,pins = < 15 16 17 18 19 20 21 22 23 24 25 26 27 >;
++		marvell,function = <1>;
++	};
++
++	cp0_smi_pins: cp0-smi-pins {
++		marvell,pins = < 35 36 >;
++		marvell,function = <8>;
++	};
++
++	cp0_spi1_pins: cp0-spi-pins-1 {
++		marvell,pins = < 47 48 49 50 >;
++		marvell,function = <5>;
++	};
++};
++
++&cp0_gpio1 {
++	enable-usb-power {
++		gpio-hog;
++		gpios = <23 GPIO_ACTIVE_HIGH>;
++		output-high;
++		line-name = "enable USB power";
++	};
++
++	enable-leds-power {
++		gpio-hog;
++		gpios = <27 GPIO_ACTIVE_HIGH>;
++		output-high;
++		line-name = "enable LED-s power";
++	};
++};
++
++&cp0_nand {
++	status = "okay";
++
++	pinctrl-names = "default";
++	pinctrl-0 = <&cp0_nand_pins>;
++
++	nand-ecc-strength = <4>;
++
++	partitions {
++		compatible = "fixed-partitions";
++		#address-cells = <1>;
++		#size-cells = <1>;
++
++		partition at 0 {
++			label = "YAFFS";
++			reg = <0x0 0x800000>;
++		};
++
++		partition at 800000 {
++			label = "ubi";
++			reg = <0x800000 0x3f800000>;
++		};
++	};
++};
++
++&cp0_usb3_1 {
++	status = "okay";
++};
++
++&cp0_utmi1 {
++	status = "okay";
++};
++
++&cp0_i2c0 {
++	status = "okay";
++
++	pinctrl-names = "default";
++	pinctrl-0 = <&cp0_i2c0_pins>;
++	clock-frequency = <100000>;
++};
++
++&cp0_comphy {
++	phy0 {
++		phy-type = <COMPHY_TYPE_UNCONNECTED>;
++	};
++
++	phy1 {
++		phy-type = <COMPHY_TYPE_UNCONNECTED>;
++	};
++
++	phy2 {
++		phy-type = <COMPHY_TYPE_SFI0>;
++		phy-speed = <COMPHY_SPEED_10_3125G>;
++	};
++
++	phy3 {
++		phy-type = <COMPHY_TYPE_USB3_HOST1>;
++		phy-speed = <COMPHY_SPEED_5G>;
++	};
++
++	phy4 {
++		phy-type = <COMPHY_TYPE_UNCONNECTED>;
++	};
++
++	phy5 {
++		phy-type = <COMPHY_TYPE_UNCONNECTED>;
++	};
++};
++
++&cp0_mdio {
++	status = "okay";
++};
++
++&cp0_ethernet {
++	status = "okay";
++};
++
++&cp0_eth0 {
++	status = "okay";
++	phy-mode = "10gbase-r";
++};
+--- a/arch/arm/mach-mvebu/arm64-common.c
++++ b/arch/arm/mach-mvebu/arm64-common.c
+@@ -62,9 +62,13 @@ __weak int dram_init_banksize(void)
+ __weak int dram_init(void)
+ {
+ 	if (IS_ENABLED(CONFIG_ARMADA_8K)) {
+-		gd->ram_size = a8k_dram_scan_ap_sz();
+-		if (gd->ram_size != 0)
+-			return 0;
++		if (of_machine_is_compatible("mikrotik,rb5009"))
++			return fdtdec_setup_mem_size_base();
++		else {
++			gd->ram_size = a8k_dram_scan_ap_sz();
++			if (gd->ram_size != 0)
++				return 0;
++		}
+ 	}
+ 
+ 	if (IS_ENABLED(CONFIG_ARMADA_3700))
+--- /dev/null
++++ b/board/Marvell/mvebu_armada-8k/mikrotik-rb5009.env
+@@ -0,0 +1,52 @@
++openwrt_initramfs=openwrt-mvebu-cortexa72-mikrotik_rb5009-initramfs-uImage.itb
++boot_devices=ubi usb net
++recovery_boot_devices=usb net
++
++button_cmd_0_name=reset
++button_cmd_0=run recovery_bootcmd
++
++recovery_bootcmd=
++	led green:sfp on;
++	led blue:hdr1 on;
++	led blue:hdr2 on;
++
++	for b in ${recovery_boot_devices}; do
++		if test ${b} = usb; then
++			run usbboot;
++		fi;
++		if test ${b} = net; then
++			run netboot;
++		fi;
++	done;
++
++bootcmd=
++	for b in ${boot_devices}; do
++		if test ${b} = ubi; then
++			run ubiboot;
++		fi;
++		if test ${b} = usb; then
++			run usbboot;
++		fi;
++		if test ${b} = net; then
++			run netboot;
++		fi;
++	done;
++
++ubiboot=
++	echo Booting from NAND (UBI);
++	ubi part ubi;
++	setenv loadimagecmd ${ubiloadimage};
++	ubi read ${loadaddr} kernel;
++	bootm ${loadaddr};
++
++usbboot=
++	echo Booting from USB Storage;
++	usb start;
++	load usb 0:1 ${loadaddr} ${openwrt_initramfs};
++	bootm ${loadaddr};
++
++netboot=
++	echo Booting from Network;
++	dhcp;
++	tftpboot ${loadaddr} ${openwrt_initramfs};
++	bootm ${loadaddr};
+--- /dev/null
++++ b/configs/mvebu_rb5009_defconfig
+@@ -0,0 +1,97 @@
++CONFIG_ARM=y
++CONFIG_ARCH_CPU_INIT=y
++CONFIG_ARCH_MVEBU=y
++CONFIG_TEXT_BASE=0x0
++CONFIG_NR_DRAM_BANKS=2
++CONFIG_ENV_SOURCE_FILE="mikrotik-rb5009"
++CONFIG_HAS_CUSTOM_SYS_INIT_SP_ADDR=y
++CONFIG_CUSTOM_SYS_INIT_SP_ADDR=0xff0000
++CONFIG_TARGET_MVEBU_ARMADA_8K=y
++CONFIG_ENV_SIZE=0x20000
++CONFIG_ENV_OFFSET=0xfe0000
++CONFIG_ENV_SECT_SIZE=0x10000
++CONFIG_DM_GPIO=y
++CONFIG_DEFAULT_DEVICE_TREE="armada-7040-rb5009"
++CONFIG_DEBUG_UART_BASE=0xf0512000
++CONFIG_DEBUG_UART_CLOCK=200000000
++CONFIG_SYS_LOAD_ADDR=0x800000
++CONFIG_DEBUG_UART=y
++# CONFIG_SYS_MALLOC_CLEAR_ON_INIT is not set
++CONFIG_REMAKE_ELF=y
++CONFIG_BUTTON_CMD=y
++CONFIG_FIT=y
++CONFIG_FIT_VERBOSE=y
++# CONFIG_BOOTSTD is not set
++CONFIG_SUPPORT_RAW_INITRD=y
++CONFIG_BOOTDELAY=5
++CONFIG_SYS_CONSOLE_INFO_QUIET=y
++CONFIG_LOG=y
++CONFIG_LOG_ERROR_RETURN=y
++# CONFIG_DISPLAY_CPUINFO is not set
++# CONFIG_DISPLAY_BOARDINFO is not set
++CONFIG_DISPLAY_BOARDINFO_LATE=y
++CONFIG_BOARD_EARLY_INIT_F=y
++CONFIG_HUSH_PARSER=y
++CONFIG_CMD_GPIO=y
++CONFIG_CMD_I2C=y
++CONFIG_CMD_MMC=y
++CONFIG_CMD_MTD=y
++CONFIG_CMD_PART=y
++CONFIG_CMD_PCI=y
++CONFIG_CMD_SPI=y
++CONFIG_CMD_USB=y
++# CONFIG_CMD_SETEXPR is not set
++CONFIG_CMD_DHCP=y
++CONFIG_CMD_TFTPPUT=y
++CONFIG_CMD_MII=y
++CONFIG_CMD_PING=y
++CONFIG_CMD_PXE=y
++CONFIG_CMD_CACHE=y
++CONFIG_CMD_TIME=y
++CONFIG_CMD_SYSBOOT=y
++CONFIG_CMD_EXT4=y
++CONFIG_CMD_EXT4_WRITE=y
++CONFIG_CMD_FAT=y
++CONFIG_CMD_FS_GENERIC=y
++CONFIG_CMD_UBI=y
++CONFIG_EFI_PARTITION=y
++CONFIG_ENV_OVERWRITE=y
++CONFIG_ENV_IS_IN_SPI_FLASH=y
++CONFIG_SYS_RELOC_GD_ENV_ADDR=y
++CONFIG_NET_RANDOM_ETHADDR=y
++CONFIG_BUTTON=y
++CONFIG_BUTTON_GPIO=y
++CONFIG_GPIO_HOG=y
++CONFIG_DM_I2C=y
++CONFIG_SYS_I2C_MVTWSI=y
++CONFIG_LED=y
++CONFIG_LED_GPIO=y
++CONFIG_MISC=y
++CONFIG_MTD_RAW_NAND=y
++CONFIG_SYS_NAND_USE_FLASH_BBT=y
++CONFIG_NAND_PXA3XX=y
++CONFIG_SYS_NAND_ONFI_DETECTION=y
++CONFIG_SPI_FLASH_SFDP_SUPPORT=y
++CONFIG_SPI_FLASH_WINBOND=y
++# CONFIG_SPI_FLASH_USE_4K_SECTORS is not set
++CONFIG_SPI_FLASH_MTD=y
++CONFIG_PHY_MARVELL=y
++CONFIG_PHY_GIGE=y
++CONFIG_MVPP2=y
++CONFIG_PHY=y
++CONFIG_MVEBU_COMPHY_SUPPORT=y
++CONFIG_PINCTRL=y
++CONFIG_PINCTRL_ARMADA_8K=y
++CONFIG_DEBUG_UART_SHIFT=2
++CONFIG_DEBUG_UART_ANNOUNCE=y
++CONFIG_SYS_NS16550=y
++CONFIG_KIRKWOOD_SPI=y
++CONFIG_USB=y
++CONFIG_USB_XHCI_HCD=y
++CONFIG_USB_EHCI_HCD=y
++CONFIG_USB_STORAGE=y
++CONFIG_USB_HOST_ETHER=y
++CONFIG_USB_ETHER_RTL8152=y
++CONFIG_YAFFS2=y
++# CONFIG_SHA256 is not set
++# CONFIG_EFI_LOADER is not set




More information about the lede-commits mailing list