/* SPDX-License-Identifier: GPL-2.0 */ /* * Config file for BuR BRPP2_IMX6 board * * Copyright (C) 2018 * B&R Industrial Automation GmbH - http://www.br-automation.com/ */ #ifndef __CONFIG_BRPP2_IMX6_H #define __CONFIG_BRPP2_IMX6_H #include <configs/bur_cfg_common.h> #include <asm/arch/imx-regs.h> /* -- i.mx6 specifica -- */ #ifndef CONFIG_SYS_L2CACHE_OFF #define CONFIG_SYS_L2_PL310 #define CONFIG_SYS_PL310_BASE L2_PL310_BASE #endif /* !CONFIG_SYS_L2CACHE_OFF */ #define CONFIG_BOARD_POSTCLK_INIT #define CONFIG_MXC_GPT_HCLK #define CONFIG_LOADADDR 0x10700000 #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR /* MMC */ #define CONFIG_FSL_USDHC /* Boot */ #define CONFIG_CMDLINE_TAG #define CONFIG_SETUP_MEMORY_TAGS #define CONFIG_INITRD_TAG #define CONFIG_MACH_TYPE 0xFFFFFFFF /* misc */ #define CONFIG_SYS_MALLOC_LEN (10 * 1024 * 1024) /* Environment */ #define CONFIG_EXTRA_ENV_SETTINGS \ BUR_COMMON_ENV \ "autoload=0\0" \ "cfgaddr=0x106F0000\0" \ "scraddr=0x10700000\0" \ "loadaddr=0x10800000\0" \ "dtbaddr=0x12000000\0" \ "ramaddr=0x12100000\0" \ "cfgscr=mw ${loadaddr} 0 128\0" \ "cfgscrl=fdt addr ${dtbaddr} &&"\ " sf probe; sf read ${cfgaddr} 0x40000 0x10000 && source ${cfgaddr}\0" \ "console=ttymxc0,115200n8 consoleblank=0 quiet\0" \ "t50args#0=setenv bootargs b_mode=${b_mode} console=${console} " \ " root=/dev/mmcblk0p2 rootfstype=ext4 rootwait panic=2 \0" \ "b_t50lgcy#0=" \ "load ${loaddev}:2 ${loadaddr} /boot/zImage && " \ "load ${loaddev}:2 ${dtbaddr} /boot/imx6dl-brppt50.dtb; " \ "run t50args#0; run cfgscrl; bootz ${loadaddr} - ${dtbaddr}\0" \ "t50args#1=setenv bootargs console=${console} b_mode=${b_mode}" \ " rootwait panic=2\0" \ "b_t50lgcy#1=" \ "load ${loaddev}:1 ${loadaddr} zImage && " \ "load ${loaddev}:1 ${dtbaddr} imx6dl-brppt50.dtb && " \ "load ${loaddev}:1 ${ramaddr} rootfsPPT50.uboot && " \ "run t50args#1; run cfgscrl; bootz ${loadaddr} ${ramaddr} ${dtbaddr}\0"\ "b_mmc0=load ${loaddev}:1 ${scraddr} bootscr.img && source ${scraddr}\0" \ "b_mmc1=load ${loaddev}:1 ${scraddr} /boot/bootscr.img && source ${scraddr}\0" \ "b_usb0=usb start && load usb 0 ${scraddr} bootscr.img && source ${scraddr}\0" \ "b_net=tftp ${scraddr} netscript.img && source ${scraddr}\0" \ "b_tgts_std=mmc0 mmc1 t50lgcy#0 t50lgcy#1 usb0 net\0" \ "b_tgts_rcy=t50lgcy#1 usb0 net\0" \ "b_tgts_pme=net usb0 mmc0 mmc1\0" \ "b_mode=4\0" \ "b_break=0\0" \ "b_deftgts=if test ${b_mode} = 12; then setenv b_tgts ${b_tgts_pme};" \ " elif test ${b_mode} = 0; then setenv b_tgts ${b_tgts_rcy};" \ " else setenv b_tgts ${b_tgts_std}; fi\0" \ "b_default=run b_deftgts; for target in ${b_tgts};"\ " do echo \"### booting ${target} ###\"; run b_${target};" \ " if test ${b_break} = 1; then; exit; fi; done\0" \ "loaddev=mmc 0\0" \ "altbootcmd=setenv b_mode 0; run b_default;\0" \ "bootlimit=1\0" \ "net2nor=sf probe && dhcp &&" \ " tftp ${loadaddr} SPL && sf erase 0 +${filesize} &&" \ " sf write ${loadaddr} 400 ${filesize} &&" \ " tftp ${loadaddr} u-boot-dtb.img && sf erase 0x100000 +${filesize} &&" \ " sf write ${loadaddr} 0x100000 ${filesize}\0" /* RAM */ #define PHYS_SDRAM_1 MMDC0_ARB_BASE_ADDR #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1 #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE #define CONFIG_SYS_INIT_SP_OFFSET \ (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) #define CONFIG_SYS_INIT_SP_ADDR \ (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET) /* Ethernet */ #define CONFIG_MII #define CONFIG_FEC_XCV_TYPE RGMII #define CONFIG_FEC_FIXED_SPEED _1000BASET #define CONFIG_ARP_TIMEOUT 1500UL /* USB Configs */ #define CONFIG_EHCI_HCD_INIT_AFTER_RESET #define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW) /* SPL */ #ifdef CONFIG_SPL #include "imx6_spl.h" #endif /* CONFIG_SPL */ #endif /* __CONFIG_BRPP2_IMX6_H */