1 /* 2 * (C) Copyright 2016 Rockchip Electronics Co., Ltd 3 * 4 * SPDX-License-Identifier: GPL-2.0+ 5 */ 6 7 #ifndef _ROCKCHIP_COMMON_H_ 8 #define _ROCKCHIP_COMMON_H_ 9 #include <linux/sizes.h> 10 11 #define COUNTER_FREQUENCY 24000000 12 13 #if CONFIG_IS_ENABLED(TINY_FRAMEWORK) && !defined(CONFIG_ARM64) 14 #undef CONFIG_SYS_ARCH_TIMER 15 #else 16 #define CONFIG_SYS_ARCH_TIMER 17 #endif 18 19 #define CONFIG_SYS_HZ_CLOCK 24000000 20 21 #define CONFIG_SYS_NS16550_MEM32 22 23 #ifdef CONFIG_SPL_BUILD 24 #define CONFIG_NR_DRAM_BANKS 2 25 #else 26 #define CONFIG_NR_DRAM_BANKS 12 27 #endif 28 29 #ifndef CONFIG_SPL_BUILD 30 #include <config_distro_defaults.h> 31 32 #ifdef CONFIG_CMD_RKNAND 33 #define BOOTENV_SHARED_RKNAND BOOTENV_SHARED_BLKDEV(rknand) 34 #define BOOTENV_DEV_RKNAND BOOTENV_DEV_BLKDEV 35 #define BOOTENV_DEV_NAME_RKNAND BOOTENV_DEV_NAME_BLKDEV 36 #else 37 #define BOOTENV_SHARED_RKNAND 38 #define BOOTENV_DEV_RKNAND \ 39 BOOT_TARGET_DEVICES_references_RKNAND_without_CONFIG_CMD_RKNAND 40 #define BOOTENV_DEV_NAME_RKNAND \ 41 BOOT_TARGET_DEVICES_references_RKNAND_without_CONFIG_CMD_RKNAND 42 #endif 43 44 #ifdef CONFIG_CMD_MTD_BLK 45 #define BOOTENV_SHARED_MTD \ 46 "mtd_boot=" \ 47 "if mtd_blk dev ${devnum}; then " \ 48 "setenv devtype mtd; " \ 49 "run scan_dev_for_boot_part; " \ 50 "fi\0" 51 #define BOOTENV_DEV_MTD BOOTENV_DEV_BLKDEV 52 #define BOOTENV_DEV_NAME_MTD BOOTENV_DEV_NAME_BLKDEV 53 #else 54 #define BOOTENV_SHARED_MTD 55 #define BOOTENV_DEV_MTD \ 56 BOOT_TARGET_DEVICES_references_MTD_without_CONFIG_CMD_MTD_BLK 57 #define BOOTENV_DEV_NAME_MTD \ 58 BOOT_TARGET_DEVICES_references_MTD_without_CONFIG_CMD_MTD_BLK 59 #endif 60 61 /* First try to boot from SD (index 1), then eMMC (index 0) */ 62 #if CONFIG_IS_ENABLED(CMD_MMC) 63 #define BOOT_TARGET_MMC(func) \ 64 func(MMC, mmc, 1) \ 65 func(MMC, mmc, 0) 66 #else 67 #define BOOT_TARGET_MMC(func) 68 #endif 69 70 #if CONFIG_IS_ENABLED(CMD_MTD_BLK) 71 #define BOOT_TARGET_MTD(func) \ 72 func(MTD, mtd, 2) \ 73 func(MTD, mtd, 1) \ 74 func(MTD, mtd, 0) 75 #else 76 #define BOOT_TARGET_MTD(func) 77 #endif 78 79 #if CONFIG_IS_ENABLED(CMD_RKNAND) 80 #define BOOT_TARGET_RKNAND(func) func(RKNAND, rknand, 0) 81 #else 82 #define BOOT_TARGET_RKNAND(func) 83 #endif 84 85 #if CONFIG_IS_ENABLED(CMD_USB) 86 #define BOOT_TARGET_USB(func) func(USB, usb, 0) 87 #else 88 #define BOOT_TARGET_USB(func) 89 #endif 90 91 #if CONFIG_IS_ENABLED(CMD_PXE) 92 #define BOOT_TARGET_PXE(func) func(PXE, pxe, na) 93 #else 94 #define BOOT_TARGET_PXE(func) 95 #endif 96 97 #if CONFIG_IS_ENABLED(CMD_DHCP) 98 #define BOOT_TARGET_DHCP(func) func(DHCP, dhcp, na) 99 #else 100 #define BOOT_TARGET_DHCP(func) 101 #endif 102 103 #define BOOT_TARGET_DEVICES(func) \ 104 BOOT_TARGET_MMC(func) \ 105 BOOT_TARGET_MTD(func) \ 106 BOOT_TARGET_RKNAND(func) \ 107 BOOT_TARGET_USB(func) \ 108 BOOT_TARGET_PXE(func) \ 109 BOOT_TARGET_DHCP(func) 110 111 #ifdef CONFIG_ARM64 112 #define ROOT_UUID "B921B045-1DF0-41C3-AF44-4C6F280D3FAE;\0" 113 #else 114 #define ROOT_UUID "69DAD710-2CE4-4E3C-B16C-21A1D49ABED3;\0" 115 #endif 116 #define PARTS_DEFAULT \ 117 "uuid_disk=${uuid_gpt_disk};" \ 118 "name=loader1,start=32K,size=4000K,uuid=${uuid_gpt_loader1};" \ 119 "name=loader2,start=8MB,size=4MB,uuid=${uuid_gpt_loader2};" \ 120 "name=trust,size=4M,uuid=${uuid_gpt_atf};" \ 121 "name=boot,size=112M,bootable,uuid=${uuid_gpt_boot};" \ 122 "name=rootfs,size=-,uuid="ROOT_UUID 123 124 #define PARTS_RKIMG \ 125 "uuid_disk=${uuid_gpt_disk};" \ 126 "name=uboot,start=8MB,size=4MB,uuid=${uuid_gpt_loader2};" \ 127 "name=trust,size=4M,uuid=${uuid_gpt_atf};" \ 128 "name=misc,size=4MB,uuid=${uuid_gpt_misc};" \ 129 "name=resource,size=16MB,uuid=${uuid_gpt_resource};" \ 130 "name=kernel,size=32M,uuid=${uuid_gpt_kernel};" \ 131 "name=boot,size=32M,bootable,uuid=${uuid_gpt_boot};" \ 132 "name=recovery,size=32M,uuid=${uuid_gpt_recovery};" \ 133 "name=backup,size=112M,uuid=${uuid_gpt_backup};" \ 134 "name=cache,size=512M,uuid=${uuid_gpt_cache};" \ 135 "name=system,size=2048M,uuid=${uuid_gpt_system};" \ 136 "name=metadata,size=16M,uuid=${uuid_gpt_metadata};" \ 137 "name=vendor,size=32M,uuid=${uuid_gpt_vendor};" \ 138 "name=oem,size=32M,uuid=${uuid_gpt_oem};" \ 139 "name=frp,size=512K,uuid=${uuid_gpt_frp};" \ 140 "name=security,size=2M,uuid=${uuid_gpt_security};" \ 141 "name=userdata,size=-,uuid=${uuid_gpt_userdata};\0" 142 143 #define RKIMG_DET_BOOTDEV \ 144 "devnum=0\0" \ 145 "devtype=mmc\0" \ 146 "rkimg_bootdev=" \ 147 "if mmc dev 1 && rkimgtest mmc 1; then " \ 148 "setenv devtype mmc; setenv devnum 1; echo Boot from SDcard;" \ 149 "elif mmc dev 0; then " \ 150 "setenv devtype mmc; setenv devnum 0;" \ 151 "elif mtd_blk dev 0; then " \ 152 "setenv devtype mtd; setenv devnum 0;" \ 153 "elif mtd_blk dev 1; then " \ 154 "setenv devtype mtd; setenv devnum 1;" \ 155 "elif mtd_blk dev 2; then " \ 156 "setenv devtype mtd; setenv devnum 2;" \ 157 "elif rknand dev 0; then " \ 158 "setenv devtype rknand; setenv devnum 0;" \ 159 "elif rksfc dev 0; then " \ 160 "setenv devtype spinand; setenv devnum 0;" \ 161 "elif rksfc dev 1; then " \ 162 "setenv devtype spinor; setenv devnum 1;" \ 163 "else;" \ 164 "setenv devtype ramdisk; setenv devnum 0;" \ 165 "fi; \0" 166 167 #if defined(CONFIG_AVB_VBMETA_PUBLIC_KEY_VALIDATE) 168 #define RKIMG_BOOTCOMMAND \ 169 "boot_android ${devtype} ${devnum};" 170 #elif defined(CONFIG_FIT_SIGNATURE) 171 #define RKIMG_BOOTCOMMAND \ 172 "boot_fit;" 173 #else 174 #define RKIMG_BOOTCOMMAND \ 175 "boot_android ${devtype} ${devnum};" \ 176 "boot_fit;" \ 177 "bootrkp;" \ 178 "run distro_bootcmd;" 179 #endif 180 181 #endif /* CONFIG_SPL_BUILD */ 182 183 #define CONFIG_DISPLAY_BOARDINFO_LATE 184 #define CONFIG_SYS_AUTOLOAD "no" 185 #define CONFIG_SPL_LOAD_FIT_ADDRESS 0x2000000 186 187 #endif /* _ROCKCHIP_COMMON_H_ */ 188