blob: 45bd94ee5c76f3965d62788366ddf8c271d22176 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +03002/*
3 * Copyright (c) 2017 Tuomas Tynkkynen
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +03004 */
5
6#ifndef __CONFIG_H
7#define __CONFIG_H
8
9#include <linux/sizes.h>
10
11/* Physical memory map */
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030012
Tom Rinibb4dd962022-11-16 13:10:37 -050013#define CFG_SYS_SDRAM_BASE 0x40000000
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030014
Sughosh Ganuccb36462022-04-15 11:29:34 +053015/* GUIDs for capsule updatable firmware images */
16#define QEMU_ARM_UBOOT_IMAGE_GUID \
17 EFI_GUID(0xf885b085, 0x99f8, 0x45af, 0x84, 0x7d, \
18 0xd5, 0x14, 0x10, 0x7a, 0x4a, 0x2c)
19
20#define QEMU_ARM64_UBOOT_IMAGE_GUID \
21 EFI_GUID(0x058b7d83, 0x50d5, 0x4c47, 0xa1, 0x95, \
22 0x60, 0xd8, 0x6a, 0xd3, 0x41, 0xc4)
23
Andre Przywaraec1ba0f2022-10-10 18:01:22 +010024/* Try files from QEMU's -kernel/-initrd, through the QEMU firmware device. */
25#define BOOTENV_DEV_QFW(devtypeu, devtypel, instance) \
26 "bootcmd_qfw= " \
27 "if qfw load $kernel_addr_r $ramdisk_addr_r; then " \
28 " booti $kernel_addr_r $ramdisk_addr_r:$filesize $fdtcontroladdr; " \
29 " if test $? -eq 1; then " \
30 " bootz $kernel_addr_r $ramdisk_addr_r:$filesize $fdtcontroladdr; " \
31 " fi ; " \
32 "fi\0"
33#define BOOTENV_DEV_NAME_QFW(devtypeu, devtypel, instance) "qfw "
34
Tuomas Tynkkynen047a4752018-04-12 04:24:45 +030035/* For timer, QEMU emulates an ARMv7/ARMv8 architected timer */
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030036
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030037/* Environment options */
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030038
Piotr Kubikf580a302021-12-29 14:30:04 +010039#if CONFIG_IS_ENABLED(CMD_USB)
40# define BOOT_TARGET_USB(func) func(USB, usb, 0)
41#else
42# define BOOT_TARGET_USB(func)
43#endif
44
45#if CONFIG_IS_ENABLED(CMD_SCSI)
46# define BOOT_TARGET_SCSI(func) func(SCSI, scsi, 0)
47#else
48# define BOOT_TARGET_SCSI(func)
49#endif
50
51#if CONFIG_IS_ENABLED(CMD_VIRTIO)
52# define BOOT_TARGET_VIRTIO(func) func(VIRTIO, virtio, 0)
53#else
54# define BOOT_TARGET_VIRTIO(func)
55#endif
56
Alexander Graf3636a9c2022-02-27 13:20:32 +010057#if CONFIG_IS_ENABLED(CMD_NVME)
58# define BOOT_TARGET_NVME(func) func(NVME, nvme, 0)
59#else
60# define BOOT_TARGET_NVME(func)
61#endif
62
Piotr Kubikf580a302021-12-29 14:30:04 +010063#if CONFIG_IS_ENABLED(CMD_DHCP)
64# define BOOT_TARGET_DHCP(func) func(DHCP, dhcp, na)
65#else
66# define BOOT_TARGET_DHCP(func)
67#endif
68
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030069#define BOOT_TARGET_DEVICES(func) \
Andre Przywaraec1ba0f2022-10-10 18:01:22 +010070 func(QFW, qfw, na) \
Piotr Kubikf580a302021-12-29 14:30:04 +010071 BOOT_TARGET_USB(func) \
72 BOOT_TARGET_SCSI(func) \
73 BOOT_TARGET_VIRTIO(func) \
Alexander Graf3636a9c2022-02-27 13:20:32 +010074 BOOT_TARGET_NVME(func) \
Piotr Kubikf580a302021-12-29 14:30:04 +010075 BOOT_TARGET_DHCP(func)
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030076
77#include <config_distro_bootcmd.h>
78
Tom Rinic9edebe2022-12-04 10:03:50 -050079#define CFG_EXTRA_ENV_SETTINGS \
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030080 "fdt_high=0xffffffff\0" \
81 "initrd_high=0xffffffff\0" \
82 "fdt_addr=0x40000000\0" \
83 "scriptaddr=0x40200000\0" \
84 "pxefile_addr_r=0x40300000\0" \
85 "kernel_addr_r=0x40400000\0" \
86 "ramdisk_addr_r=0x44000000\0" \
87 BOOTENV
88
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +030089#endif /* __CONFIG_H */