blob: 4aaed3ae7da7633bbe7263e55889d27c73610ca9 [file] [log] [blame]
Peng Fan86ac7a92018-11-20 10:20:00 +00001/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * Copyright 2018 NXP
4 */
5
6#ifndef __IMX8M_EVK_H
7#define __IMX8M_EVK_H
8
9#include <linux/sizes.h>
Simon Glass1af3c7f2020-05-10 11:40:09 -060010#include <linux/stringify.h>
Peng Fan86ac7a92018-11-20 10:20:00 +000011#include <asm/arch/imx-regs.h>
12
Oleksandr Suvorov13586e42021-08-29 22:39:12 +030013#define CONFIG_SYS_BOOTM_LEN (64 * SZ_1M)
Peng Fanb297c0d2020-07-28 17:28:57 +080014
Peng Fan86ac7a92018-11-20 10:20:00 +000015#define CONFIG_SPL_MAX_SIZE (124 * 1024)
16#define CONFIG_SYS_MONITOR_LEN (512 * 1024)
Peng Fan86ac7a92018-11-20 10:20:00 +000017
18#ifdef CONFIG_SPL_BUILD
19/*#define CONFIG_ENABLE_DDR_TRAINING_DEBUG*/
Peng Fan86ac7a92018-11-20 10:20:00 +000020#define CONFIG_SPL_STACK 0x187FF0
Peng Fan86ac7a92018-11-20 10:20:00 +000021#define CONFIG_SPL_BSS_START_ADDR 0x00180000
22#define CONFIG_SPL_BSS_MAX_SIZE 0x2000 /* 8 KB */
23#define CONFIG_SYS_SPL_MALLOC_START 0x42200000
24#define CONFIG_SYS_SPL_MALLOC_SIZE 0x80000 /* 512 KB */
25#define CONFIG_SYS_SPL_PTE_RAM_BASE 0x41580000
Peng Fan86ac7a92018-11-20 10:20:00 +000026
27/* malloc f used before GD_FLG_FULL_MALLOC_INIT set */
28#define CONFIG_MALLOC_F_ADDR 0x182000
29/* For RAW image gives a error info not panic */
30#define CONFIG_SPL_ABORT_ON_RAW_IMAGE
31
32#undef CONFIG_DM_MMC
Peng Fan86ac7a92018-11-20 10:20:00 +000033
Peng Fan86ac7a92018-11-20 10:20:00 +000034#define CONFIG_POWER_PFUZE100
35#define CONFIG_POWER_PFUZE100_I2C_ADDR 0x08
36#endif
37
Peng Fan86ac7a92018-11-20 10:20:00 +000038/* ENET Config */
39/* ENET1 */
40#if defined(CONFIG_CMD_NET)
Peng Fan86ac7a92018-11-20 10:20:00 +000041#define CONFIG_ETHPRIME "FEC"
42
Peng Fan86ac7a92018-11-20 10:20:00 +000043#define CONFIG_FEC_XCV_TYPE RGMII
44#define CONFIG_FEC_MXC_PHYADDR 0
45#define FEC_QUIRK_ENET_MAC
46
Peng Fan86ac7a92018-11-20 10:20:00 +000047#define IMX_FEC_BASE 0x30BE0000
Peng Fan86ac7a92018-11-20 10:20:00 +000048#endif
49
Alice Guo5b3c76e2021-01-14 16:23:23 +080050#ifndef CONFIG_SPL_BUILD
51#define BOOT_TARGET_DEVICES(func) \
52 func(MMC, mmc, 0) \
53 func(MMC, mmc, 1) \
54 func(DHCP, dhcp, na)
55
56#include <config_distro_bootcmd.h>
57#endif
58
Peng Fan86ac7a92018-11-20 10:20:00 +000059/* Initial environment variables */
60#define CONFIG_EXTRA_ENV_SETTINGS \
Alice Guo5b3c76e2021-01-14 16:23:23 +080061 BOOTENV \
Andrey Zhizhikinefaf9a22022-01-16 22:38:31 +010062 "scriptaddr=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
63 "kernel_addr_r=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
Peng Fan86ac7a92018-11-20 10:20:00 +000064 "image=Image\0" \
Fabio Estevam502f3ca2019-12-11 14:31:03 -030065 "console=ttymxc0,115200\0" \
Andrey Zhizhikinefaf9a22022-01-16 22:38:31 +010066 "fdt_addr_r=0x43000000\0" \
Peng Fan86ac7a92018-11-20 10:20:00 +000067 "boot_fdt=try\0" \
Andrey Zhizhikinefaf9a22022-01-16 22:38:31 +010068 "fdtfile=imx8mq-evk.dtb\0" \
Peng Fan86ac7a92018-11-20 10:20:00 +000069 "initrd_addr=0x43800000\0" \
Grygorii Tertychnyiacbc1d82020-08-21 15:39:43 +020070 "bootm_size=0x10000000\0" \
Tom Rinide35b8f2021-12-11 14:55:52 -050071 "mmcpart=1\0" \
Peng Fan86ac7a92018-11-20 10:20:00 +000072 "mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \
Peng Fan86ac7a92018-11-20 10:20:00 +000073
74/* Link Definitions */
Peng Fan86ac7a92018-11-20 10:20:00 +000075
76#define CONFIG_SYS_INIT_RAM_ADDR 0x40000000
77#define CONFIG_SYS_INIT_RAM_SIZE 0x80000
78#define CONFIG_SYS_INIT_SP_OFFSET \
79 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
80#define CONFIG_SYS_INIT_SP_ADDR \
81 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
82
Peng Fan86ac7a92018-11-20 10:20:00 +000083#define CONFIG_MMCROOT "/dev/mmcblk1p2" /* USDHC2 */
84
Peng Fan86ac7a92018-11-20 10:20:00 +000085#define CONFIG_SYS_SDRAM_BASE 0x40000000
86#define PHYS_SDRAM 0x40000000
87#define PHYS_SDRAM_SIZE 0xC0000000 /* 3GB DDR */
88
Peng Fan86ac7a92018-11-20 10:20:00 +000089#define CONFIG_MXC_UART_BASE UART1_BASE_ADDR
90
91/* Monitor Command Prompt */
Peng Fan86ac7a92018-11-20 10:20:00 +000092#define CONFIG_SYS_CBSIZE 1024
93#define CONFIG_SYS_MAXARGS 64
94#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
95#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + \
96 sizeof(CONFIG_SYS_PROMPT) + 16)
97
Peng Fan86ac7a92018-11-20 10:20:00 +000098#define CONFIG_SYS_FSL_USDHC_NUM 2
99#define CONFIG_SYS_FSL_ESDHC_ADDR 0
100
Peng Fan86ac7a92018-11-20 10:20:00 +0000101#endif