1 /* SPDX-License-Identifier: GPL-2.0+ */ 2 /* 3 * Copyright (C) 2015-2016 Stefan Roese <sr@denx.de> 4 */ 5 6 #ifndef _CONFIG_THEADORABLE_H 7 #define _CONFIG_THEADORABLE_H 8 9 /* 10 * High Level Configuration Options (easy to change) 11 */ 12 13 /* 14 * TEXT_BASE needs to be below 16MiB, since this area is scrubbed 15 * for DDR ECC byte filling in the SPL before loading the main 16 * U-Boot into it. 17 */ 18 #define CONFIG_SYS_TCLK 250000000 /* 250MHz */ 19 20 /* 21 * Commands configuration 22 */ 23 24 /* 25 * The debugging version enables USB support via defconfig. 26 * This version should also enable all other non-production 27 * interfaces / features. 28 */ 29 30 /* I2C */ 31 #define CONFIG_SYS_I2C 32 #define CONFIG_SYS_I2C_MVTWSI 33 #define CONFIG_I2C_MVTWSI_BASE0 MVEBU_TWSI_BASE 34 #define CONFIG_I2C_MVTWSI_BASE1 MVEBU_TWSI1_BASE 35 #define CONFIG_SYS_I2C_SLAVE 0x0 36 #define CONFIG_SYS_I2C_SPEED 100000 37 38 /* USB/EHCI configuration */ 39 #define CONFIG_EHCI_IS_TDI 40 #define CONFIG_USB_MAX_CONTROLLER_COUNT 3 41 42 /* SPI NOR flash default params, used by sf commands */ 43 #define CONFIG_SF_DEFAULT_SPEED 27777777 /* for fast SPL booting */ 44 #define CONFIG_SF_DEFAULT_MODE SPI_MODE_3 45 46 /* Environment in SPI NOR flash */ 47 #define CONFIG_ENV_OFFSET (1 << 20) /* 1MiB in */ 48 #define CONFIG_ENV_SIZE (64 << 10) /* 64KiB */ 49 #define CONFIG_ENV_SECT_SIZE (256 << 10) /* 256KiB sectors */ 50 #define CONFIG_ENV_OVERWRITE 51 52 #define CONFIG_PHY_MARVELL /* there is a marvell phy */ 53 #define PHY_ANEG_TIMEOUT 8000 /* PHY needs a longer aneg time */ 54 55 #define CONFIG_PREBOOT 56 57 /* Keep device tree and initrd in lower memory so the kernel can access them */ 58 #define CONFIG_EXTRA_ENV_SETTINGS \ 59 "fdt_high=0x10000000\0" \ 60 "initrd_high=0x10000000\0" 61 62 /* SATA support */ 63 #define CONFIG_SYS_SATA_MAX_DEVICE 1 64 #define CONFIG_LBA48 65 66 /* PCIe support */ 67 #ifdef CONFIG_CMD_PCI 68 #ifndef CONFIG_SPL_BUILD 69 #define CONFIG_PCI_MVEBU 70 #endif 71 #endif 72 73 /* Enable LCD and reserve 512KB from top of memory*/ 74 #define CONFIG_SYS_MEM_TOP_HIDE 0x80000 75 76 /* FPGA programming support */ 77 #define CONFIG_FPGA_STRATIX_V 78 79 /* 80 * Bootcounter 81 */ 82 /* Max size of RAM minus BOOTCOUNT_ADDR is the bootcounter address */ 83 #define BOOTCOUNT_ADDR 0x1000 84 85 /* 86 * mv-common.h should be defined after CMD configs since it used them 87 * to enable certain macros 88 */ 89 #include "mv-common.h" 90 91 /* 92 * Memory layout while starting into the bin_hdr via the 93 * BootROM: 94 * 95 * 0x4000.4000 - 0x4003.4000 headers space (192KiB) 96 * 0x4000.4030 bin_hdr start address 97 * 0x4003.4000 - 0x4004.7c00 BootROM memory allocations (15KiB) 98 * 0x4007.fffc BootROM stack top 99 * 100 * The address space between 0x4007.fffc and 0x400f.fff is not locked in 101 * L2 cache thus cannot be used. 102 */ 103 104 /* SPL */ 105 /* Defines for SPL */ 106 #define CONFIG_SPL_TEXT_BASE 0x40004030 107 #define CONFIG_SPL_MAX_SIZE ((128 << 10) - 0x4030) 108 109 #define CONFIG_SPL_BSS_START_ADDR (0x40000000 + (128 << 10)) 110 #define CONFIG_SPL_BSS_MAX_SIZE (16 << 10) 111 112 #ifdef CONFIG_SPL_BUILD 113 #define CONFIG_SYS_MALLOC_SIMPLE 114 #endif 115 116 #define CONFIG_SPL_STACK (0x40000000 + ((192 - 16) << 10)) 117 #define CONFIG_SPL_BOOTROM_SAVE (CONFIG_SPL_STACK + 4) 118 119 /* SPL related SPI defines */ 120 #define CONFIG_SYS_SPI_U_BOOT_OFFS 0x1a000 121 #define CONFIG_SYS_U_BOOT_OFFS CONFIG_SYS_SPI_U_BOOT_OFFS 122 123 /* Enable DDR support in SPL (DDR3 training from Marvell bin_hdr) */ 124 #define CONFIG_DDR_FIXED_SIZE (2 << 20) /* 2GiB */ 125 126 #endif /* _CONFIG_THEADORABLE_H */ 127