blob: 587963963adf5af8e682b9521bb92b5422074766 [file] [log] [blame]
Marek Vasut2e499842010-05-11 04:31:44 +02001/*
2 * Toradex Colibri PXA270 configuration file
3 *
4 * Copyright (C) 2010 Marek Vasut <marek.vasut@gmail.com>
Marcel Ziswilerb891d012016-11-16 17:49:23 +01005 * Copyright (C) 2015-2016 Marcel Ziswiler <marcel@ziswiler.com>
Marek Vasut2e499842010-05-11 04:31:44 +02006 *
Wolfgang Denk3765b3e2013-10-07 13:07:26 +02007 * SPDX-License-Identifier: GPL-2.0+
Marek Vasut2e499842010-05-11 04:31:44 +02008 */
9
Marcel Ziswiler7c49b522015-03-01 00:53:15 +010010#ifndef __CONFIG_H
11#define __CONFIG_H
Marek Vasut2e499842010-05-11 04:31:44 +020012
13/*
14 * High Level Board Configuration Options
15 */
Marek Vasutabc20ab2011-11-26 07:20:07 +010016#define CONFIG_CPU_PXA27X 1 /* Marvell PXA270 CPU */
Marek Vasutf9f54862011-11-26 07:15:36 +010017#define CONFIG_SYS_TEXT_BASE 0x0
Marcel Ziswiler7c49b522015-03-01 00:53:15 +010018/* Avoid overwriting factory configuration block */
19#define CONFIG_BOARD_SIZE_LIMIT 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +020020
Marcel Ziswiler4f9bbd92015-08-16 04:16:35 +020021/* We will never enable dcache because we have to setup MMU first */
22#define CONFIG_SYS_DCACHE_OFF
23
Marcel Ziswilerb891d012016-11-16 17:49:23 +010024#define CONFIG_DISPLAY_BOARDINFO_LATE /* Calls show_board_info() */
25
Marek Vasut2e499842010-05-11 04:31:44 +020026/*
27 * Environment settings
28 */
Marek Vasutf9f54862011-11-26 07:15:36 +010029#define CONFIG_ENV_OVERWRITE
Marcel Ziswilerb891d012016-11-16 17:49:23 +010030#define CONFIG_ENV_VARS_UBOOT_CONFIG
31#define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
Marek Vasutf9f54862011-11-26 07:15:36 +010032#define CONFIG_SYS_MALLOC_LEN (128 * 1024)
33#define CONFIG_ARCH_CPU_INIT
Marek Vasut2e499842010-05-11 04:31:44 +020034#define CONFIG_BOOTCOMMAND \
Marcel Ziswiler99d672f2015-03-01 00:53:16 +010035 "if fatload mmc 0 0xa0000000 uImage; then " \
Marek Vasut2e499842010-05-11 04:31:44 +020036 "bootm 0xa0000000; " \
37 "fi; " \
38 "if usb reset && fatload usb 0 0xa0000000 uImage; then " \
39 "bootm 0xa0000000; " \
40 "fi; " \
Marcel Ziswiler99d672f2015-03-01 00:53:16 +010041 "bootm 0xc0000;"
Marek Vasut2e499842010-05-11 04:31:44 +020042#define CONFIG_BOOTARGS "console=tty0 console=ttyS0,115200"
43#define CONFIG_TIMESTAMP
Marek Vasut2e499842010-05-11 04:31:44 +020044#define CONFIG_CMDLINE_TAG
45#define CONFIG_SETUP_MEMORY_TAGS
Marek Vasut2e499842010-05-11 04:31:44 +020046
47/*
48 * Serial Console Configuration
49 */
Marek Vasut2e499842010-05-11 04:31:44 +020050
51/*
52 * Bootloader Components Configuration
53 */
Marek Vasut2e499842010-05-11 04:31:44 +020054
Marcel Ziswiler3664fa12015-08-16 04:16:36 +020055/* I2C support */
56#ifdef CONFIG_SYS_I2C
Marcel Ziswiler3664fa12015-08-16 04:16:36 +020057#define CONFIG_SYS_I2C_PXA
58#define CONFIG_PXA_STD_I2C
59#define CONFIG_PXA_PWR_I2C
60#define CONFIG_SYS_I2C_SPEED 100000
61#endif
62
Marcel Ziswiler4f9bbd92015-08-16 04:16:35 +020063/* LCD support */
64#ifdef CONFIG_LCD
65#define CONFIG_PXA_LCD
66#define CONFIG_PXA_VGA
Marcel Ziswiler4f9bbd92015-08-16 04:16:35 +020067#define CONFIG_LCD_LOGO
68#endif
69
Marek Vasut2e499842010-05-11 04:31:44 +020070/*
71 * Networking Configuration
Marek Vasut2e499842010-05-11 04:31:44 +020072 */
73#ifdef CONFIG_CMD_NET
Marek Vasut2e499842010-05-11 04:31:44 +020074
Marek Vasut2e499842010-05-11 04:31:44 +020075#define CONFIG_DRIVER_DM9000 1
76#define CONFIG_DM9000_BASE 0x08000000
77#define DM9000_IO (CONFIG_DM9000_BASE)
78#define DM9000_DATA (CONFIG_DM9000_BASE + 4)
79#define CONFIG_NET_RETRY_COUNT 10
80
81#define CONFIG_BOOTP_BOOTFILESIZE
82#define CONFIG_BOOTP_BOOTPATH
83#define CONFIG_BOOTP_GATEWAY
84#define CONFIG_BOOTP_HOSTNAME
85#endif
86
Marcel Ziswilerfe488a82015-03-01 00:53:14 +010087#undef CONFIG_SYS_LONGHELP /* Saves 10 KB */
Marek Vasutf9f54862011-11-26 07:15:36 +010088#define CONFIG_SYS_CBSIZE 256
89#define CONFIG_SYS_PBSIZE \
90 (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16)
91#define CONFIG_SYS_MAXARGS 16
92#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
Marek Vasut2e499842010-05-11 04:31:44 +020093#define CONFIG_SYS_DEVICE_NULLDEV 1
Marcel Ziswilerfc127d12016-11-14 21:40:27 +010094#undef CONFIG_CMDLINE_EDITING /* Saves 2.5 KB */
95#undef CONFIG_AUTO_COMPLETE /* Saves 2.5 KB */
Marek Vasutf9f54862011-11-26 07:15:36 +010096
Marek Vasut2e499842010-05-11 04:31:44 +020097/*
98 * Clock Configuration
99 */
Marek Vasutf9f54862011-11-26 07:15:36 +0100100#define CONFIG_SYS_CPUSPEED 0x290 /* 520MHz */
Marek Vasut2e499842010-05-11 04:31:44 +0200101
102/*
Marek Vasut2e499842010-05-11 04:31:44 +0200103 * DRAM Map
104 */
105#define CONFIG_NR_DRAM_BANKS 1 /* We have 1 bank of DRAM */
106#define PHYS_SDRAM_1 0xa0000000 /* SDRAM Bank #1 */
107#define PHYS_SDRAM_1_SIZE 0x04000000 /* 64 MB */
108
109#define CONFIG_SYS_DRAM_BASE 0xa0000000 /* CS0 */
110#define CONFIG_SYS_DRAM_SIZE 0x04000000 /* 64 MB DRAM */
111
112#define CONFIG_SYS_MEMTEST_START 0xa0400000 /* memtest works on */
113#define CONFIG_SYS_MEMTEST_END 0xa0800000 /* 4 ... 8 MB in DRAM */
114
Marek Vasutf9f54862011-11-26 07:15:36 +0100115#define CONFIG_SYS_LOAD_ADDR PHYS_SDRAM_1
Marek Vasut6ef6eb92010-09-23 09:46:57 +0200116#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
Marek Vasutf9f54862011-11-26 07:15:36 +0100117#define CONFIG_SYS_INIT_SP_ADDR 0x5c010000
Marek Vasut6ef6eb92010-09-23 09:46:57 +0200118
Marek Vasut2e499842010-05-11 04:31:44 +0200119/*
120 * NOR FLASH
121 */
122#ifdef CONFIG_CMD_FLASH
123#define PHYS_FLASH_1 0x00000000 /* Flash Bank #1 */
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200124#define PHYS_FLASH_SIZE 0x02000000 /* 32 MB */
Marek Vasut2e499842010-05-11 04:31:44 +0200125#define CONFIG_SYS_FLASH_BASE PHYS_FLASH_1
126
127#define CONFIG_SYS_FLASH_CFI
128#define CONFIG_FLASH_CFI_DRIVER 1
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200129#define CONFIG_SYS_FLASH_CFI_WIDTH FLASH_CFI_32BIT
Marek Vasut2e499842010-05-11 04:31:44 +0200130
131#define CONFIG_SYS_MAX_FLASH_SECT (4 + 255)
132#define CONFIG_SYS_MAX_FLASH_BANKS 1
133
Marek Vasutf9f54862011-11-26 07:15:36 +0100134#define CONFIG_SYS_FLASH_ERASE_TOUT (25 * CONFIG_SYS_HZ)
135#define CONFIG_SYS_FLASH_WRITE_TOUT (25 * CONFIG_SYS_HZ)
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200136#define CONFIG_SYS_FLASH_LOCK_TOUT (25 * CONFIG_SYS_HZ)
137#define CONFIG_SYS_FLASH_UNLOCK_TOUT (25 * CONFIG_SYS_HZ)
Marek Vasut2e499842010-05-11 04:31:44 +0200138
139#define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 1
140#define CONFIG_SYS_FLASH_PROTECTION 1
141
142#define CONFIG_ENV_IS_IN_FLASH 1
143
144#else /* No flash */
Marcel Ziswiler50dea462015-03-01 00:53:12 +0100145#define CONFIG_ENV_IS_NOWHERE
Marek Vasut2e499842010-05-11 04:31:44 +0200146#endif
147
Marek Vasutf9f54862011-11-26 07:15:36 +0100148#define CONFIG_SYS_MONITOR_BASE 0x0
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100149#define CONFIG_SYS_MONITOR_LEN 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +0200150
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100151/* Skip factory configuration block */
Marek Vasutf9f54862011-11-26 07:15:36 +0100152#define CONFIG_ENV_ADDR \
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100153 (CONFIG_SYS_MONITOR_BASE + CONFIG_SYS_MONITOR_LEN + 0x40000)
Marek Vasutf9f54862011-11-26 07:15:36 +0100154#define CONFIG_ENV_SIZE 0x40000
155#define CONFIG_ENV_SECT_SIZE 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +0200156
157/*
158 * GPIO settings
159 */
160#define CONFIG_SYS_GPSR0_VAL 0x00000000
161#define CONFIG_SYS_GPSR1_VAL 0x00020000
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100162#define CONFIG_SYS_GPSR2_VAL 0x0002c000
Marek Vasut2e499842010-05-11 04:31:44 +0200163#define CONFIG_SYS_GPSR3_VAL 0x00000000
164
165#define CONFIG_SYS_GPCR0_VAL 0x00000000
166#define CONFIG_SYS_GPCR1_VAL 0x00000000
167#define CONFIG_SYS_GPCR2_VAL 0x00000000
168#define CONFIG_SYS_GPCR3_VAL 0x00000000
169
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100170#define CONFIG_SYS_GPDR0_VAL 0xc8008000
171#define CONFIG_SYS_GPDR1_VAL 0xfc02a981
172#define CONFIG_SYS_GPDR2_VAL 0x92c3ffff
173#define CONFIG_SYS_GPDR3_VAL 0x0061e804
Marek Vasut2e499842010-05-11 04:31:44 +0200174
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100175#define CONFIG_SYS_GAFR0_L_VAL 0x80100000
176#define CONFIG_SYS_GAFR0_U_VAL 0xa5c00010
177#define CONFIG_SYS_GAFR1_L_VAL 0x6992901a
178#define CONFIG_SYS_GAFR1_U_VAL 0xaaa50008
179#define CONFIG_SYS_GAFR2_L_VAL 0xaaaaaaaa
180#define CONFIG_SYS_GAFR2_U_VAL 0x4109a002
181#define CONFIG_SYS_GAFR3_L_VAL 0x54000310
182#define CONFIG_SYS_GAFR3_U_VAL 0x00005401
Marek Vasut2e499842010-05-11 04:31:44 +0200183
184#define CONFIG_SYS_PSSR_VAL 0x30
185
186/*
187 * Clock settings
188 */
189#define CONFIG_SYS_CKEN 0x00500240
190#define CONFIG_SYS_CCCR 0x02000290
191
192/*
193 * Memory settings
194 */
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100195#define CONFIG_SYS_MSC0_VAL 0x9ee1c5f2
196#define CONFIG_SYS_MSC1_VAL 0x9ee1f994
197#define CONFIG_SYS_MSC2_VAL 0x9ee19ee1
198#define CONFIG_SYS_MDCNFG_VAL 0x090009c9
199#define CONFIG_SYS_MDREFR_VAL 0x2003a031
200#define CONFIG_SYS_MDMRS_VAL 0x00220022
201#define CONFIG_SYS_FLYCNFG_VAL 0x00010001
Marek Vasut2e499842010-05-11 04:31:44 +0200202#define CONFIG_SYS_SXCNFG_VAL 0x40044004
203
204/*
205 * PCMCIA and CF Interfaces
206 */
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100207#define CONFIG_SYS_MECR_VAL 0x00000000
208#define CONFIG_SYS_MCMEM0_VAL 0x00028307
Marek Vasut2e499842010-05-11 04:31:44 +0200209#define CONFIG_SYS_MCMEM1_VAL 0x00014307
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100210#define CONFIG_SYS_MCATT0_VAL 0x00038787
Marek Vasut2e499842010-05-11 04:31:44 +0200211#define CONFIG_SYS_MCATT1_VAL 0x0001c787
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100212#define CONFIG_SYS_MCIO0_VAL 0x0002830f
Marek Vasut2e499842010-05-11 04:31:44 +0200213#define CONFIG_SYS_MCIO1_VAL 0x0001430f
214
Marek Vasut67a1f002011-11-26 11:27:50 +0100215#include "pxa-common.h"
Marek Vasut2e499842010-05-11 04:31:44 +0200216
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100217#endif /* __CONFIG_H */