Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 2 | /* |
| 3 | * Board configuration file for Dragonboard 410C |
| 4 | * |
| 5 | * (C) Copyright 2015 Mateusz Kulikowski <mateusz.kulikowski@gmail.com> |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #ifndef __CONFIGS_DRAGONBOARD410C_H |
| 9 | #define __CONFIGS_DRAGONBOARD410C_H |
| 10 | |
| 11 | #include <linux/sizes.h> |
| 12 | #include <asm/arch/sysmap-apq8016.h> |
| 13 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 14 | /* Physical Memory Map */ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 15 | #define PHYS_SDRAM_1 0x80000000 |
| 16 | /* 1008 MB (the last ~30Mb are secured for TrustZone by ATF*/ |
| 17 | #define PHYS_SDRAM_1_SIZE 0x3da00000 |
| 18 | #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1 |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 19 | #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_SDRAM_BASE + 0x7fff0) |
| 20 | #define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x80000) |
Jorge Ramirez-Ortiz | 2212f63 | 2018-01-10 11:34:34 +0100 | [diff] [blame] | 21 | #define CONFIG_SYS_BOOTM_LEN SZ_64M |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 22 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 23 | /* UART */ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 24 | |
| 25 | /* Generic Timer Definitions */ |
| 26 | #define COUNTER_FREQUENCY 19000000 |
| 27 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 28 | /* Fixup - in init code we switch from device to host mode, |
| 29 | * it has to be done after each HCD reset */ |
| 30 | #define CONFIG_EHCI_HCD_INIT_AFTER_RESET |
| 31 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 32 | /* BOOTP options */ |
| 33 | #define CONFIG_BOOTP_BOOTFILESIZE |
| 34 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 35 | #define BOOT_TARGET_DEVICES(func) \ |
| 36 | func(USB, usb, 0) \ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 37 | func(MMC, mmc, 1) \ |
Ricardo Salveti de Araujo | 1ff6229 | 2016-07-03 13:59:01 -0300 | [diff] [blame] | 38 | func(MMC, mmc, 0) \ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 39 | func(DHCP, dhcp, na) |
| 40 | |
| 41 | #include <config_distro_bootcmd.h> |
| 42 | |
| 43 | /* Does what recovery does */ |
| 44 | #define REFLASH(file, part) \ |
| 45 | "part start mmc 0 "#part" start && "\ |
| 46 | "part size mmc 0 "#part" size && "\ |
| 47 | "tftp $loadaddr "#file" && " \ |
| 48 | "mmc write $loadaddr $start $size && " |
| 49 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 50 | #define CONFIG_ENV_REFLASH \ |
| 51 | "mmc dev 0 && "\ |
| 52 | "usb start && "\ |
| 53 | "dhcp && "\ |
| 54 | "tftp $loadaddr dragonboard/rescue/gpt_both0.bin && "\ |
| 55 | "mmc write $loadaddr 0 43 && " \ |
| 56 | "mmc rescan && "\ |
| 57 | REFLASH(dragonboard/rescue/NON-HLOS.bin, 1)\ |
| 58 | REFLASH(dragonboard/rescue/sbl1.mbn, 2)\ |
| 59 | REFLASH(dragonboard/rescue/rpm.mbn, 3)\ |
| 60 | REFLASH(dragonboard/rescue/tz.mbn, 4)\ |
| 61 | REFLASH(dragonboard/rescue/hyp.mbn, 5)\ |
| 62 | REFLASH(dragonboard/rescue/sec.dat, 6)\ |
| 63 | REFLASH(dragonboard/rescue/emmc_appsboot.mbn, 7)\ |
| 64 | REFLASH(dragonboard/u-boot.img, 8)\ |
| 65 | "usb stop &&"\ |
| 66 | "echo Reflash completed" |
| 67 | |
| 68 | /* Environment */ |
| 69 | #define CONFIG_EXTRA_ENV_SETTINGS \ |
| 70 | "reflash="CONFIG_ENV_REFLASH"\0"\ |
| 71 | "loadaddr=0x81000000\0" \ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 72 | "initrd_high=0xffffffffffffffff\0" \ |
| 73 | "linux_image=Image\0" \ |
Andreas Färber | ce30298 | 2016-04-13 14:16:22 +0200 | [diff] [blame] | 74 | "kernel_addr_r=0x81000000\0"\ |
Rob Clark | 7ed446a | 2018-01-10 11:34:40 +0100 | [diff] [blame] | 75 | "fdtfile=qcom/apq8016-sbc.dtb\0" \ |
Andreas Färber | ce30298 | 2016-04-13 14:16:22 +0200 | [diff] [blame] | 76 | "fdt_addr_r=0x83000000\0"\ |
| 77 | "ramdisk_addr_r=0x84000000\0"\ |
Ricardo Salveti de Araujo | 8804453 | 2016-07-03 14:16:03 -0300 | [diff] [blame] | 78 | "scriptaddr=0x90000000\0"\ |
| 79 | "pxefile_addr_r=0x90100000\0"\ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 80 | BOOTENV |
| 81 | |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 82 | /* Size of malloc() pool */ |
| 83 | #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + SZ_8M) |
| 84 | |
| 85 | /* Monitor Command Prompt */ |
| 86 | #define CONFIG_SYS_CBSIZE 512 /* Console I/O Buffer Size */ |
Mateusz Kulikowski | ee5e70d | 2016-03-31 23:12:33 +0200 | [diff] [blame] | 87 | #define CONFIG_SYS_MAXARGS 64 /* max command args */ |
| 88 | |
| 89 | #endif |