blob: 5774184300c2adcf4184af63bffd1a5b55705ff6 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Vanessa Maegima27142c32017-05-08 13:17:28 -03002/*
3 * Copyright (C) 2017 NXP Semiconductors
4 *
5 * Configuration settings for the i.MX7D Pico board.
Vanessa Maegima27142c32017-05-08 13:17:28 -03006 */
7
8#ifndef __PICO_IMX7D_CONFIG_H
9#define __PICO_IMX7D_CONFIG_H
10
11#include "mx7_common.h"
12
Tom Rinia17aa192022-12-04 10:04:55 -050013#define CFG_MXC_UART_BASE UART5_IPS_BASE_ADDR
Vanessa Maegima27142c32017-05-08 13:17:28 -030014
Vanessa Maegima27142c32017-05-08 13:17:28 -030015/* MMC Config */
Tom Rini376b88a2022-10-28 20:27:13 -040016#define CFG_SYS_FSL_ESDHC_ADDR 0
Vanessa Maegima27142c32017-05-08 13:17:28 -030017
Tom Rini3aef00d2022-12-04 10:03:38 -050018#define CFG_DFU_ENV_SETTINGS \
Fabio Berton99b3f9d2018-06-29 15:19:12 -030019 "dfu_alt_info=" \
Otavio Salvadorb3aeded2018-09-28 11:22:36 -030020 "spl raw 0x2 0x400;" \
Joris Offougae23b5892019-04-04 14:00:56 +020021 "u-boot raw 0x8a 0x1000;" \
Otavio Salvador304058c2018-06-29 15:19:09 -030022 "/boot/zImage ext4 0 1;" \
Otavio Salvadorb50fc2a2018-09-14 15:53:35 -030023 "/boot/imx7d-pico-hobbit.dtb ext4 0 1;" \
Otavio Salvador304058c2018-06-29 15:19:09 -030024 "/boot/imx7d-pico-pi.dtb ext4 0 1;" \
25 "rootfs part 0 1\0" \
26
Jun Nie92febe82019-05-08 14:38:33 +080027/* When booting with FIT specify the node entry containing boot.scr */
28#if defined(CONFIG_FIT)
29#define PICO_BOOT_ENV \
Jun Niea81dc962019-07-16 15:42:57 +080030 BOOTENV \
31 "fdtovaddr=0x83100000\0" \
32 "scriptaddr=0x83200000\0" \
33 "mmcargs=setenv bootargs console=${console},${baudrate} " \
34 "rootwait rw\0" \
35 "boot_a_script=" \
36 "load ${devtype} ${devnum}:${distro_bootpart} " \
37 "${scriptaddr} ${prefix}${script}; " \
38 "iminfo ${scriptaddr};" \
39 "if test $? -eq 1; then hab_failsafe; fi;" \
40 "source ${scriptaddr}:bootscr\0"
Jun Nie92febe82019-05-08 14:38:33 +080041#else
42#define PICO_BOOT_ENV \
Otavio Salvadorb50fc2a2018-09-14 15:53:35 -030043 "bootmenu_0=Boot using PICO-Hobbit baseboard=" \
44 "setenv fdtfile imx7d-pico-hobbit.dtb\0" \
Otavio Salvadorc7a06122019-04-11 09:17:48 -030045 "bootmenu_1=Boot using PICO-Dwarf baseboard=" \
46 "setenv fdtfile imx7d-pico-dwarf.dtb\0" \
Otavio Salvador25def3e2019-04-11 09:19:42 -030047 "bootmenu_2=Boot using PICO-Nymph baseboard=" \
48 "setenv fdtfile imx7d-pico-nymph.dtb\0" \
49 "bootmenu_3=Boot using PICO-Pi baseboard=" \
Otavio Salvadorab10d322018-06-29 15:19:13 -030050 "setenv fdtfile imx7d-pico-pi.dtb\0" \
Jun Nie92febe82019-05-08 14:38:33 +080051 BOOTENV
52#endif
53
Tom Rinic9edebe2022-12-04 10:03:50 -050054#define CFG_EXTRA_ENV_SETTINGS \
Vanessa Maegima27142c32017-05-08 13:17:28 -030055 "image=zImage\0" \
Fabio Estevamfb3532d2018-12-11 16:40:38 -020056 "splashpos=m,m\0" \
Tom Rini9004ee02021-08-23 10:25:30 -040057 "splashimage=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
Vanessa Maegima27142c32017-05-08 13:17:28 -030058 "console=ttymxc4\0" \
59 "fdt_high=0xffffffff\0" \
60 "initrd_high=0xffffffff\0" \
Otavio Salvadordd3a22b2018-06-29 15:19:17 -030061 "fdtfile=" CONFIG_DEFAULT_FDT_FILE "\0" \
Fabio Estevamfb3532d2018-12-11 16:40:38 -020062 "videomode=video=ctfb:x:800,y:480,depth:24,mode:0,pclk:30000,le:46,ri:210,up:22,lo:23,hs:20,vs:10,sync:0,vmode:0\0" \
Vanessa Maegima27142c32017-05-08 13:17:28 -030063 "fdt_addr=0x83000000\0" \
Fabio Estevam821f6a62018-06-29 15:19:06 -030064 "fdt_addr_r=0x83000000\0" \
Tom Rini9004ee02021-08-23 10:25:30 -040065 "kernel_addr_r=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
66 "pxefile_addr_r=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
Fabio Estevam821f6a62018-06-29 15:19:06 -030067 "ramdisk_addr_r=0x83000000\0" \
68 "ramdiskaddr=0x83000000\0" \
Tom Rini9004ee02021-08-23 10:25:30 -040069 "scriptaddr=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
Tom Rini3aef00d2022-12-04 10:03:38 -050070 CFG_DFU_ENV_SETTINGS \
Otavio Salvadorab10d322018-06-29 15:19:13 -030071 "findfdt=" \
72 "if test $fdtfile = ask ; then " \
73 "bootmenu -1; fi;" \
74 "if test $fdtfile != ask ; then " \
75 "saveenv; fi;\0" \
Otavio Salvador3dc4bc52018-06-29 15:19:07 -030076 "finduuid=part uuid mmc 0:1 uuid\0" \
Otavio Salvador85910c72018-06-29 15:19:08 -030077 "partitions=" \
78 "uuid_disk=${uuid_gpt_disk};" \
79 "name=rootfs,size=0,uuid=${uuid_gpt_rootfs}\0" \
Fabio Estevam5c458262018-06-29 15:19:10 -030080 "fastboot_partition_alias_system=rootfs\0" \
Otavio Salvador85910c72018-06-29 15:19:08 -030081 "setup_emmc=mmc dev 0; gpt write mmc 0 $partitions; reset;\0" \
Jun Nie92febe82019-05-08 14:38:33 +080082 PICO_BOOT_ENV
83
Fabio Estevam821f6a62018-06-29 15:19:06 -030084#define BOOT_TARGET_DEVICES(func) \
85 func(MMC, mmc, 0) \
Otavio Salvador1de7ae02018-09-28 11:22:37 -030086 func(USB, usb, 0) \
87 func(PXE, pxe, na) \
Fabio Estevam821f6a62018-06-29 15:19:06 -030088 func(DHCP, dhcp, na)
Vanessa Maegima27142c32017-05-08 13:17:28 -030089
Fabio Estevam821f6a62018-06-29 15:19:06 -030090#include <config_distro_bootcmd.h>
Simon Glassfb64e362020-05-10 11:40:09 -060091#include <linux/stringify.h>
Vanessa Maegima27142c32017-05-08 13:17:28 -030092
Vanessa Maegima27142c32017-05-08 13:17:28 -030093/* Physical Memory Map */
Vanessa Maegima27142c32017-05-08 13:17:28 -030094#define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
95
Tom Rinibb4dd962022-11-16 13:10:37 -050096#define CFG_SYS_SDRAM_BASE PHYS_SDRAM
Tom Rini6a5dccc2022-11-16 13:10:41 -050097#define CFG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
98#define CFG_SYS_INIT_RAM_SIZE IRAM_SIZE
Vanessa Maegima27142c32017-05-08 13:17:28 -030099
Vanessa Maegima27142c32017-05-08 13:17:28 -0300100/* PMIC */
Tom Riniadce81d2022-12-04 10:13:36 -0500101#define CFG_POWER_PFUZE3000_I2C_ADDR 0x08
Vanessa Maegima27142c32017-05-08 13:17:28 -0300102
103/* FLASH and environment organization */
Vanessa Maegima27142c32017-05-08 13:17:28 -0300104
Fabio Estevamc899a652018-11-30 12:52:13 -0200105/* Environment starts at 768k = 768 * 1024 = 786432 */
Fabio Estevamc899a652018-11-30 12:52:13 -0200106
Tom Rini376b88a2022-10-28 20:27:13 -0400107#define CFG_SYS_FSL_USDHC_NUM 2
Vanessa Maegima27142c32017-05-08 13:17:28 -0300108
Vanessa Maegima27142c32017-05-08 13:17:28 -0300109/* USB Configs */
Tom Rinib9796e82022-12-04 10:04:56 -0500110#define CFG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW)
111#define CFG_MXC_USB_FLAGS 0
Vanessa Maegima27142c32017-05-08 13:17:28 -0300112
Vanessa Maegima27142c32017-05-08 13:17:28 -0300113#endif