blob: 17ebccd2c4bb9078a6cd54e52b6bff87e237e730 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Carlo Caione72ad9032016-06-10 20:18:22 +02002/*
Jerome Brunet32bacc52018-10-25 16:41:37 +02003 * Configuration for Amlogic Meson 64bits SoCs
Carlo Caione72ad9032016-06-10 20:18:22 +02004 * (C) Copyright 2016 Beniamino Galvani <b.galvani@gmail.com>
Carlo Caione72ad9032016-06-10 20:18:22 +02005 */
6
Jerome Brunet32bacc52018-10-25 16:41:37 +02007#ifndef __MESON64_CONFIG_H
8#define __MESON64_CONFIG_H
9
10/* Generic Interrupt Controller Definitions */
Anand Moonc51afd92019-12-26 11:33:52 +000011#if (defined(CONFIG_MESON_AXG) || defined(CONFIG_MESON_G12A))
Neil Armstrong0fca9232018-09-05 15:56:12 +020012#define GICD_BASE 0xffc01000
13#define GICC_BASE 0xffc02000
14#else /* MESON GXL and GXBB */
Jerome Brunet32bacc52018-10-25 16:41:37 +020015#define GICD_BASE 0xc4301000
16#define GICC_BASE 0xc4302000
Neil Armstrong0fca9232018-09-05 15:56:12 +020017#endif
Carlo Caione72ad9032016-06-10 20:18:22 +020018
Neil Armstrong07fccdb2018-07-26 11:45:46 +020019/* For splashscreen */
20#ifdef CONFIG_DM_VIDEO
Neil Armstrong07fccdb2018-07-26 11:45:46 +020021#define STDOUT_CFG "vidconsole,serial"
22#else
23#define STDOUT_CFG "serial"
24#endif
25
26#ifdef CONFIG_USB_KEYBOARD
27#define STDIN_CFG "usbkbd,serial"
Neil Armstrong07fccdb2018-07-26 11:45:46 +020028#else
29#define STDIN_CFG "serial"
30#endif
31
Carlo Caione72ad9032016-06-10 20:18:22 +020032#define CONFIG_CPU_ARMV8
33#define CONFIG_REMAKE_ELF
Carlo Caione72ad9032016-06-10 20:18:22 +020034#define CONFIG_SYS_MAXARGS 32
35#define CONFIG_SYS_MALLOC_LEN (32 << 20)
36#define CONFIG_SYS_CBSIZE 1024
Carlo Caione72ad9032016-06-10 20:18:22 +020037
38#define CONFIG_SYS_SDRAM_BASE 0
Carlo Caione72ad9032016-06-10 20:18:22 +020039#define CONFIG_SYS_INIT_SP_ADDR 0x20000000
40#define CONFIG_SYS_LOAD_ADDR CONFIG_SYS_TEXT_BASE
Jerome Brunet32bacc52018-10-25 16:41:37 +020041#define CONFIG_SYS_BOOTM_LEN (64 << 20) /* 64 MiB */
Carlo Caione72ad9032016-06-10 20:18:22 +020042
Neil Armstrong2fbfcbb2018-07-27 14:10:00 +020043/* ROM USB boot support, auto-execute boot.scr at scriptaddr */
44#define BOOTENV_DEV_ROMUSB(devtypeu, devtypel, instance) \
45 "bootcmd_romusb=" \
46 "if test \"${boot_source}\" = \"usb\" && " \
47 "test -n \"${scriptaddr}\"; then " \
48 "echo '(ROM USB boot)'; " \
49 "source ${scriptaddr}; " \
50 "fi\0"
51
52#define BOOTENV_DEV_NAME_ROMUSB(devtypeu, devtypel, instance) \
53 "romusb "
54
Neil Armstrong42fe74e2018-06-14 13:43:38 +020055#ifdef CONFIG_CMD_USB
56#define BOOT_TARGET_DEVICES_USB(func) func(USB, usb, 0)
57#else
58#define BOOT_TARGET_DEVICES_USB(func)
59#endif
60
Neil Armstrong311b2d62021-02-26 15:17:36 +010061#ifdef CONFIG_CMD_NVME
62 #define BOOT_TARGET_NVME(func) func(NVME, nvme, 0)
63#else
64 #define BOOT_TARGET_NVME(func)
65#endif
66
Jerome Brunet32bacc52018-10-25 16:41:37 +020067#ifndef BOOT_TARGET_DEVICES
Andreas Färberd1296682017-01-15 20:22:30 +010068#define BOOT_TARGET_DEVICES(func) \
Neil Armstrong2fbfcbb2018-07-27 14:10:00 +020069 func(ROMUSB, romusb, na) \
xypron.glpk@gmx.de787b5d12017-04-15 21:30:39 +020070 func(MMC, mmc, 0) \
71 func(MMC, mmc, 1) \
72 func(MMC, mmc, 2) \
Neil Armstrong42fe74e2018-06-14 13:43:38 +020073 BOOT_TARGET_DEVICES_USB(func) \
Neil Armstrong311b2d62021-02-26 15:17:36 +010074 BOOT_TARGET_NVME(func) \
Vagrant Cascadian69d4b992017-05-05 14:11:26 -070075 func(PXE, pxe, na) \
Andreas Färberd1296682017-01-15 20:22:30 +010076 func(DHCP, dhcp, na)
Jerome Brunet32bacc52018-10-25 16:41:37 +020077#endif
Andreas Färberd1296682017-01-15 20:22:30 +010078
Jaehoon Chung0d5071e2020-11-02 12:07:06 +090079#include <config_distro_bootcmd.h>
80
Jerome Brunet32bacc52018-10-25 16:41:37 +020081#ifndef CONFIG_EXTRA_ENV_SETTINGS
Andreas Färberd1296682017-01-15 20:22:30 +010082#define CONFIG_EXTRA_ENV_SETTINGS \
Neil Armstrong07fccdb2018-07-26 11:45:46 +020083 "stdin=" STDIN_CFG "\0" \
84 "stdout=" STDOUT_CFG "\0" \
85 "stderr=" STDOUT_CFG "\0" \
Jerome Brunet7c3ca352018-10-24 16:27:51 +020086 "fdt_addr_r=0x08008000\0" \
87 "scriptaddr=0x08000000\0" \
88 "kernel_addr_r=0x08080000\0" \
Andreas Färberd1296682017-01-15 20:22:30 +010089 "pxefile_addr_r=0x01080000\0" \
Neil Armstrong0ddb48e2021-02-10 15:22:13 +010090 "fdtoverlay_addr_r=0x01000000\0" \
xypron.glpk@gmx.de840e0af2017-04-14 20:04:46 +020091 "ramdisk_addr_r=0x13000000\0" \
Jerome Brunetff5ce032018-10-19 12:00:51 +020092 "fdtfile=amlogic/" CONFIG_DEFAULT_DEVICE_TREE ".dtb\0" \
Andreas Färberd1296682017-01-15 20:22:30 +010093 BOOTENV
Jerome Brunet32bacc52018-10-25 16:41:37 +020094#endif
Andreas Färberd1296682017-01-15 20:22:30 +010095
xypron.glpk@gmx.de07fee662017-04-14 19:54:40 +020096
Jerome Brunet32bacc52018-10-25 16:41:37 +020097#endif /* __MESON64_CONFIG_H */