board: Add new Broadcom Northstar board
This adds a simple Northstar "BRCMNS" board to be used with the BCM4708x and BCM5301x chips. The main intention is to use this with the D-Link DIR-890L and DIR-885L routers for loading the kernel into RAM from NAND memory using the BCH-1 ECC and using the separately submitted SEAMA load command, so we are currently not adding support for things such as networking. The DTS file is a multiplatform NorthStar board, designed to be usable with several NorthStar designs by avoiding any particulars not related to the operation of U-Boot. If other board need other ECC for example, they need to create a separate DTS file and augment the code, but I don't know if any other users will turn up. Cc: Rafał Miłecki <rafal@milecki.pl> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
d3d9cd8ee1
commit
6f63c296fe
11 changed files with 275 additions and 0 deletions
|
@ -2285,6 +2285,7 @@ source "board/Marvell/octeontx2/Kconfig"
|
||||||
source "board/armltd/vexpress/Kconfig"
|
source "board/armltd/vexpress/Kconfig"
|
||||||
source "board/armltd/vexpress64/Kconfig"
|
source "board/armltd/vexpress64/Kconfig"
|
||||||
source "board/cortina/presidio-asic/Kconfig"
|
source "board/cortina/presidio-asic/Kconfig"
|
||||||
|
source "board/broadcom/bcmns/Kconfig"
|
||||||
source "board/broadcom/bcmns3/Kconfig"
|
source "board/broadcom/bcmns3/Kconfig"
|
||||||
source "board/cavium/thunderx/Kconfig"
|
source "board/cavium/thunderx/Kconfig"
|
||||||
source "board/eets/pdu001/Kconfig"
|
source "board/eets/pdu001/Kconfig"
|
||||||
|
|
|
@ -1200,6 +1200,8 @@ dtb-$(CONFIG_ARCH_BCM283X) += \
|
||||||
bcm2837-rpi-cm3-io3.dtb \
|
bcm2837-rpi-cm3-io3.dtb \
|
||||||
bcm2711-rpi-4-b.dtb
|
bcm2711-rpi-4-b.dtb
|
||||||
|
|
||||||
|
dtb-$(CONFIG_TARGET_BCMNS) += ns-board.dtb
|
||||||
|
|
||||||
dtb-$(CONFIG_TARGET_BCMNS3) += ns3-board.dtb
|
dtb-$(CONFIG_TARGET_BCMNS3) += ns3-board.dtb
|
||||||
|
|
||||||
dtb-$(CONFIG_ARCH_BCMSTB) += bcm7xxx.dtb
|
dtb-$(CONFIG_ARCH_BCMSTB) += bcm7xxx.dtb
|
||||||
|
|
57
arch/arm/dts/ns-board.dts
Normal file
57
arch/arm/dts/ns-board.dts
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
|
|
||||||
|
/dts-v1/;
|
||||||
|
|
||||||
|
#include "bcm5301x.dtsi"
|
||||||
|
|
||||||
|
/ {
|
||||||
|
/*
|
||||||
|
* The Northstar does not have a proper fallback compatible, but
|
||||||
|
* these basic chips will suffice.
|
||||||
|
*/
|
||||||
|
model = "Northstar model";
|
||||||
|
compatible = "brcm,bcm47094", "brcm,bcm4708";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
interrupt-parent = <&gic>;
|
||||||
|
|
||||||
|
memory {
|
||||||
|
device_type = "memory";
|
||||||
|
reg = <0x00000000 0x08000000>,
|
||||||
|
<0x88000000 0x08000000>;
|
||||||
|
};
|
||||||
|
|
||||||
|
aliases {
|
||||||
|
serial0 = &uart0;
|
||||||
|
};
|
||||||
|
|
||||||
|
chosen {
|
||||||
|
stdout-path = "serial0:115200n8";
|
||||||
|
};
|
||||||
|
|
||||||
|
nand-controller@18028000 {
|
||||||
|
nandcs: nand@0 {
|
||||||
|
compatible = "brcm,nandcs";
|
||||||
|
reg = <0>;
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Same as using the bcm5301x-nand-cs0-bch1.dtsi
|
||||||
|
* include from the Linux kernel.
|
||||||
|
*/
|
||||||
|
nand-ecc-algo = "bch";
|
||||||
|
nand-ecc-strength = <1>;
|
||||||
|
nand-ecc-step-size = <512>;
|
||||||
|
|
||||||
|
partitions {
|
||||||
|
compatible = "brcm,bcm947xx-cfe-partitions";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart0 {
|
||||||
|
clock-frequency = <125000000>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
12
board/broadcom/bcmns/Kconfig
Normal file
12
board/broadcom/bcmns/Kconfig
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
if TARGET_BCMNS
|
||||||
|
|
||||||
|
config SYS_BOARD
|
||||||
|
default "bcmns"
|
||||||
|
|
||||||
|
config SYS_VENDOR
|
||||||
|
default "broadcom"
|
||||||
|
|
||||||
|
config SYS_CONFIG_NAME
|
||||||
|
default "bcmns"
|
||||||
|
|
||||||
|
endif
|
6
board/broadcom/bcmns/MAINTAINERS
Normal file
6
board/broadcom/bcmns/MAINTAINERS
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
BCMNS BOARD
|
||||||
|
M: Linus Walleij <linus.walleij@linaro.org>
|
||||||
|
S: Maintained
|
||||||
|
F: board/broadcom/bcmnsp/
|
||||||
|
F: configs/bcmnsp_defconfig
|
||||||
|
F: include/configs/bcmnsp.h
|
2
board/broadcom/bcmns/Makefile
Normal file
2
board/broadcom/bcmns/Makefile
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
obj-y := ns.o
|
60
board/broadcom/bcmns/ns.c
Normal file
60
board/broadcom/bcmns/ns.c
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
|
/*
|
||||||
|
* Broadcom Northstar generic board set-up code
|
||||||
|
* Copyright (C) 2023 Linus Walleij <linus.walleij@linaro.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <common.h>
|
||||||
|
#include <dm.h>
|
||||||
|
#include <init.h>
|
||||||
|
#include <log.h>
|
||||||
|
#include <ram.h>
|
||||||
|
#include <serial.h>
|
||||||
|
#include <asm/global_data.h>
|
||||||
|
#include <asm/io.h>
|
||||||
|
#include <asm/armv7m.h>
|
||||||
|
|
||||||
|
DECLARE_GLOBAL_DATA_PTR;
|
||||||
|
|
||||||
|
int dram_init(void)
|
||||||
|
{
|
||||||
|
return fdtdec_setup_mem_size_base();
|
||||||
|
}
|
||||||
|
|
||||||
|
int dram_init_banksize(void)
|
||||||
|
{
|
||||||
|
return fdtdec_setup_memory_banksize();
|
||||||
|
}
|
||||||
|
|
||||||
|
int board_late_init(void)
|
||||||
|
{
|
||||||
|
/* LEDs etc can be initialized here */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int board_init(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void reset_cpu(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
int print_cpuinfo(void)
|
||||||
|
{
|
||||||
|
printf("BCMNS Northstar SoC\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int misc_init_r(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int ft_board_setup(void *fdt, struct bd_info *bd)
|
||||||
|
{
|
||||||
|
printf("Northstar board setup: DTB at 0x%08lx\n", (ulong)fdt);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
41
configs/bcmns_defconfig
Normal file
41
configs/bcmns_defconfig
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
CONFIG_ARM=y
|
||||||
|
CONFIG_TARGET_BCMNS=y
|
||||||
|
CONFIG_TEXT_BASE=0x00008000
|
||||||
|
CONFIG_SYS_MALLOC_LEN=0x2000000
|
||||||
|
CONFIG_SYS_MALLOC_F_LEN=0x8000
|
||||||
|
CONFIG_NR_DRAM_BANKS=2
|
||||||
|
CONFIG_DEFAULT_DEVICE_TREE="ns-board"
|
||||||
|
CONFIG_IDENT_STRING="Broadcom Northstar"
|
||||||
|
CONFIG_SYS_LOAD_ADDR=0x00008000
|
||||||
|
CONFIG_HAS_CUSTOM_SYS_INIT_SP_ADDR=y
|
||||||
|
CONFIG_CUSTOM_SYS_INIT_SP_ADDR=0x00100000
|
||||||
|
# CONFIG_BOOTSTD is not set
|
||||||
|
CONFIG_AUTOBOOT_KEYED=y
|
||||||
|
CONFIG_AUTOBOOT_PROMPT="Boot Northstar system in %d seconds\n"
|
||||||
|
CONFIG_BOOTDELAY=1
|
||||||
|
CONFIG_USE_BOOTCOMMAND=y
|
||||||
|
CONFIG_BOOTCOMMAND="run bootcmd_dlink_dir8xxl"
|
||||||
|
CONFIG_SYS_PROMPT="northstar> "
|
||||||
|
CONFIG_ENV_VARS_UBOOT_CONFIG=y
|
||||||
|
CONFIG_OF_BOARD_SETUP=y
|
||||||
|
CONFIG_OF_STDOUT_VIA_ALIAS=y
|
||||||
|
CONFIG_DISPLAY_BOARDINFO_LATE=y
|
||||||
|
CONFIG_HUSH_PARSER=y
|
||||||
|
CONFIG_SYS_MAXARGS=64
|
||||||
|
CONFIG_CMD_SEAMA=y
|
||||||
|
CONFIG_CMD_BOOTZ=y
|
||||||
|
CONFIG_CMD_CACHE=y
|
||||||
|
CONFIG_OF_EMBED=y
|
||||||
|
CONFIG_USE_HOSTNAME=y
|
||||||
|
CONFIG_HOSTNAME="NS"
|
||||||
|
CONFIG_CLK=y
|
||||||
|
CONFIG_MTD=y
|
||||||
|
CONFIG_DM_MTD=y
|
||||||
|
CONFIG_MTD_RAW_NAND=y
|
||||||
|
CONFIG_NAND_BRCMNAND=y
|
||||||
|
CONFIG_SYS_NAND_ONFI_DETECTION=y
|
||||||
|
CONFIG_CMD_NAND=y
|
||||||
|
CONFIG_DM_SERIAL=y
|
||||||
|
CONFIG_SYS_NS16550=y
|
||||||
|
# CONFIG_NET is not set
|
||||||
|
# CONFIG_EFI_LOADER is not set
|
|
@ -9,3 +9,4 @@ Broadcom
|
||||||
|
|
||||||
bcm7xxx
|
bcm7xxx
|
||||||
raspberrypi
|
raspberrypi
|
||||||
|
northstar
|
||||||
|
|
44
doc/board/broadcom/northstar.rst
Normal file
44
doc/board/broadcom/northstar.rst
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
.. SPDX-License-Identifier: GPL-2.0+
|
||||||
|
.. Copyright (C) 2023 Linus Walleij <linus.walleij@linaro.org>
|
||||||
|
|
||||||
|
Broadcom Northstar Boards
|
||||||
|
=========================
|
||||||
|
|
||||||
|
This document describes how to use U-Boot on the Broadcom Northstar
|
||||||
|
boards, comprised of the Cortex A9 ARM-based BCM470x and BCM5301x SoCs. These
|
||||||
|
were introduced in 2012-2013 and some of them are also called StrataGX.
|
||||||
|
|
||||||
|
Northstar is part of the iProc SoC family.
|
||||||
|
|
||||||
|
A good overview of these boards can be found in Jon Mason's presentation
|
||||||
|
"Enabling New Hardware in U-Boot" where the difference between Northstar
|
||||||
|
and Northstar Plus and Northstar 2 (Aarch64) is addressed.
|
||||||
|
|
||||||
|
The ROM in the Northstar SoC will typically look into NOR flash memory
|
||||||
|
for a boot loader, and the way this works is undocumented. It should be
|
||||||
|
possible to execute U-Boot as the first binary from the NOR flash but
|
||||||
|
this usage path is unexplored. Please add information if you know more.
|
||||||
|
|
||||||
|
D-Link Boards
|
||||||
|
-------------
|
||||||
|
|
||||||
|
When we use U-Boot with D-Link routers, the NOR flash has a boot loader
|
||||||
|
and web server that can re-flash the bigger NAND flash memory for object
|
||||||
|
code in the SEAMA format, so on these platforms U-Boot is converted into
|
||||||
|
a SEAMA binary and installed in the SoC using the flash tool resident in
|
||||||
|
the NOR flash. Details can be found in the OpenWrt project codebase.
|
||||||
|
|
||||||
|
Configure
|
||||||
|
---------
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ make CROSS_COMPILE=${CROSS_COMPILE} bcmns_defconfig
|
||||||
|
|
||||||
|
Build
|
||||||
|
-----
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ make CROSS_COMPILE=${CROSS_COMPILE}
|
||||||
|
$ ${CROSS_COMPILE}strip u-boot
|
49
include/configs/bcmns.h
Normal file
49
include/configs/bcmns.h
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
||||||
|
|
||||||
|
#ifndef __BCM_NS_H
|
||||||
|
#define __BCM_NS_H
|
||||||
|
|
||||||
|
#include <linux/sizes.h>
|
||||||
|
|
||||||
|
/* Physical Memory Map */
|
||||||
|
#define V2M_BASE 0x00000000
|
||||||
|
#define PHYS_SDRAM_1 V2M_BASE
|
||||||
|
|
||||||
|
#define CFG_SYS_SDRAM_BASE PHYS_SDRAM_1
|
||||||
|
|
||||||
|
/* Called "periph_clk" in Linux, used by the global timer */
|
||||||
|
#define CFG_SYS_HZ_CLOCK 500000000
|
||||||
|
|
||||||
|
/* Called "iprocslow" in Linux */
|
||||||
|
#define CFG_SYS_NS16550_CLK 125000000
|
||||||
|
|
||||||
|
/* console configuration */
|
||||||
|
#define CONSOLE_ARGS "console_args=console=ttyS0,115200n8\0"
|
||||||
|
#define MAX_CPUS "max_cpus=maxcpus=2\0"
|
||||||
|
#define EXTRA_ARGS "extra_args=earlycon=uart8250,mmio32,0x18000300\0"
|
||||||
|
|
||||||
|
#define BASE_ARGS "${console_args} ${extra_args} ${pcie_args}" \
|
||||||
|
" ${max_cpus} ${log_level} ${reserved_mem}"
|
||||||
|
#define SETBOOTARGS "setbootargs=setenv bootargs " BASE_ARGS "\0"
|
||||||
|
|
||||||
|
#define KERNEL_LOADADDR_CFG \
|
||||||
|
"loadaddr=0x01000000\0" \
|
||||||
|
"dtb_loadaddr=0x02000000\0"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Hardcoded for the only boards we support, if you add more
|
||||||
|
* boards, add a more clever bootcmd!
|
||||||
|
*/
|
||||||
|
#define NS_BOOTCMD "bootcmd_dlink_dir8xxl=seama 0x00fe0000; go 0x01000000"
|
||||||
|
|
||||||
|
#define ARCH_ENV_SETTINGS \
|
||||||
|
CONSOLE_ARGS \
|
||||||
|
MAX_CPUS \
|
||||||
|
EXTRA_ARGS \
|
||||||
|
KERNEL_LOADADDR_CFG \
|
||||||
|
NS_BOOTCMD
|
||||||
|
|
||||||
|
#define CFG_EXTRA_ENV_SETTINGS \
|
||||||
|
ARCH_ENV_SETTINGS
|
||||||
|
|
||||||
|
#endif /* __BCM_NS_H */
|
Loading…
Reference in a new issue