1264eaa0eSValentin Longchamp /* 2264eaa0eSValentin Longchamp * (C) Copyright 2008-2011 3264eaa0eSValentin Longchamp * Heiko Schocher, DENX Software Engineering, hs@denx.de. 4264eaa0eSValentin Longchamp * 51a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 6264eaa0eSValentin Longchamp */ 7264eaa0eSValentin Longchamp 8264eaa0eSValentin Longchamp #ifndef __CONFIG_KEYMILE_H 9264eaa0eSValentin Longchamp #define __CONFIG_KEYMILE_H 10264eaa0eSValentin Longchamp 11264eaa0eSValentin Longchamp #define CONFIG_BOOTCOUNT_LIMIT 12264eaa0eSValentin Longchamp 13264eaa0eSValentin Longchamp #undef CONFIG_WATCHDOG /* disable platform specific watchdog */ 14264eaa0eSValentin Longchamp 15264eaa0eSValentin Longchamp /* 16264eaa0eSValentin Longchamp * Miscellaneous configurable options 17264eaa0eSValentin Longchamp */ 18264eaa0eSValentin Longchamp #define CONFIG_SYS_LONGHELP /* undef to save memory */ 19264eaa0eSValentin Longchamp #if defined(CONFIG_CMD_KGDB) 20264eaa0eSValentin Longchamp #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */ 21264eaa0eSValentin Longchamp #else 22264eaa0eSValentin Longchamp #define CONFIG_SYS_CBSIZE 512 /* Console I/O Buffer Size */ 23264eaa0eSValentin Longchamp #endif 24264eaa0eSValentin Longchamp #define CONFIG_SYS_MAXARGS 32 /* max number of command args */ 25264eaa0eSValentin Longchamp #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 26264eaa0eSValentin Longchamp #define CONFIG_CMDLINE_EDITING 27264eaa0eSValentin Longchamp #define CONFIG_AUTO_COMPLETE 28264eaa0eSValentin Longchamp 29264eaa0eSValentin Longchamp #define CONFIG_HUSH_INIT_VAR 30264eaa0eSValentin Longchamp 31264eaa0eSValentin Longchamp #define CONFIG_SYS_ALT_MEMTEST /* memory test, takes time */ 32264eaa0eSValentin Longchamp 33264eaa0eSValentin Longchamp #define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200, 230400 } 34264eaa0eSValentin Longchamp 35264eaa0eSValentin Longchamp #define CONFIG_LOADS_ECHO 36264eaa0eSValentin Longchamp #define CONFIG_SYS_LOADS_BAUD_CHANGE 37264eaa0eSValentin Longchamp 387f70460eSHolger Brunck 39264eaa0eSValentin Longchamp /* Support the IVM EEprom */ 40264eaa0eSValentin Longchamp #define CONFIG_SYS_IVM_EEPROM_ADR 0x50 41264eaa0eSValentin Longchamp #define CONFIG_SYS_IVM_EEPROM_MAX_LEN 0x400 42264eaa0eSValentin Longchamp #define CONFIG_SYS_IVM_EEPROM_PAGE_LEN 0x100 43264eaa0eSValentin Longchamp 44264eaa0eSValentin Longchamp #define CONFIG_SYS_FLASH_PROTECTION 45264eaa0eSValentin Longchamp 46264eaa0eSValentin Longchamp /* 47264eaa0eSValentin Longchamp * BOOTP options 48264eaa0eSValentin Longchamp */ 49264eaa0eSValentin Longchamp #define CONFIG_BOOTP_BOOTFILESIZE 50264eaa0eSValentin Longchamp #define CONFIG_BOOTP_BOOTPATH 51264eaa0eSValentin Longchamp #define CONFIG_BOOTP_GATEWAY 52264eaa0eSValentin Longchamp #define CONFIG_BOOTP_HOSTNAME 53264eaa0eSValentin Longchamp 54264eaa0eSValentin Longchamp /* UBI Support for all Keymile boards */ 55264eaa0eSValentin Longchamp #define CONFIG_MTD_CONCAT 56264eaa0eSValentin Longchamp 57264eaa0eSValentin Longchamp #ifndef CONFIG_KM_DEF_ENV_BOOTPARAMS 58264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_ENV_BOOTPARAMS \ 59db0bb572SHolger Brunck "actual_bank=0\0" 60264eaa0eSValentin Longchamp #endif 61264eaa0eSValentin Longchamp 62264eaa0eSValentin Longchamp #ifndef CONFIG_KM_DEF_NETDEV 63264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_NETDEV \ 64264eaa0eSValentin Longchamp "netdev=eth0\0" 65264eaa0eSValentin Longchamp #endif 66264eaa0eSValentin Longchamp 67cf73639dSAndreas Huber #ifndef CONFIG_KM_UBI_PARTITION_NAME_BOOT 68cf73639dSAndreas Huber #define CONFIG_KM_UBI_PARTITION_NAME_BOOT "ubi0" 69cf73639dSAndreas Huber #endif /* CONFIG_KM_UBI_PARTITION_NAME_BOOT */ 70cf73639dSAndreas Huber 71cf7707a1SValentin Longchamp #ifndef CONFIG_KM_UBI_PART_BOOT_OPTS 72cf7707a1SValentin Longchamp #define CONFIG_KM_UBI_PART_BOOT_OPTS "" 73cf7707a1SValentin Longchamp #endif /* CONFIG_KM_UBI_PART_BOOT_OPTS */ 74cf7707a1SValentin Longchamp 75cf73639dSAndreas Huber #ifndef CONFIG_KM_UBI_PARTITION_NAME_APP 76cf73639dSAndreas Huber /* one flash chip only called boot */ 77cf73639dSAndreas Huber /* boot: CONFIG_KM_UBI_PARTITION_NAME_BOOT */ 78cf73639dSAndreas Huber # define CONFIG_KM_UBI_LINUX_MTD \ 79cf7707a1SValentin Longchamp "ubi.mtd=" CONFIG_KM_UBI_PARTITION_NAME_BOOT \ 80cf7707a1SValentin Longchamp CONFIG_KM_UBI_PART_BOOT_OPTS 81cf73639dSAndreas Huber # define CONFIG_KM_DEV_ENV_FLASH_BOOT_UBI \ 82cf73639dSAndreas Huber "ubiattach=ubi part " CONFIG_KM_UBI_PARTITION_NAME_BOOT "\0" 83cf73639dSAndreas Huber #else /* CONFIG_KM_UBI_PARTITION_NAME_APP */ 84cf73639dSAndreas Huber /* two flash chips called boot and app */ 85cf73639dSAndreas Huber /* boot: CONFIG_KM_UBI_PARTITION_NAME_BOOT */ 86cf73639dSAndreas Huber /* app: CONFIG_KM_UBI_PARTITION_NAME_APP */ 87cf73639dSAndreas Huber # define CONFIG_KM_UBI_LINUX_MTD \ 88cf7707a1SValentin Longchamp "ubi.mtd=" CONFIG_KM_UBI_PARTITION_NAME_BOOT \ 89cf7707a1SValentin Longchamp CONFIG_KM_UBI_PART_BOOT_OPTS " " \ 90cf73639dSAndreas Huber "ubi.mtd=" CONFIG_KM_UBI_PARTITION_NAME_APP 91cf73639dSAndreas Huber # define CONFIG_KM_DEV_ENV_FLASH_BOOT_UBI \ 92cf73639dSAndreas Huber "ubiattach=if test ${boot_bank} -eq 0; then; " \ 93cf73639dSAndreas Huber "ubi part " CONFIG_KM_UBI_PARTITION_NAME_BOOT "; else; " \ 94cf73639dSAndreas Huber "ubi part " CONFIG_KM_UBI_PARTITION_NAME_APP "; fi\0" 95cf73639dSAndreas Huber #endif /* CONFIG_KM_UBI_PARTITION_NAME_APP */ 96264eaa0eSValentin Longchamp 97dacc109cSAndreas Huber #ifdef CONFIG_NAND_ECC_BCH 98dacc109cSAndreas Huber #define CONFIG_KM_UIMAGE_NAME "ecc_bch_uImage\0" 99a7bc9144SHolger Brunck #define CONFIG_KM_ECC_MODE " eccmode=bch" 100dacc109cSAndreas Huber #else 101dacc109cSAndreas Huber #define CONFIG_KM_UIMAGE_NAME "uImage\0" 102a7bc9144SHolger Brunck #define CONFIG_KM_ECC_MODE 103dacc109cSAndreas Huber #endif 104dacc109cSAndreas Huber 105264eaa0eSValentin Longchamp /* 106264eaa0eSValentin Longchamp * boottargets 107db0bb572SHolger Brunck * - set 'subbootcmds' 108264eaa0eSValentin Longchamp * - set 'bootcmd' and 'altbootcmd' 109264eaa0eSValentin Longchamp * available targets: 110264eaa0eSValentin Longchamp * - 'release': for a standalone system kernel/rootfs from flash 111264eaa0eSValentin Longchamp */ 112264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_ENV_BOOTTARGETS \ 113*c6d32dfdSValentin Longchamp "subbootcmds=ubiattach ubicopy checkfdt cramfsloadfdt " \ 114*c6d32dfdSValentin Longchamp "set_fdthigh cramfsloadkernel flashargs add_default " \ 115*c6d32dfdSValentin Longchamp "addpanic boot\0" \ 116b648bfc2SHolger Brunck "develop=" \ 117b648bfc2SHolger Brunck "tftp 200000 scripts/develop-${arch}.txt && " \ 1182d9528e3SHolger Brunck "env import -t 200000 ${filesize} && " \ 119b648bfc2SHolger Brunck "run setup_debug_env\0" \ 120b648bfc2SHolger Brunck "ramfs=" \ 121b648bfc2SHolger Brunck "tftp 200000 scripts/ramfs-${arch}.txt && " \ 122b648bfc2SHolger Brunck "env import -t 200000 ${filesize} && " \ 123b648bfc2SHolger Brunck "run setup_debug_env\0" \ 124264eaa0eSValentin Longchamp "" 125264eaa0eSValentin Longchamp 126264eaa0eSValentin Longchamp /* 127264eaa0eSValentin Longchamp * bootargs 128264eaa0eSValentin Longchamp * - modify 'bootargs' 129264eaa0eSValentin Longchamp * 130db0bb572SHolger Brunck * - 'add_default': default bootargs common for all arm/ppc boards 131264eaa0eSValentin Longchamp * - 'addpanic': add kernel panic options 132264eaa0eSValentin Longchamp * - 'flashargs': defaults arguments for flash base boot 133264eaa0eSValentin Longchamp * 134264eaa0eSValentin Longchamp */ 135264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_ENV_BOOTARGS \ 136db0bb572SHolger Brunck "add_default=" \ 137264eaa0eSValentin Longchamp "setenv bootargs ${bootargs} " \ 138264eaa0eSValentin Longchamp "ip=${ipaddr}:${serverip}:${gatewayip}:${netmask}" \ 1397c3d6a29SValentin Longchamp ":${hostname}:${netdev}:off:" \ 140db0bb572SHolger Brunck " console=" CONFIG_KM_CONSOLE_TTY ",${baudrate}" \ 1412a7714ceSAndreas Huber " mem=${kernelmem} init=${init}" \ 142a7bc9144SHolger Brunck CONFIG_KM_ECC_MODE \ 14393ea89f0SMarek Vasut " phram.phram=phvar,${varaddr}," __stringify(CONFIG_KM_PHRAM)\ 144cf73639dSAndreas Huber " " CONFIG_KM_UBI_LINUX_MTD " " \ 145db0bb572SHolger Brunck CONFIG_KM_DEF_BOOT_ARGS_CPU \ 146db0bb572SHolger Brunck "\0" \ 147264eaa0eSValentin Longchamp "addpanic=" \ 1482d9528e3SHolger Brunck "setenv bootargs ${bootargs} panic=1 panic_on_oops=1\0" \ 149264eaa0eSValentin Longchamp "flashargs=" \ 150264eaa0eSValentin Longchamp "setenv bootargs " \ 151264eaa0eSValentin Longchamp "root=mtdblock:rootfs${boot_bank} " \ 152264eaa0eSValentin Longchamp "rootfstype=squashfs ro\0" \ 153264eaa0eSValentin Longchamp "" 154264eaa0eSValentin Longchamp 155264eaa0eSValentin Longchamp /* 156264eaa0eSValentin Longchamp * flash_boot 157264eaa0eSValentin Longchamp * - commands for booting from flash 158264eaa0eSValentin Longchamp * 159264eaa0eSValentin Longchamp * - 'cramfsloadkernel': copy kernel from a cramfs to ram 160264eaa0eSValentin Longchamp * - 'ubiattach': attach ubi partition 161264eaa0eSValentin Longchamp * - 'ubicopy': copy ubi volume to ram 162264eaa0eSValentin Longchamp * - volume names: bootfs0, bootfs1, bootfs2, ... 163264eaa0eSValentin Longchamp * 164264eaa0eSValentin Longchamp * processor specific settings 165264eaa0eSValentin Longchamp * - 'cramfsloadfdt': copy fdt from a cramfs to ram 166264eaa0eSValentin Longchamp */ 167264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_ENV_FLASH_BOOT \ 16893ea89f0SMarek Vasut "cramfsaddr=" __stringify(CONFIG_KM_CRAMFS_ADDR) "\0" \ 169dacc109cSAndreas Huber "cramfsloadkernel=cramfsload ${load_addr_r} ${uimage}\0" \ 17093ea89f0SMarek Vasut "ubicopy=ubi read "__stringify(CONFIG_KM_CRAMFS_ADDR) \ 1712d9528e3SHolger Brunck " bootfs${boot_bank}\0" \ 172dacc109cSAndreas Huber "uimage=" CONFIG_KM_UIMAGE_NAME \ 173cf73639dSAndreas Huber CONFIG_KM_DEV_ENV_FLASH_BOOT_UBI 174264eaa0eSValentin Longchamp 175264eaa0eSValentin Longchamp /* 176264eaa0eSValentin Longchamp * constants 177264eaa0eSValentin Longchamp * - KM specific constants and commands 178264eaa0eSValentin Longchamp * 179264eaa0eSValentin Longchamp * - 'default': setup default environment 180264eaa0eSValentin Longchamp */ 181264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_ENV_CONSTANTS \ 182264eaa0eSValentin Longchamp "backup_bank=0\0" \ 183db0bb572SHolger Brunck "release=run newenv; reset\0" \ 18493ea89f0SMarek Vasut "pnvramsize=" __stringify(CONFIG_KM_PNVRAM) "\0" \ 1850333cfe6SThomas Herzmann "testbootcmd=setenv boot_bank ${test_bank}; " \ 1860333cfe6SThomas Herzmann "run ${subbootcmds}; reset\0" \ 187264eaa0eSValentin Longchamp "" 188264eaa0eSValentin Longchamp 189264eaa0eSValentin Longchamp #ifndef CONFIG_KM_DEF_ENV 190264eaa0eSValentin Longchamp #define CONFIG_KM_DEF_ENV \ 191264eaa0eSValentin Longchamp CONFIG_KM_DEF_ENV_BOOTPARAMS \ 192264eaa0eSValentin Longchamp CONFIG_KM_DEF_NETDEV \ 193264eaa0eSValentin Longchamp CONFIG_KM_DEF_ENV_CPU \ 194264eaa0eSValentin Longchamp CONFIG_KM_DEF_ENV_BOOTTARGETS \ 195264eaa0eSValentin Longchamp CONFIG_KM_DEF_ENV_BOOTARGS \ 196264eaa0eSValentin Longchamp CONFIG_KM_DEF_ENV_FLASH_BOOT \ 197264eaa0eSValentin Longchamp CONFIG_KM_DEF_ENV_CONSTANTS \ 198264eaa0eSValentin Longchamp "altbootcmd=run bootcmd\0" \ 1997b2268b8SGerlando Falauto "boot=bootm ${load_addr_r} - ${fdt_addr_r}\0" \ 200db0bb572SHolger Brunck "bootcmd=km_checkbidhwk && " \ 201c1b3d841SThomas Herzmann "setenv bootcmd \'if km_checktestboot; then; " \ 202c1b3d841SThomas Herzmann "setenv boot_bank ${test_bank}; else; " \ 203c1b3d841SThomas Herzmann "setenv boot_bank ${actual_bank}; fi;" \ 204db0bb572SHolger Brunck "run ${subbootcmds}; reset\' && " \ 205db0bb572SHolger Brunck "setenv altbootcmd \'setenv boot_bank ${backup_bank}; " \ 206db0bb572SHolger Brunck "run ${subbootcmds}; reset\' && " \ 207db0bb572SHolger Brunck "saveenv && saveenv && boot\0" \ 20831dd8988SHolger Brunck "bootlimit=3\0" \ 2097b2268b8SGerlando Falauto "cramfsloadfdt=" \ 2107b2268b8SGerlando Falauto "cramfsload ${fdt_addr_r} " \ 2117b2268b8SGerlando Falauto "fdt_0x${IVM_BoardId}_0x${IVM_HWKey}.dtb\0" \ 2127b2268b8SGerlando Falauto "fdt_addr_r="__stringify(CONFIG_KM_FDT_ADDR) "\0" \ 213264eaa0eSValentin Longchamp "init=/sbin/init-overlay.sh\0" \ 21493ea89f0SMarek Vasut "load_addr_r="__stringify(CONFIG_KM_KERNEL_ADDR) "\0" \ 215db0bb572SHolger Brunck "load=tftpboot ${load_addr_r} ${u-boot}\0" \ 216264eaa0eSValentin Longchamp "mtdids=" MTDIDS_DEFAULT "\0" \ 217264eaa0eSValentin Longchamp "mtdparts=" MTDPARTS_DEFAULT "\0" \ 218264eaa0eSValentin Longchamp "" 219264eaa0eSValentin Longchamp #endif /* CONFIG_KM_DEF_ENV */ 220264eaa0eSValentin Longchamp 221264eaa0eSValentin Longchamp #endif /* __CONFIG_KEYMILE_H */ 222