blob: 51f7877908019fdc77c4cc9db103553dfc281fcf [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#define CONFIG_BAUDRATE 115200
Marek Vasut2e499842010-05-11 04:31:44 +020051
52/*
53 * Bootloader Components Configuration
54 */
Marek Vasut2e499842010-05-11 04:31:44 +020055#define CONFIG_CMD_ENV
Marek Vasut2e499842010-05-11 04:31:44 +020056
Marcel Ziswiler3664fa12015-08-16 04:16:36 +020057/* I2C support */
58#ifdef CONFIG_SYS_I2C
Marcel Ziswiler3664fa12015-08-16 04:16:36 +020059#define CONFIG_SYS_I2C_PXA
60#define CONFIG_PXA_STD_I2C
61#define CONFIG_PXA_PWR_I2C
62#define CONFIG_SYS_I2C_SPEED 100000
63#endif
64
Marcel Ziswiler4f9bbd92015-08-16 04:16:35 +020065/* LCD support */
66#ifdef CONFIG_LCD
67#define CONFIG_PXA_LCD
68#define CONFIG_PXA_VGA
69#define CONFIG_SYS_WHITE_ON_BLACK
Marcel Ziswiler4f9bbd92015-08-16 04:16:35 +020070#define CONFIG_CMD_BMP
71#define CONFIG_LCD_LOGO
72#endif
73
Marek Vasut2e499842010-05-11 04:31:44 +020074/*
75 * Networking Configuration
Marek Vasut2e499842010-05-11 04:31:44 +020076 */
77#ifdef CONFIG_CMD_NET
Marek Vasut2e499842010-05-11 04:31:44 +020078
Marek Vasut2e499842010-05-11 04:31:44 +020079#define CONFIG_DRIVER_DM9000 1
80#define CONFIG_DM9000_BASE 0x08000000
81#define DM9000_IO (CONFIG_DM9000_BASE)
82#define DM9000_DATA (CONFIG_DM9000_BASE + 4)
83#define CONFIG_NET_RETRY_COUNT 10
84
85#define CONFIG_BOOTP_BOOTFILESIZE
86#define CONFIG_BOOTP_BOOTPATH
87#define CONFIG_BOOTP_GATEWAY
88#define CONFIG_BOOTP_HOSTNAME
89#endif
90
Marcel Ziswilerfe488a82015-03-01 00:53:14 +010091#undef CONFIG_SYS_LONGHELP /* Saves 10 KB */
Marek Vasutf9f54862011-11-26 07:15:36 +010092#define CONFIG_SYS_CBSIZE 256
93#define CONFIG_SYS_PBSIZE \
94 (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16)
95#define CONFIG_SYS_MAXARGS 16
96#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
Marek Vasut2e499842010-05-11 04:31:44 +020097#define CONFIG_SYS_DEVICE_NULLDEV 1
Marcel Ziswilerfc127d12016-11-14 21:40:27 +010098#undef CONFIG_CMDLINE_EDITING /* Saves 2.5 KB */
99#undef CONFIG_AUTO_COMPLETE /* Saves 2.5 KB */
Marek Vasutf9f54862011-11-26 07:15:36 +0100100
Marek Vasut2e499842010-05-11 04:31:44 +0200101/*
102 * Clock Configuration
103 */
Marek Vasutf9f54862011-11-26 07:15:36 +0100104#define CONFIG_SYS_CPUSPEED 0x290 /* 520MHz */
Marek Vasut2e499842010-05-11 04:31:44 +0200105
106/*
Marek Vasut2e499842010-05-11 04:31:44 +0200107 * DRAM Map
108 */
109#define CONFIG_NR_DRAM_BANKS 1 /* We have 1 bank of DRAM */
110#define PHYS_SDRAM_1 0xa0000000 /* SDRAM Bank #1 */
111#define PHYS_SDRAM_1_SIZE 0x04000000 /* 64 MB */
112
113#define CONFIG_SYS_DRAM_BASE 0xa0000000 /* CS0 */
114#define CONFIG_SYS_DRAM_SIZE 0x04000000 /* 64 MB DRAM */
115
116#define CONFIG_SYS_MEMTEST_START 0xa0400000 /* memtest works on */
117#define CONFIG_SYS_MEMTEST_END 0xa0800000 /* 4 ... 8 MB in DRAM */
118
Marek Vasutf9f54862011-11-26 07:15:36 +0100119#define CONFIG_SYS_LOAD_ADDR PHYS_SDRAM_1
Marek Vasut6ef6eb92010-09-23 09:46:57 +0200120#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
Marek Vasutf9f54862011-11-26 07:15:36 +0100121#define CONFIG_SYS_INIT_SP_ADDR 0x5c010000
Marek Vasut6ef6eb92010-09-23 09:46:57 +0200122
Marek Vasut2e499842010-05-11 04:31:44 +0200123/*
124 * NOR FLASH
125 */
126#ifdef CONFIG_CMD_FLASH
127#define PHYS_FLASH_1 0x00000000 /* Flash Bank #1 */
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200128#define PHYS_FLASH_SIZE 0x02000000 /* 32 MB */
Marek Vasut2e499842010-05-11 04:31:44 +0200129#define CONFIG_SYS_FLASH_BASE PHYS_FLASH_1
130
131#define CONFIG_SYS_FLASH_CFI
132#define CONFIG_FLASH_CFI_DRIVER 1
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200133#define CONFIG_SYS_FLASH_CFI_WIDTH FLASH_CFI_32BIT
Marek Vasut2e499842010-05-11 04:31:44 +0200134
135#define CONFIG_SYS_MAX_FLASH_SECT (4 + 255)
136#define CONFIG_SYS_MAX_FLASH_BANKS 1
137
Marek Vasutf9f54862011-11-26 07:15:36 +0100138#define CONFIG_SYS_FLASH_ERASE_TOUT (25 * CONFIG_SYS_HZ)
139#define CONFIG_SYS_FLASH_WRITE_TOUT (25 * CONFIG_SYS_HZ)
Marcel Ziswilerd8178892015-08-16 04:16:34 +0200140#define CONFIG_SYS_FLASH_LOCK_TOUT (25 * CONFIG_SYS_HZ)
141#define CONFIG_SYS_FLASH_UNLOCK_TOUT (25 * CONFIG_SYS_HZ)
Marek Vasut2e499842010-05-11 04:31:44 +0200142
143#define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 1
144#define CONFIG_SYS_FLASH_PROTECTION 1
145
146#define CONFIG_ENV_IS_IN_FLASH 1
147
148#else /* No flash */
149#define CONFIG_SYS_NO_FLASH
Marcel Ziswiler50dea462015-03-01 00:53:12 +0100150#define CONFIG_ENV_IS_NOWHERE
Marek Vasut2e499842010-05-11 04:31:44 +0200151#endif
152
Marek Vasutf9f54862011-11-26 07:15:36 +0100153#define CONFIG_SYS_MONITOR_BASE 0x0
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100154#define CONFIG_SYS_MONITOR_LEN 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +0200155
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100156/* Skip factory configuration block */
Marek Vasutf9f54862011-11-26 07:15:36 +0100157#define CONFIG_ENV_ADDR \
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100158 (CONFIG_SYS_MONITOR_BASE + CONFIG_SYS_MONITOR_LEN + 0x40000)
Marek Vasutf9f54862011-11-26 07:15:36 +0100159#define CONFIG_ENV_SIZE 0x40000
160#define CONFIG_ENV_SECT_SIZE 0x40000
Marek Vasut2e499842010-05-11 04:31:44 +0200161
162/*
163 * GPIO settings
164 */
165#define CONFIG_SYS_GPSR0_VAL 0x00000000
166#define CONFIG_SYS_GPSR1_VAL 0x00020000
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100167#define CONFIG_SYS_GPSR2_VAL 0x0002c000
Marek Vasut2e499842010-05-11 04:31:44 +0200168#define CONFIG_SYS_GPSR3_VAL 0x00000000
169
170#define CONFIG_SYS_GPCR0_VAL 0x00000000
171#define CONFIG_SYS_GPCR1_VAL 0x00000000
172#define CONFIG_SYS_GPCR2_VAL 0x00000000
173#define CONFIG_SYS_GPCR3_VAL 0x00000000
174
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100175#define CONFIG_SYS_GPDR0_VAL 0xc8008000
176#define CONFIG_SYS_GPDR1_VAL 0xfc02a981
177#define CONFIG_SYS_GPDR2_VAL 0x92c3ffff
178#define CONFIG_SYS_GPDR3_VAL 0x0061e804
Marek Vasut2e499842010-05-11 04:31:44 +0200179
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100180#define CONFIG_SYS_GAFR0_L_VAL 0x80100000
181#define CONFIG_SYS_GAFR0_U_VAL 0xa5c00010
182#define CONFIG_SYS_GAFR1_L_VAL 0x6992901a
183#define CONFIG_SYS_GAFR1_U_VAL 0xaaa50008
184#define CONFIG_SYS_GAFR2_L_VAL 0xaaaaaaaa
185#define CONFIG_SYS_GAFR2_U_VAL 0x4109a002
186#define CONFIG_SYS_GAFR3_L_VAL 0x54000310
187#define CONFIG_SYS_GAFR3_U_VAL 0x00005401
Marek Vasut2e499842010-05-11 04:31:44 +0200188
189#define CONFIG_SYS_PSSR_VAL 0x30
190
191/*
192 * Clock settings
193 */
194#define CONFIG_SYS_CKEN 0x00500240
195#define CONFIG_SYS_CCCR 0x02000290
196
197/*
198 * Memory settings
199 */
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100200#define CONFIG_SYS_MSC0_VAL 0x9ee1c5f2
201#define CONFIG_SYS_MSC1_VAL 0x9ee1f994
202#define CONFIG_SYS_MSC2_VAL 0x9ee19ee1
203#define CONFIG_SYS_MDCNFG_VAL 0x090009c9
204#define CONFIG_SYS_MDREFR_VAL 0x2003a031
205#define CONFIG_SYS_MDMRS_VAL 0x00220022
206#define CONFIG_SYS_FLYCNFG_VAL 0x00010001
Marek Vasut2e499842010-05-11 04:31:44 +0200207#define CONFIG_SYS_SXCNFG_VAL 0x40044004
208
209/*
210 * PCMCIA and CF Interfaces
211 */
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100212#define CONFIG_SYS_MECR_VAL 0x00000000
213#define CONFIG_SYS_MCMEM0_VAL 0x00028307
Marek Vasut2e499842010-05-11 04:31:44 +0200214#define CONFIG_SYS_MCMEM1_VAL 0x00014307
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100215#define CONFIG_SYS_MCATT0_VAL 0x00038787
Marek Vasut2e499842010-05-11 04:31:44 +0200216#define CONFIG_SYS_MCATT1_VAL 0x0001c787
Marcel Ziswiler44ba7a32015-03-01 00:53:19 +0100217#define CONFIG_SYS_MCIO0_VAL 0x0002830f
Marek Vasut2e499842010-05-11 04:31:44 +0200218#define CONFIG_SYS_MCIO1_VAL 0x0001430f
219
Marek Vasut67a1f002011-11-26 11:27:50 +0100220#include "pxa-common.h"
Marek Vasut2e499842010-05-11 04:31:44 +0200221
Marcel Ziswiler7c49b522015-03-01 00:53:15 +0100222#endif /* __CONFIG_H */