blob: 3a42210c6e59d2cd02d797e3facf8a5c4ab1bbd2 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +05302/*
3 * Copyright 2016 Freescale Semiconductor
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +05304 */
5
6#ifndef __LS1012A_COMMON_H
7#define __LS1012A_COMMON_H
8
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +05309#define CONFIG_GICV2
10
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053011#include <asm/arch/config.h>
Bharat Bhushan9f076db2017-03-22 12:06:29 +053012#include <asm/arch/stream_id_lsch2.h>
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053013
Hou Zhiqiang904110c2017-01-10 16:44:15 +080014#define CONFIG_SYS_CLK_FREQ 125000000
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053015
16#define CONFIG_SKIP_LOWLEVEL_INIT
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053017
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +000018#ifdef CONFIG_TFABOOT
19#define CONFIG_SYS_INIT_SP_ADDR CONFIG_SYS_TEXT_BASE
20#else
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053021#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_FSL_OCRAM_BASE + 0xfff0)
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +000022#endif
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053023#define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_DDR_SDRAM_BASE + 0x10000000)
24
25#define CONFIG_SYS_DDR_SDRAM_BASE 0x80000000
26#define CONFIG_SYS_FSL_DDR_SDRAM_BASE_PHY 0
27#define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_DDR_SDRAM_BASE
Prabhakar Kushwaha7d559602017-01-30 17:05:22 +053028#define CONFIG_SYS_DDR_BLOCK2_BASE 0x880000000ULL
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053029
30/* Generic Timer Definitions */
Yuantian Tangb5845102017-10-12 14:29:26 +080031#define COUNTER_FREQUENCY 25000000 /* 25MHz */
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053032
33/* CSU */
34#define CONFIG_LAYERSCAPE_NS_ACCESS
35
36/* Size of malloc() pool */
37#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 128 * 1024)
38
39/*SPI device */
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +000040#if defined(CONFIG_QSPI_BOOT) || defined(CONFIG_TFABOOT)
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053041#define CONFIG_SYS_QE_FW_IN_SPIFLASH
42#define CONFIG_SYS_FMAN_FW_ADDR 0x400d0000
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053043#define CONFIG_SPI_FLASH_SPANSION
44#define CONFIG_FSL_SPI_INTERFACE
45#define CONFIG_SF_DATAFLASH
46
47#define CONFIG_FSL_QSPI
48#define QSPI0_AMBA_BASE 0x40000000
49#define CONFIG_SPI_FLASH_SPANSION
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053050
Suresh Gupta5e3f7632017-04-25 14:51:38 +053051#define FSL_QSPI_FLASH_SIZE SZ_64M
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053052#define FSL_QSPI_FLASH_NUM 2
53
54/*
55 * Environment
56 */
57#define CONFIG_ENV_OVERWRITE
58
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053059#define CONFIG_ENV_SIZE 0x40000 /* 256KB */
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +000060#ifdef CONFIG_TFABOOT
61#define CONFIG_ENV_OFFSET 0x500000 /* 5MB */
62#else
Bhaskar Upadhaya4def3782017-11-14 05:05:10 +053063#define CONFIG_ENV_OFFSET 0x300000 /* 3MB */
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +000064#endif
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053065#define CONFIG_ENV_SECT_SIZE 0x40000
66#endif
67
Yuantian Tangae02cf02018-01-03 15:53:10 +080068/* SATA */
69#define CONFIG_SCSI_AHCI_PLAT
70
71#define CONFIG_SYS_SATA AHCI_BASE_ADDR
72
73#define CONFIG_SYS_SCSI_MAX_SCSI_ID 1
74#define CONFIG_SYS_SCSI_MAX_LUN 1
75#define CONFIG_SYS_SCSI_MAX_DEVICE (CONFIG_SYS_SCSI_MAX_SCSI_ID * \
76 CONFIG_SYS_SCSI_MAX_LUN)
77
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053078/* I2C */
79#define CONFIG_SYS_I2C
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053080
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053081#define CONFIG_SYS_NS16550_SERIAL
82#define CONFIG_SYS_NS16550_REG_SIZE 1
Hou Zhiqiang904110c2017-01-10 16:44:15 +080083#define CONFIG_SYS_NS16550_CLK (get_serial_clock())
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053084
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053085#define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200 }
86
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +053087#define CONFIG_SYS_HZ 1000
88
89#define CONFIG_HWCONFIG
90#define HWCONFIG_BUFFER_SIZE 128
91
Rajesh Bhagata81357a2017-11-30 16:44:38 +053092#ifndef CONFIG_SPL_BUILD
93#define BOOT_TARGET_DEVICES(func) \
94 func(MMC, mmc, 0) \
Yunfeng Dingd2c49aa2019-02-19 14:44:04 +080095 func(USB, usb, 0) \
96 func(SCSI, scsi, 0) \
97 func(DHCP, dhcp, na)
Rajesh Bhagata81357a2017-11-30 16:44:38 +053098#include <config_distro_bootcmd.h>
99#endif
100
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530101/* Initial environment variables */
102#define CONFIG_EXTRA_ENV_SETTINGS \
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530103 "verify=no\0" \
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530104 "loadaddr=0x80100000\0" \
105 "kernel_addr=0x100000\0" \
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530106 "fdt_high=0xffffffffffffffff\0" \
107 "initrd_high=0xffffffffffffffff\0" \
Bhaskar Upadhaya4def3782017-11-14 05:05:10 +0530108 "kernel_start=0x1000000\0" \
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530109 "kernel_load=0xa0000000\0" \
110 "kernel_size=0x2800000\0" \
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530111
Rajesh Bhagata81357a2017-11-30 16:44:38 +0530112#undef CONFIG_BOOTCOMMAND
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +0000113#ifdef CONFIG_TFABOOT
114#define QSPI_NOR_BOOTCOMMAND "pfe stop; sf probe 0:0; sf read $kernel_load "\
115 "$kernel_start $kernel_size && "\
116 "bootm $kernel_load"
117#else
Calvin Johnsona802d1e2018-03-08 15:30:35 +0530118#define CONFIG_BOOTCOMMAND "pfe stop; sf probe 0:0; sf read $kernel_load "\
119 "$kernel_start $kernel_size && "\
120 "bootm $kernel_load"
Rajesh Bhagat1f6180d2018-11-05 18:02:53 +0000121#endif
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530122
123/* Monitor Command Prompt */
124#define CONFIG_SYS_CBSIZE 512 /* Console I/O Buffer Size */
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530125#define CONFIG_SYS_MAXARGS 64 /* max command args */
126
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530127#define CONFIG_SYS_BOOTM_LEN (64 << 20) /* Increase max gunzip size */
128
Simon Glass457e51c2017-05-17 08:23:10 -0600129#include <asm/arch/soc.h>
130
Prabhakar Kushwaha9d044fc2016-06-03 18:41:34 +0530131#endif /* __LS1012A_COMMON_H */