2 * Board configuration file for Dragonboard 410C
4 * (C) Copyright 2015 Mateusz Kulikowski <mateusz.kulikowski@gmail.com>
6 * SPDX-License-Identifier: GPL-2.0+
9 #ifndef __CONFIGS_DRAGONBOARD410C_H
10 #define __CONFIGS_DRAGONBOARD410C_H
12 #include <linux/sizes.h>
13 #include <asm/arch/sysmap-apq8016.h>
15 #define CONFIG_MISC_INIT_R /* To stop autoboot */
17 /* Physical Memory Map */
18 #define CONFIG_NR_DRAM_BANKS 1
19 #define PHYS_SDRAM_1 0x80000000
20 /* 1008 MB (the last ~30Mb are secured for TrustZone by ATF*/
21 #define PHYS_SDRAM_1_SIZE 0x3da00000
22 #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
23 #define CONFIG_SYS_TEXT_BASE 0x80080000
24 #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_SDRAM_BASE + 0x7fff0)
25 #define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x80000)
26 #define CONFIG_SYS_BOOTM_LEN 0x1000000 /* 16MB max kernel size */
30 /* Generic Timer Definitions */
31 #define COUNTER_FREQUENCY 19000000
33 #define CONFIG_SYS_LDSCRIPT "board/qualcomm/dragonboard410c/u-boot.lds"
35 /* Fixup - in init code we switch from device to host mode,
36 * it has to be done after each HCD reset */
37 #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
39 #define CONFIG_USB_HOST_ETHER /* Enable USB Networking */
41 /* Support all possible USB ethernet dongles */
42 #define CONFIG_USB_ETHER_DM9601
43 #define CONFIG_USB_ETHER_ASIX
44 #define CONFIG_USB_ETHER_ASIX88179
45 #define CONFIG_USB_ETHER_MCS7830
46 #define CONFIG_USB_ETHER_SMSC95XX
49 #define CONFIG_CMD_ENV
50 /* Enable that for switching of boot partitions */
51 /* Disabled by default as some sub-commands can brick eMMC */
52 /*#define CONFIG_SUPPORT_EMMC_BOOT */
53 #define CONFIG_CMD_REGINFO /* Register dump */
54 #define CONFIG_CMD_TFTP
56 /* Partition table support */
57 #define HAVE_BLOCK_DEVICE /* Needed for partition commands */
59 #include <config_distro_defaults.h>
62 #define CONFIG_BOOTP_BOOTFILESIZE
64 /* Environment - Boot*/
65 #define CONFIG_BOOTARGS "console=ttyMSM0,115200n8"
67 #define BOOT_TARGET_DEVICES(func) \
73 #include <config_distro_bootcmd.h>
75 /* Does what recovery does */
76 #define REFLASH(file, part) \
77 "part start mmc 0 "#part" start && "\
78 "part size mmc 0 "#part" size && "\
79 "tftp $loadaddr "#file" && " \
80 "mmc write $loadaddr $start $size && "
82 #define CONFIG_ENV_REFLASH \
86 "tftp $loadaddr dragonboard/rescue/gpt_both0.bin && "\
87 "mmc write $loadaddr 0 43 && " \
89 REFLASH(dragonboard/rescue/NON-HLOS.bin, 1)\
90 REFLASH(dragonboard/rescue/sbl1.mbn, 2)\
91 REFLASH(dragonboard/rescue/rpm.mbn, 3)\
92 REFLASH(dragonboard/rescue/tz.mbn, 4)\
93 REFLASH(dragonboard/rescue/hyp.mbn, 5)\
94 REFLASH(dragonboard/rescue/sec.dat, 6)\
95 REFLASH(dragonboard/rescue/emmc_appsboot.mbn, 7)\
96 REFLASH(dragonboard/u-boot.img, 8)\
98 "echo Reflash completed"
101 #define CONFIG_EXTRA_ENV_SETTINGS \
102 "reflash="CONFIG_ENV_REFLASH"\0"\
103 "loadaddr=0x81000000\0" \
104 "fdt_high=0xffffffffffffffff\0" \
105 "initrd_high=0xffffffffffffffff\0" \
106 "linux_image=Image\0" \
107 "kernel_addr_r=0x81000000\0"\
108 "fdtfile=apq8016-sbc.dtb\0" \
109 "fdt_addr_r=0x83000000\0"\
110 "ramdisk_addr_r=0x84000000\0"\
111 "scriptaddr=0x90000000\0"\
112 "pxefile_addr_r=0x90100000\0"\
115 #define CONFIG_ENV_IS_NOWHERE
116 #define CONFIG_ENV_SIZE 0x2000
117 #define CONFIG_ENV_VARS_UBOOT_CONFIG
119 /* Size of malloc() pool */
120 #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + SZ_8M)
122 /* Monitor Command Prompt */
123 #define CONFIG_SYS_CBSIZE 512 /* Console I/O Buffer Size */
124 #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + \
125 sizeof(CONFIG_SYS_PROMPT) + 16)
126 #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
127 #define CONFIG_SYS_MAXARGS 64 /* max command args */