blob: 39fd94b3de345b9cd776f24650853c7cbb9d68a6 [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 Ziswiler85559672015-03-01 00:53:13 +01005 * Copyright (C) 2015 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
Marek Vasut2e499842010-05-11 04:31:44 +020024/*
25 * Environment settings
26 */
Marek Vasutf9f54862011-11-26 07:15:36 +010027#define CONFIG_ENV_OVERWRITE
28#define CONFIG_SYS_MALLOC_LEN (128 * 1024)
29#define CONFIG_ARCH_CPU_INIT
Marek Vasut2e499842010-05-11 04:31:44 +020030#define CONFIG_BOOTCOMMAND \
Marcel Ziswiler99d672f2015-03-01 00:53:16 +010031 "if fatload mmc 0 0xa0000000 uImage; then " \
Marek Vasut2e499842010-05-11 04:31:44 +020032 "bootm 0xa0000000; " \
33 "fi; " \
34 "if usb reset && fatload usb 0 0xa0000000 uImage; then " \
35 "bootm 0xa0000000; " \
36 "fi; " \
Marcel Ziswiler99d672f2015-03-01 00:53:16 +010037 "bootm 0xc0000;"
Marek Vasut2e499842010-05-11 04:31:44 +020038#define CONFIG_BOOTARGS "console=tty0 console=ttyS0,115200"
39#define CONFIG_TIMESTAMP
Marek Vasut2e499842010-05-11 04:31:44 +020040#define CONFIG_CMDLINE_TAG
41#define CONFIG_SETUP_MEMORY_TAGS
Marek Vasut2e499842010-05-11 04:31:44 +020042
43/*
44 * Serial Console Configuration
45 */
Marek Vasut2e499842010-05-11 04:31:44 +020046#define CONFIG_FFUART 1
Marek Vasutce6971c2012-09-12 12:36:25 +020047#define CONFIG_CONS_INDEX 3
Marek Vasut2e499842010-05-11 04:31:44 +020048#define CONFIG_BAUDRATE 115200
Marek Vasut2e499842010-05-11 04:31:44 +020049
50/*
51 * Bootloader Components Configuration
52 */
Marek Vasut2e499842010-05-11 04:31:44 +020053#define CONFIG_CMD_ENV
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
67#define CONFIG_SYS_WHITE_ON_BLACK
Marcel Ziswiler4f9bbd92015-08-16 04:16:35 +020068#define CONFIG_CMD_BMP
69#define CONFIG_LCD_LOGO
70#endif
71
Marek Vasut2e499842010-05-11 04:31:44 +020072/*
73 * Networking Configuration
Marek Vasut2e499842010-05-11 04:31:44 +020074 */
75#ifdef CONFIG_CMD_NET
Marek Vasut2e499842010-05-11 04:31:44 +020076
Marek Vasut2e499842010-05-11 04:31:44 +020077#define CONFIG_DRIVER_DM9000 1
78#define CONFIG_DM9000_BASE 0x08000000
79#define DM9000_IO (CONFIG_DM9000_BASE)
80#define DM9000_DATA (CONFIG_DM9000_BASE + 4)
81#define CONFIG_NET_RETRY_COUNT 10
82
83#define CONFIG_BOOTP_BOOTFILESIZE
84#define CONFIG_BOOTP_BOOTPATH
85#define CONFIG_BOOTP_GATEWAY
86#define CONFIG_BOOTP_HOSTNAME
87#endif
88
Marcel Ziswilerfe488a82015-03-01 00:53:14 +010089#undef CONFIG_SYS_LONGHELP /* Saves 10 KB */
Marek Vasutf9f54862011-11-26 07:15:36 +010090#define CONFIG_SYS_CBSIZE 256
91#define CONFIG_SYS_PBSIZE \
92 (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16)
93#define CONFIG_SYS_MAXARGS 16
94#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
Marek Vasut2e499842010-05-11 04:31:44 +020095#define CONFIG_SYS_DEVICE_NULLDEV 1
Marcel Ziswilerfc127d12016-11-14 21:40:27 +010096#undef CONFIG_CMDLINE_EDITING /* Saves 2.5 KB */
97#undef CONFIG_AUTO_COMPLETE /* Saves 2.5 KB */
Marek Vasutf9f54862011-11-26 07:15:36 +010098
Marek Vasut2e499842010-05-11 04:31:44 +020099/*
100 * Clock Configuration
101 */
Marek Vasutf9f54862011-11-26 07:15:36 +0100102#define CONFIG_SYS_CPUSPEED 0x290 /* 520MHz */
Marek Vasut2e499842010-05-11 04:31:44 +0200103
104/*
Marek Vasut2e499842010-05-11 04:31:44 +0200105 * DRAM Map
106 */
107#define CONFIG_NR_DRAM_BANKS 1 /* We have 1 bank of DRAM */
108#define PHYS_SDRAM_1 0xa0000000 /* SDRAM Bank #1 */
109#define PHYS_SDRAM_1_SIZE 0x04000000 /* 64 MB */
110
111#define CONFIG_SYS_DRAM_BASE 0xa0000000 /* CS0 */
112#define CONFIG_SYS_DRAM_SIZE 0x04000000 /* 64 MB DRAM */
113
114#define CONFIG_SYS_MEMTEST_START 0xa0400000 /* memtest works on */
115#define CONFIG_SYS_MEMTEST_END 0xa0800000 /* 4 ... 8 MB in DRAM */
116
Marek Vasutf9f54862011-11-26 07:15:36 +0100117#define CONFIG_SYS_LOAD_ADDR PHYS_SDRAM_1
Marek Vasut6ef6eb92010-09-23 09:46:57 +0200118#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
Marek Vasutf9f54862011-11-26 07:15:36 +0100119#define CONFIG_SYS_INIT_SP_ADDR 0x5c010000
Marek Vasut6ef6eb92010-09-23 09:46:57 +0200120
Marek Vasut2e499842010-05-11 04:31:44 +0200121/*
122 * NOR FLASH
123 */
124#ifdef CONFIG_CMD_FLASH
125#define PHYS_FLASH_1 0x00000000 /* Flash Bank #1 */
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200126#define PHYS_FLASH_SIZE 0x02000000 /* 32 MB */
Marek Vasut2e499842010-05-11 04:31:44 +0200127#define CONFIG_SYS_FLASH_BASE PHYS_FLASH_1
128
129#define CONFIG_SYS_FLASH_CFI
130#define CONFIG_FLASH_CFI_DRIVER 1
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200131#define CONFIG_SYS_FLASH_CFI_WIDTH FLASH_CFI_32BIT
Marek Vasut2e499842010-05-11 04:31:44 +0200132
133#define CONFIG_SYS_MAX_FLASH_SECT (4 + 255)
134#define CONFIG_SYS_MAX_FLASH_BANKS 1
135
Marek Vasutf9f54862011-11-26 07:15:36 +0100136#define CONFIG_SYS_FLASH_ERASE_TOUT (25 * CONFIG_SYS_HZ)
137#define CONFIG_SYS_FLASH_WRITE_TOUT (25 * CONFIG_SYS_HZ)
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200138#define CONFIG_SYS_FLASH_LOCK_TOUT (25 * CONFIG_SYS_HZ)
139#define CONFIG_SYS_FLASH_UNLOCK_TOUT (25 * CONFIG_SYS_HZ)
Marek Vasut2e499842010-05-11 04:31:44 +0200140
141#define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 1
142#define CONFIG_SYS_FLASH_PROTECTION 1
143
144#define CONFIG_ENV_IS_IN_FLASH 1
145
146#else /* No flash */
147#define CONFIG_SYS_NO_FLASH
Marcel Ziswiler50dea462015-03-01 00:53:12 +0100148#define CONFIG_ENV_IS_NOWHERE
Marek Vasut2e499842010-05-11 04:31:44 +0200149#endif
150
Marek Vasutf9f54862011-11-26 07:15:36 +0100151#define CONFIG_SYS_MONITOR_BASE 0x0
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100152#define CONFIG_SYS_MONITOR_LEN 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +0200153
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100154/* Skip factory configuration block */
Marek Vasutf9f54862011-11-26 07:15:36 +0100155#define CONFIG_ENV_ADDR \
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100156 (CONFIG_SYS_MONITOR_BASE + CONFIG_SYS_MONITOR_LEN + 0x40000)
Marek Vasutf9f54862011-11-26 07:15:36 +0100157#define CONFIG_ENV_SIZE 0x40000
158#define CONFIG_ENV_SECT_SIZE 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +0200159
160/*
161 * GPIO settings
162 */
163#define CONFIG_SYS_GPSR0_VAL 0x00000000
164#define CONFIG_SYS_GPSR1_VAL 0x00020000
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100165#define CONFIG_SYS_GPSR2_VAL 0x0002c000
Marek Vasut2e499842010-05-11 04:31:44 +0200166#define CONFIG_SYS_GPSR3_VAL 0x00000000
167
168#define CONFIG_SYS_GPCR0_VAL 0x00000000
169#define CONFIG_SYS_GPCR1_VAL 0x00000000
170#define CONFIG_SYS_GPCR2_VAL 0x00000000
171#define CONFIG_SYS_GPCR3_VAL 0x00000000
172
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100173#define CONFIG_SYS_GPDR0_VAL 0xc8008000
174#define CONFIG_SYS_GPDR1_VAL 0xfc02a981
175#define CONFIG_SYS_GPDR2_VAL 0x92c3ffff
176#define CONFIG_SYS_GPDR3_VAL 0x0061e804
Marek Vasut2e499842010-05-11 04:31:44 +0200177
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100178#define CONFIG_SYS_GAFR0_L_VAL 0x80100000
179#define CONFIG_SYS_GAFR0_U_VAL 0xa5c00010
180#define CONFIG_SYS_GAFR1_L_VAL 0x6992901a
181#define CONFIG_SYS_GAFR1_U_VAL 0xaaa50008
182#define CONFIG_SYS_GAFR2_L_VAL 0xaaaaaaaa
183#define CONFIG_SYS_GAFR2_U_VAL 0x4109a002
184#define CONFIG_SYS_GAFR3_L_VAL 0x54000310
185#define CONFIG_SYS_GAFR3_U_VAL 0x00005401
Marek Vasut2e499842010-05-11 04:31:44 +0200186
187#define CONFIG_SYS_PSSR_VAL 0x30
188
189/*
190 * Clock settings
191 */
192#define CONFIG_SYS_CKEN 0x00500240
193#define CONFIG_SYS_CCCR 0x02000290
194
195/*
196 * Memory settings
197 */
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100198#define CONFIG_SYS_MSC0_VAL 0x9ee1c5f2
199#define CONFIG_SYS_MSC1_VAL 0x9ee1f994
200#define CONFIG_SYS_MSC2_VAL 0x9ee19ee1
201#define CONFIG_SYS_MDCNFG_VAL 0x090009c9
202#define CONFIG_SYS_MDREFR_VAL 0x2003a031
203#define CONFIG_SYS_MDMRS_VAL 0x00220022
204#define CONFIG_SYS_FLYCNFG_VAL 0x00010001
Marek Vasut2e499842010-05-11 04:31:44 +0200205#define CONFIG_SYS_SXCNFG_VAL 0x40044004
206
207/*
208 * PCMCIA and CF Interfaces
209 */
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100210#define CONFIG_SYS_MECR_VAL 0x00000000
211#define CONFIG_SYS_MCMEM0_VAL 0x00028307
Marek Vasut2e499842010-05-11 04:31:44 +0200212#define CONFIG_SYS_MCMEM1_VAL 0x00014307
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100213#define CONFIG_SYS_MCATT0_VAL 0x00038787
Marek Vasut2e499842010-05-11 04:31:44 +0200214#define CONFIG_SYS_MCATT1_VAL 0x0001c787
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100215#define CONFIG_SYS_MCIO0_VAL 0x0002830f
Marek Vasut2e499842010-05-11 04:31:44 +0200216#define CONFIG_SYS_MCIO1_VAL 0x0001430f
217
Marek Vasut67a1f002011-11-26 11:27:50 +0100218#include "pxa-common.h"
Marek Vasut2e499842010-05-11 04:31:44 +0200219
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100220#endif /* __CONFIG_H */