blob: b1ffcc8872e4e1bea479b58e44b91f769e90cae1 [file] [log] [blame]
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +00001/*
2 * Copyright (C) 2013, ISEE 2007 SL - http://www.isee.biz/
3 *
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License as
6 * published by the Free Software Foundation version 2.
7 *
8 * This program is distributed "as is" WITHOUT ANY WARRANTY of any
9 * kind, whether express or implied; without even the implied warranty
10 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 */
13
Ladislav Michl10bdc712017-04-01 17:17:16 +020014#ifndef __CONFIG_IGEP003X_H
15#define __CONFIG_IGEP003X_H
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000016
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020017#define CONFIG_NAND
18#include <configs/ti_am335x_common.h>
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000019
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000020/* Clock defines */
21#define V_OSCK 24000000 /* Clock output from T2 */
22#define V_SCLK (V_OSCK)
23
Ladislav Michlb6bd7f92017-04-01 17:17:57 +020024#define CONFIG_ENV_SIZE (96 << 10) /* 96 KiB */
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000025
Enric Balletbo i Serrabace5162013-07-25 09:27:39 +020026/* Make the verbose messages from UBI stop printing */
27#define CONFIG_UBI_SILENCE_MSG
28#define CONFIG_UBIFS_SILENCE_MSG
29
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000030#define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020031
32#ifndef CONFIG_SPL_BUILD
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000033#define CONFIG_EXTRA_ENV_SETTINGS \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020034 DEFAULT_LINUX_BOOT_ENV \
Enric Balletbò i Serra620b91d2013-07-25 09:27:37 +020035 "bootdir=/boot\0" \
36 "bootfile=zImage\0" \
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000037 "console=ttyO0,115200n8\0" \
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000038 "mmcdev=0\0" \
39 "mmcroot=/dev/mmcblk0p2 rw\0" \
40 "mmcrootfstype=ext4 rootwait\0" \
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000041 "mmcargs=setenv bootargs console=${console} " \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020042 "${optargs} " \
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000043 "root=${mmcroot} " \
44 "rootfstype=${mmcrootfstype}\0" \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020045 "bootenv=uEnv.txt\0" \
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +000046 "loadbootenv=load mmc ${mmcdev} ${loadaddr} ${bootenv}\0" \
47 "importbootenv=echo Importing environment from mmc ...; " \
Enric Balletbò i Serra620b91d2013-07-25 09:27:37 +020048 "env import -t ${loadaddr} ${filesize}\0" \
49 "mmcload=load mmc ${mmcdev}:2 ${loadaddr} ${bootdir}/${bootfile}; " \
Pau Pajuelob2310f12017-04-01 17:18:40 +020050 "load mmc ${mmcdev}:2 ${fdtaddr} ${bootdir}/${fdtfile}\0" \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020051 "mmcboot=mmc dev ${mmcdev}; " \
52 "if mmc rescan; then " \
53 "echo SD/MMC found on device ${mmcdev};" \
54 "if run loadbootenv; then " \
55 "echo Loaded environment from ${bootenv};" \
56 "run importbootenv;" \
57 "fi;" \
58 "if test -n $uenvcmd; then " \
59 "echo Running uenvcmd ...;" \
60 "run uenvcmd;" \
61 "fi;" \
62 "if run mmcload; then " \
63 "run mmcargs; " \
64 "bootz ${loadaddr} - ${fdtaddr};" \
65 "fi;" \
66 "fi;\0" \
67 "mtdids=" MTDIDS_DEFAULT "\0" \
68 "mtdparts=" MTDPARTS_DEFAULT "\0" \
Ladislav Michlb6bd7f92017-04-01 17:17:57 +020069 "nandroot=ubi0:rootfs rw ubi.mtd=1\0" \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020070 "nandrootfstype=ubifs rootwait\0" \
Ladislav Michlb6bd7f92017-04-01 17:17:57 +020071 "nandload=ubi part UBI; " \
72 "ubi read ${loadaddr} kernel; " \
73 "ubi read ${fdtaddr} dtb \0" \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +020074 "nandargs=setenv bootargs console=${console} " \
75 "${optargs} " \
76 "root=${nandroot} " \
77 "rootfstype=${nandrootfstype} \0" \
78 "nandboot=echo Booting from nand ...; " \
79 "run nandargs; " \
80 "run nandload; " \
Pau Pajuelob2310f12017-04-01 17:18:40 +020081 "bootz ${loadaddr} - ${fdtaddr} \0" \
Pau Pajuelo305f1f22017-04-01 17:19:43 +020082 "netload=tftpboot ${loadaddr} ${bootfile}; " \
83 "tftpboot ${fdtaddr} ${fdtfile} \0" \
84 "netargs=setenv bootargs console=${console} " \
85 "${optargs} " \
86 "root=/dev/nfs " \
87 "ip=${ipaddr} nfsroot=${serverip}:${rootnfs},v3,tcp \0" \
88 "netboot=echo Booting from net ...; " \
89 "run netargs; " \
90 "run netload; " \
91 "bootz ${loadaddr} - ${fdtaddr} \0" \
Pau Pajuelob2310f12017-04-01 17:18:40 +020092 "findfdt="\
93 "if test ${board_name} = igep0033; then " \
94 "setenv fdtfile am335x-igep-base0033.dtb; fi; " \
95 "if test ${board_name} = igep0034; then " \
96 "setenv fdtfile am335x-igep-base0040.dtb; fi; " \
97 "if test ${board_name} = igep0034-lite; then " \
98 "setenv fdtfile am335x-igep-base0040-lite.dtb; fi; " \
99 "if test ${fdtfile} = ''; then " \
100 "echo WARNING: Could not determine device tree to use; fi; \0"
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +0200101#endif
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000102
103#define CONFIG_BOOTCOMMAND \
Pau Pajuelob2310f12017-04-01 17:18:40 +0200104 "run findfdt;" \
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +0200105 "run mmcboot;" \
Pau Pajuelo305f1f22017-04-01 17:19:43 +0200106 "run nandboot;" \
107 "run netboot;"
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000108
109/* NS16550 Configuration */
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000110#define CONFIG_SYS_NS16550_COM1 0x44e09000 /* UART0 */
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000111#define CONFIG_CONS_INDEX 1
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000112
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000113/* Ethernet support */
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000114#define CONFIG_PHYLIB
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000115#define CONFIG_PHY_SMSC
116
117/* NAND support */
pekon gupta89ad1dc2013-11-18 19:02:59 +0530118#define CONFIG_NAND_OMAP_ELM
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000119#define CONFIG_SYS_NAND_ONFI_DETECTION 1
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000120
121#define CONFIG_MTD_PARTITIONS
122#define CONFIG_MTD_DEVICE
123#define CONFIG_RBTREE
124#define CONFIG_LZO
125
Enric Balletbo i Serrabace5162013-07-25 09:27:39 +0200126#define MTDIDS_DEFAULT "nand0=omap2-nand.0"
Ladislav Michlb6bd7f92017-04-01 17:17:57 +0200127#define MTDPARTS_DEFAULT "mtdparts=omap2-nand.0:512k(SPL),-(UBI)"
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000128
Enric Balletbo i Serrab78093b2014-09-03 17:59:57 +0200129/* SPL */
Lokesh Vutla899fd3e2017-04-26 13:37:07 +0530130#define CONFIG_SPL_LDSCRIPT "arch/arm/mach-omap2/u-boot-spl.lds"
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000131
Ladislav Michlb6bd7f92017-04-01 17:17:57 +0200132/* UBI configuration */
133#define CONFIG_SPL_UBI 1
134#define CONFIG_SPL_UBI_MAX_VOL_LEBS 256
135#define CONFIG_SPL_UBI_MAX_PEB_SIZE (256*1024)
136#define CONFIG_SPL_UBI_MAX_PEBS 4096
137#define CONFIG_SPL_UBI_VOL_IDS 8
138#define CONFIG_SPL_UBI_LOAD_MONITOR_ID 0
139#define CONFIG_SPL_UBI_LOAD_KERNEL_ID 3
140#define CONFIG_SPL_UBI_LOAD_ARGS_ID 4
141#define CONFIG_SPL_UBI_PEB_OFFSET 4
142#define CONFIG_SPL_UBI_VID_OFFSET 512
143#define CONFIG_SPL_UBI_LEB_START 2048
144#define CONFIG_SPL_UBI_INFO_ADDR 0x88080000
145
146/* environment organization */
147#define CONFIG_ENV_IS_IN_UBI 1
148#define CONFIG_ENV_UBI_PART "UBI"
149#define CONFIG_ENV_UBI_VOLUME "config"
150#define CONFIG_ENV_UBI_VOLUME_REDUND "config_r"
151
152/* NAND config */
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000153#define CONFIG_SYS_NAND_5_ADDR_CYCLE
154#define CONFIG_SYS_NAND_PAGE_COUNT (CONFIG_SYS_NAND_BLOCK_SIZE / \
155 CONFIG_SYS_NAND_PAGE_SIZE)
156#define CONFIG_SYS_NAND_PAGE_SIZE 2048
157#define CONFIG_SYS_NAND_OOBSIZE 64
158#define CONFIG_SYS_NAND_BLOCK_SIZE (128*1024)
159#define CONFIG_SYS_NAND_BAD_BLOCK_POS NAND_LARGE_BADBLOCK_POS
160#define CONFIG_SYS_NAND_ECCPOS { 2, 3, 4, 5, 6, 7, 8, 9, \
161 10, 11, 12, 13, 14, 15, 16, 17, \
162 18, 19, 20, 21, 22, 23, 24, 25, \
163 26, 27, 28, 29, 30, 31, 32, 33, \
164 34, 35, 36, 37, 38, 39, 40, 41, \
165 42, 43, 44, 45, 46, 47, 48, 49, \
166 50, 51, 52, 53, 54, 55, 56, 57, }
167
168#define CONFIG_SYS_NAND_ECCSIZE 512
169#define CONFIG_SYS_NAND_ECCBYTES 14
pekon gupta3ef49732013-11-18 19:03:01 +0530170#define CONFIG_NAND_OMAP_ECCSCHEME OMAP_ECC_BCH8_CODE_HW
Enric Balletbo i Serra9b96f462013-04-04 22:27:58 +0000171
Ladislav Michl10bdc712017-04-01 17:17:16 +0200172#endif /* ! __CONFIG_IGEP003X_H */