blob: b9d65697521bb754b6ccb093b979cf56f49573a1 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -04002/*
Enric Balletbò i Serradc7a9e62012-03-05 11:32:16 +00003 * Common configuration settings for IGEP technology based boards
4 *
5 * (C) Copyright 2012
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -04006 * ISEE 2007 SL, <www.iseebcn.com>
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -04007 */
8
Enric Balletbò i Serradc7a9e62012-03-05 11:32:16 +00009#ifndef __IGEP00X0_H
10#define __IGEP00X0_H
11
Enric Balletbò i Serrae37e9542013-12-06 21:30:24 +010012#include <configs/ti_omap3_common.h>
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -040013
Tom Rinifa2f81b2016-08-26 13:30:43 -040014/*
15 * We are only ever GP parts and will utilize all of the "downloaded image"
16 * area in SRAM which starts at 0x40200000 and ends at 0x4020FFFF (64KB).
17 */
Enric Balletbo i Serrae7fbcbc2016-05-03 08:59:24 +020018#undef CONFIG_SPL_TEXT_BASE
Enric Balletbo i Serrae7fbcbc2016-05-03 08:59:24 +020019#define CONFIG_SPL_TEXT_BASE 0x40200000
20
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -040021#define CONFIG_REVISION_TAG 1
22
Pau Pajuelo195dc232017-08-17 03:09:14 +020023/* GPIO banks */
24#define CONFIG_OMAP3_GPIO_2 /* GPIO32..63 is in GPIO bank 2 */
25#define CONFIG_OMAP3_GPIO_4 /* GPIO96..127 is in GPIO bank 4 */
26
27/* TPS65950 */
28#define PBIASLITEVMODE1 (1 << 8)
29
30/* LED */
31#define IGEP0020_GPIO_LED 27
32#define IGEP0030_GPIO_LED 16
33
34/* Board and revision detection GPIOs */
35#define IGEP0030_USB_TRANSCEIVER_RESET 54
36#define GPIO_IGEP00X0_BOARD_DETECTION 28
37#define GPIO_IGEP00X0_REVISION_DETECTION 129
Javier Martinez Canillas9d4f5422012-12-27 03:36:01 +000038
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -040039/* USB device configuration */
40#define CONFIG_USB_DEVICE 1
41#define CONFIG_USB_TTY 1
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -040042
43/* Change these to suit your needs */
44#define CONFIG_USBD_VENDORID 0x0451
45#define CONFIG_USBD_PRODUCTID 0x5678
46#define CONFIG_USBD_MANUFACTURER "Texas Instruments"
47#define CONFIG_USBD_PRODUCT_NAME "IGEP"
48
Enric Balletbò i Serra40372242015-09-07 08:28:09 +020049#ifndef CONFIG_SPL_BUILD
Enric Balletbo i Serra304a46c2011-04-19 09:16:36 -040050
Enric Balletbò i Serra40372242015-09-07 08:28:09 +020051/* Environment */
52#define ENV_DEVICE_SETTINGS \
53 "stdin=serial\0" \
54 "stdout=serial\0" \
55 "stderr=serial\0"
56
57#define MEM_LAYOUT_SETTINGS \
58 DEFAULT_LINUX_BOOT_ENV \
59 "scriptaddr=0x87E00000\0" \
60 "pxefile_addr_r=0x87F00000\0"
61
62#define BOOT_TARGET_DEVICES(func) \
63 func(MMC, mmc, 0)
64
65#include <config_distro_bootcmd.h>
66
Pau Pajuelo195dc232017-08-17 03:09:14 +020067#define ENV_FINDFDT \
68 "findfdt="\
69 "if test ${board_name} = igep0020; then " \
70 "if test ${board_rev} = F; then " \
71 "setenv fdtfile omap3-igep0020-rev-f.dtb; " \
72 "else " \
73 "setenv fdtfile omap3-igep0020.dtb; fi; fi; " \
74 "if test ${board_name} = igep0030; then " \
75 "if test ${board_rev} = G; then " \
76 "setenv fdtfile omap3-igep0030-rev-g.dtb; " \
77 "else " \
78 "setenv fdtfile omap3-igep0030.dtb; fi; fi; " \
79 "if test ${fdtfile} = ''; then " \
80 "echo WARNING: Could not determine device tree to use; fi; \0"
81
Enric Balletbò i Serra40372242015-09-07 08:28:09 +020082#define CONFIG_EXTRA_ENV_SETTINGS \
Pau Pajuelo195dc232017-08-17 03:09:14 +020083 ENV_FINDFDT \
Enric Balletbò i Serra40372242015-09-07 08:28:09 +020084 ENV_DEVICE_SETTINGS \
85 MEM_LAYOUT_SETTINGS \
86 BOOTENV
87
88#endif
Enric Balletbo i Serra8a3f6bb2010-10-14 16:54:59 -040089
Ladislav Michla5debaa2016-07-12 20:28:33 +020090#define CONFIG_SYS_MTDPARTS_RUNTIME
Ladislav Michl4b9dc7c2016-07-12 20:28:32 +020091
92/* OneNAND config */
Ladislav Michl4b9dc7c2016-07-12 20:28:32 +020093#define CONFIG_USE_ONENAND_BOARD_INIT
94#define CONFIG_SYS_ONENAND_BASE ONENAND_MAP
95#define CONFIG_SYS_ONENAND_BLOCK_SIZE (128*1024)
Javier Martinez Canillasd271a612012-07-28 01:19:34 +000096
Ladislav Michl4b9dc7c2016-07-12 20:28:32 +020097/* NAND config */
Javier Martinez Canillasd271a612012-07-28 01:19:34 +000098#define CONFIG_SYS_NAND_5_ADDR_CYCLE
99#define CONFIG_SYS_NAND_PAGE_COUNT 64
100#define CONFIG_SYS_NAND_PAGE_SIZE 2048
101#define CONFIG_SYS_NAND_OOBSIZE 64
102#define CONFIG_SYS_NAND_BLOCK_SIZE (128*1024)
Ladislav Michl81fd8582015-10-12 18:09:14 +0200103#define CONFIG_SYS_NAND_BAD_BLOCK_POS NAND_LARGE_BADBLOCK_POS
104#define CONFIG_SYS_NAND_ECCPOS { 2, 3, 4, 5, 6, 7, 8, 9, \
105 10, 11, 12, 13, 14, 15, 16, 17, \
106 18, 19, 20, 21, 22, 23, 24, 25, \
107 26, 27, 28, 29, 30, 31, 32, 33, \
108 34, 35, 36, 37, 38, 39, 40, 41, \
109 42, 43, 44, 45, 46, 47, 48, 49, \
110 50, 51, 52, 53, 54, 55, 56, 57, }
Javier Martinez Canillasd271a612012-07-28 01:19:34 +0000111#define CONFIG_SYS_NAND_ECCSIZE 512
Ladislav Michl81fd8582015-10-12 18:09:14 +0200112#define CONFIG_SYS_NAND_ECCBYTES 14
113#define CONFIG_NAND_OMAP_ECCSCHEME OMAP_ECC_BCH8_CODE_HW_DETECTION_SW
Ladislav Michl81fd8582015-10-12 18:09:14 +0200114
Ladislav Michl4b9dc7c2016-07-12 20:28:32 +0200115/* UBI configuration */
116#define CONFIG_SPL_UBI 1
117#define CONFIG_SPL_UBI_MAX_VOL_LEBS 256
118#define CONFIG_SPL_UBI_MAX_PEB_SIZE (256*1024)
119#define CONFIG_SPL_UBI_MAX_PEBS 4096
120#define CONFIG_SPL_UBI_VOL_IDS 8
121#define CONFIG_SPL_UBI_LOAD_MONITOR_ID 0
122#define CONFIG_SPL_UBI_LOAD_KERNEL_ID 3
123#define CONFIG_SPL_UBI_LOAD_ARGS_ID 4
124#define CONFIG_SPL_UBI_PEB_OFFSET 4
125#define CONFIG_SPL_UBI_VID_OFFSET 512
126#define CONFIG_SPL_UBI_LEB_START 2048
127#define CONFIG_SPL_UBI_INFO_ADDR 0x88080000
128
129/* environment organization */
Ladislav Michl4b9dc7c2016-07-12 20:28:32 +0200130#define CONFIG_ENV_UBI_PART "UBI"
131#define CONFIG_ENV_UBI_VOLUME "config"
132#define CONFIG_ENV_UBI_VOLUME_REDUND "config_r"
Ladislav Michl4b9dc7c2016-07-12 20:28:32 +0200133#define CONFIG_ENV_SIZE (32*1024)
134
Enric Balletbò i Serradc7a9e62012-03-05 11:32:16 +0000135#endif /* __IGEP00X0_H */