blob: 8f464dd39f0b53757e090dcba01c19e985b07c80 [file] [log] [blame]
Igor Opaniuk309e65b2020-01-28 14:42:25 +01001/* SPDX-License-Identifier: GPL-2.0+ */
2/*
Oleksandr Suvorovf106e632021-10-09 22:41:11 +02003 * Copyright 2020-2021 Toradex
Igor Opaniuk309e65b2020-01-28 14:42:25 +01004 */
5
6#ifndef __VERDIN_IMX8MM_H
7#define __VERDIN_IMX8MM_H
8
9#include <asm/arch/imx-regs.h>
10#include <linux/sizes.h>
11
Igor Opaniuk309e65b2020-01-28 14:42:25 +010012#define CONFIG_SYS_MONITOR_LEN SZ_512K
Igor Opaniuk309e65b2020-01-28 14:42:25 +010013#define CONFIG_SYS_UBOOT_BASE \
14 (QSPI0_AMBA_BASE + CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR * 512)
15
Marek Vasut0d35f742021-05-18 00:40:30 +020016#define CONFIG_SYS_BOOTM_LEN SZ_64M
17
Igor Opaniuk309e65b2020-01-28 14:42:25 +010018#ifdef CONFIG_SPL_BUILD
Igor Opaniuk309e65b2020-01-28 14:42:25 +010019/* malloc f used before GD_FLG_FULL_MALLOC_INIT set */
20#define CONFIG_MALLOC_F_ADDR 0x930000
21/* For RAW image gives a error info not panic */
22#define CONFIG_SPL_ABORT_ON_RAW_IMAGE
23#endif
24
25#define MEM_LAYOUT_ENV_SETTINGS \
26 "fdt_addr_r=0x44000000\0" \
27 "kernel_addr_r=0x42000000\0" \
28 "ramdisk_addr_r=0x46400000\0" \
29 "scriptaddr=0x46000000\0"
30
Igor Opaniuk309e65b2020-01-28 14:42:25 +010031/* Enable Distro Boot */
32#ifndef CONFIG_SPL_BUILD
33#define BOOT_TARGET_DEVICES(func) \
34 func(MMC, mmc, 1) \
35 func(MMC, mmc, 0) \
36 func(DHCP, dhcp, na)
37#include <config_distro_bootcmd.h>
Igor Opaniuk309e65b2020-01-28 14:42:25 +010038#else
39#define BOOTENV
40#endif
41
42/* Initial environment variables */
43#define CONFIG_EXTRA_ENV_SETTINGS \
44 BOOTENV \
45 MEM_LAYOUT_ENV_SETTINGS \
46 "bootcmd_mfg=fastboot 0\0" \
Oleksandr Suvorovf106e632021-10-09 22:41:11 +020047 "boot_file=Image\0" \
Igor Opaniuk84c1a2d2022-04-13 11:33:27 +020048 "boot_script_dhcp=boot.scr\0" \
Igor Opaniuk309e65b2020-01-28 14:42:25 +010049 "console=ttymxc0\0" \
50 "fdt_addr=0x43000000\0" \
Oleksandr Suvorovf106e632021-10-09 22:41:11 +020051 "fdt_board=dev\0" \
Igor Opaniuk309e65b2020-01-28 14:42:25 +010052 "initrd_addr=0x43800000\0" \
53 "initrd_high=0xffffffffffffffff\0" \
Igor Opaniuk309e65b2020-01-28 14:42:25 +010054 "setup=setenv setupargs console=${console},${baudrate} " \
55 "console=tty1 consoleblank=0 earlycon\0" \
56 "update_uboot=askenv confirm Did you load flash.bin (y/N)?; " \
57 "if test \"$confirm\" = \"y\"; then " \
58 "setexpr blkcnt ${filesize} + 0x1ff && setexpr blkcnt " \
59 "${blkcnt} / 0x200; mmc dev 0 1; mmc write ${loadaddr} 0x2 " \
60 "${blkcnt}; fi\0"
61
62#define CONFIG_SYS_INIT_RAM_ADDR 0x40000000
63#define CONFIG_SYS_INIT_RAM_SIZE SZ_2M
Igor Opaniuk309e65b2020-01-28 14:42:25 +010064
Igor Opaniuk309e65b2020-01-28 14:42:25 +010065#if defined(CONFIG_ENV_IS_IN_MMC)
66/* Environment in eMMC, before config block at the end of 1st "boot sector" */
Igor Opaniuk309e65b2020-01-28 14:42:25 +010067#endif
68
Igor Opaniuk309e65b2020-01-28 14:42:25 +010069#define CONFIG_SYS_SDRAM_BASE 0x40000000
70
71/* SDRAM configuration */
72#define PHYS_SDRAM 0x40000000
73#define PHYS_SDRAM_SIZE SZ_2G /* 2GB DDR */
74
Igor Opaniuk309e65b2020-01-28 14:42:25 +010075/* UART */
Marek Vasut86a27482022-04-24 23:44:03 +020076#define CONFIG_MXC_UART_BASE UART_BASE_ADDR(1)
Igor Opaniuk309e65b2020-01-28 14:42:25 +010077
Igor Opaniuk309e65b2020-01-28 14:42:25 +010078/* ENET */
Igor Opaniuk309e65b2020-01-28 14:42:25 +010079#define CONFIG_FEC_MXC_PHYADDR 7
Igor Opaniuk309e65b2020-01-28 14:42:25 +010080
Marek Vasut0dcadcf2021-03-31 23:46:35 +020081/* USB Configs */
82#define CONFIG_EHCI_HCD_INIT_AFTER_RESET
83#define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW)
84#define CONFIG_USB_MAX_CONTROLLER_COUNT 2
85
Oleksandr Suvorovf106e632021-10-09 22:41:11 +020086#endif /* __VERDIN_IMX8MM_H */