1*0e31666dSChris Packham /* SPDX-License-Identifier: GPL-2.0+ */ 2*0e31666dSChris Packham /* 3*0e31666dSChris Packham * Copyright (C) 2018 Allied Telesis Labs 4*0e31666dSChris Packham */ 5*0e31666dSChris Packham 6*0e31666dSChris Packham #ifndef _CONFIG_X530_H 7*0e31666dSChris Packham #define _CONFIG_X530_H 8*0e31666dSChris Packham 9*0e31666dSChris Packham /* 10*0e31666dSChris Packham * High Level Configuration Options (easy to change) 11*0e31666dSChris Packham */ 12*0e31666dSChris Packham 13*0e31666dSChris Packham #define CONFIG_DISPLAY_BOARDINFO_LATE 14*0e31666dSChris Packham 15*0e31666dSChris Packham #define CONFIG_SYS_TCLK 250000000 /* 250MHz */ 16*0e31666dSChris Packham 17*0e31666dSChris Packham /* 18*0e31666dSChris Packham * NS16550 Configuration 19*0e31666dSChris Packham */ 20*0e31666dSChris Packham #define CONFIG_SYS_NS16550_SERIAL 21*0e31666dSChris Packham #define CONFIG_SYS_NS16550_CLK CONFIG_SYS_TCLK 22*0e31666dSChris Packham #if !defined(CONFIG_DM_SERIAL) 23*0e31666dSChris Packham #define CONFIG_SYS_NS16550_REG_SIZE (-4) 24*0e31666dSChris Packham #define CONFIG_SYS_NS16550_COM1 MV_UART_CONSOLE_BASE 25*0e31666dSChris Packham #endif 26*0e31666dSChris Packham 27*0e31666dSChris Packham /* 28*0e31666dSChris Packham * Serial Port configuration 29*0e31666dSChris Packham * The following definitions let you select what serial you want to use 30*0e31666dSChris Packham * for your console driver. 31*0e31666dSChris Packham */ 32*0e31666dSChris Packham 33*0e31666dSChris Packham #define CONFIG_CONS_INDEX 1 /*Console on UART0 */ 34*0e31666dSChris Packham 35*0e31666dSChris Packham /* 36*0e31666dSChris Packham * Commands configuration 37*0e31666dSChris Packham */ 38*0e31666dSChris Packham #define CONFIG_CMD_PCI 39*0e31666dSChris Packham 40*0e31666dSChris Packham /* NAND */ 41*0e31666dSChris Packham #define CONFIG_SYS_NAND_ONFI_DETECTION 42*0e31666dSChris Packham #define CONFIG_SYS_NAND_USE_FLASH_BBT 43*0e31666dSChris Packham #define CONFIG_SYS_MAX_NAND_DEVICE 1 44*0e31666dSChris Packham 45*0e31666dSChris Packham #define BBT_CUSTOM_SCAN 46*0e31666dSChris Packham #define BBT_CUSTOM_SCAN_PAGE 0 47*0e31666dSChris Packham #define BBT_CUSTOM_SCAN_POSITION 2048 48*0e31666dSChris Packham 49*0e31666dSChris Packham /* SPI NOR flash default params, used by sf commands */ 50*0e31666dSChris Packham #define CONFIG_SF_DEFAULT_BUS 1 51*0e31666dSChris Packham #define CONFIG_SF_DEFAULT_SPEED 50000000 52*0e31666dSChris Packham #define CONFIG_SF_DEFAULT_MODE SPI_MODE_3 53*0e31666dSChris Packham 54*0e31666dSChris Packham #define MTDIDS_DEFAULT "nand0=nand" 55*0e31666dSChris Packham #define MTDPARTS_DEFAULT "mtdparts=nand:240M(user),8M(errlog),8M(nand-bbt)" 56*0e31666dSChris Packham #define MTDPARTS_MTDOOPS "errlog" 57*0e31666dSChris Packham 58*0e31666dSChris Packham /* Partition support */ 59*0e31666dSChris Packham 60*0e31666dSChris Packham /* Additional FS support/configuration */ 61*0e31666dSChris Packham 62*0e31666dSChris Packham /* USB/EHCI configuration */ 63*0e31666dSChris Packham #define CONFIG_EHCI_IS_TDI 64*0e31666dSChris Packham 65*0e31666dSChris Packham /* Environment in SPI NOR flash */ 66*0e31666dSChris Packham #define CONFIG_ENV_SPI_BUS CONFIG_SF_DEFAULT_BUS 67*0e31666dSChris Packham #define CONFIG_ENV_SPI_MODE CONFIG_SF_DEFAULT_MODE 68*0e31666dSChris Packham #define CONFIG_ENV_OFFSET (1 << 20) /* 1MiB in */ 69*0e31666dSChris Packham #define CONFIG_ENV_SIZE (64 << 10) /* 64KiB */ 70*0e31666dSChris Packham #define CONFIG_ENV_SECT_SIZE (256 << 10) /* 256KiB sectors */ 71*0e31666dSChris Packham #define CONFIG_ENV_ADDR CONFIG_ENV_OFFSET 72*0e31666dSChris Packham 73*0e31666dSChris Packham #define CONFIG_PHY_MARVELL /* there is a marvell phy */ 74*0e31666dSChris Packham #define PHY_ANEG_TIMEOUT 8000 /* PHY needs a longer aneg time */ 75*0e31666dSChris Packham 76*0e31666dSChris Packham /* PCIe support */ 77*0e31666dSChris Packham #ifndef CONFIG_SPL_BUILD 78*0e31666dSChris Packham #define CONFIG_PCI_MVEBU 79*0e31666dSChris Packham #define CONFIG_PCI_SCAN_SHOW 80*0e31666dSChris Packham #endif 81*0e31666dSChris Packham 82*0e31666dSChris Packham /* NAND */ 83*0e31666dSChris Packham #define CONFIG_SYS_NAND_USE_FLASH_BBT 84*0e31666dSChris Packham #define CONFIG_SYS_NAND_ONFI_DETECTION 85*0e31666dSChris Packham #define CONFIG_CMD_UBI 86*0e31666dSChris Packham #define CONFIG_CMD_UBIFS 87*0e31666dSChris Packham #define CONFIG_LZO 88*0e31666dSChris Packham #define CONFIG_MTD_DEVICE 89*0e31666dSChris Packham #define CONFIG_CMD_MTDPARTS 90*0e31666dSChris Packham 91*0e31666dSChris Packham #define CONFIG_SYS_MALLOC_LEN (4 << 20) 92*0e31666dSChris Packham 93*0e31666dSChris Packham #include <asm/arch/config.h> 94*0e31666dSChris Packham 95*0e31666dSChris Packham /* 96*0e31666dSChris Packham * Other required minimal configurations 97*0e31666dSChris Packham */ 98*0e31666dSChris Packham #define CONFIG_ARCH_CPU_INIT /* call arch_cpu_init() */ 99*0e31666dSChris Packham #define CONFIG_SYS_RESET_ADDRESS 0xffff0000 /* Rst Vector Adr */ 100*0e31666dSChris Packham 101*0e31666dSChris Packham #define CONFIG_SYS_ALT_MEMTEST 102*0e31666dSChris Packham 103*0e31666dSChris Packham /* Keep device tree and initrd in low memory so the kernel can access them */ 104*0e31666dSChris Packham #define CONFIG_EXTRA_ENV_SETTINGS \ 105*0e31666dSChris Packham "fdt_high=0x10000000\0" \ 106*0e31666dSChris Packham "initrd_high=0x10000000\0" 107*0e31666dSChris Packham 108*0e31666dSChris Packham #define CONFIG_SYS_LOAD_ADDR 0x1000000 109*0e31666dSChris Packham #define CONFIG_UBI_PART user 110*0e31666dSChris Packham #define CONFIG_UBIFS_VOLUME user 111*0e31666dSChris Packham 112*0e31666dSChris Packham /* SPL */ 113*0e31666dSChris Packham 114*0e31666dSChris Packham /* Defines for SPL */ 115*0e31666dSChris Packham #define CONFIG_SPL_SIZE (140 << 10) 116*0e31666dSChris Packham #define CONFIG_SPL_TEXT_BASE 0x40000030 117*0e31666dSChris Packham #define CONFIG_SPL_MAX_SIZE (CONFIG_SPL_SIZE - 0x0030) 118*0e31666dSChris Packham 119*0e31666dSChris Packham #define CONFIG_SPL_BSS_START_ADDR (0x40000000 + CONFIG_SPL_SIZE) 120*0e31666dSChris Packham #define CONFIG_SPL_BSS_MAX_SIZE (16 << 10) 121*0e31666dSChris Packham 122*0e31666dSChris Packham #ifdef CONFIG_SPL_BUILD 123*0e31666dSChris Packham #define CONFIG_SYS_MALLOC_SIMPLE 124*0e31666dSChris Packham #endif 125*0e31666dSChris Packham 126*0e31666dSChris Packham #define CONFIG_SPL_STACK (0x40000000 + ((192 - 16) << 10)) 127*0e31666dSChris Packham #define CONFIG_SPL_BOOTROM_SAVE (CONFIG_SPL_STACK + 4) 128*0e31666dSChris Packham 129*0e31666dSChris Packham /* SPL related SPI defines */ 130*0e31666dSChris Packham #define CONFIG_SPL_SPI_LOAD 131*0e31666dSChris Packham #define CONFIG_SYS_SPI_U_BOOT_OFFS 0x24000 132*0e31666dSChris Packham #define CONFIG_SYS_U_BOOT_OFFS CONFIG_SYS_SPI_U_BOOT_OFFS 133*0e31666dSChris Packham 134*0e31666dSChris Packham #endif /* _CONFIG_X530_H */ 135