]> git.ipfire.org Git - people/ms/u-boot.git/blob - include/configs/palmtreo680.h
Merge branch 'master' of git://git.denx.de/u-boot-nand-flash
[people/ms/u-boot.git] / include / configs / palmtreo680.h
1 /*
2 * Palm Treo 680 configuration file
3 *
4 * Copyright (C) 2013 Mike Dunn <mikedunn@newsguy.com>
5 *
6 * This file is released under the terms of GPL v2 and any later version.
7 * See the file COPYING in the root directory of the source tree for details.
8 *
9 */
10
11 #ifndef __CONFIG_H
12 #define __CONFIG_H
13
14 /*
15 * High Level Board Configuration Options
16 */
17 #define CONFIG_CPU_PXA27X
18 #define CONFIG_PALMTREO680
19 #define CONFIG_MACH_TYPE MACH_TYPE_TREO680
20
21 #define CONFIG_SYS_MALLOC_LEN (4096*1024)
22
23 #define CONFIG_LZMA
24
25 /*
26 * Serial Console Configuration
27 */
28 #define CONFIG_PXA_SERIAL
29 #define CONFIG_FFUART 1
30 #define CONFIG_BAUDRATE 9600
31 #define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200 }
32 #define CONFIG_CONS_INDEX 3
33
34 /* we have nand (although technically nand *is* flash...) */
35 #define CONFIG_SYS_NO_FLASH
36
37 #define CONFIG_LCD
38 /* #define CONFIG_KEYBOARD */ /* TODO */
39
40 /*
41 * Bootloader Components Configuration
42 */
43 #include <config_cmd_default.h>
44 #undef CONFIG_CMD_FPGA
45 #undef CONFIG_CMD_LOADS
46 #undef CONFIG_CMD_NET
47 #undef CONFIG_CMD_NFS
48 #undef CONFIG_CMD_IMLS
49 #undef CONFIG_CMD_FLASH
50 #undef CONFIG_CMD_SETGETDCR
51 #undef CONFIG_CMD_SOURCE
52 #undef CONFIG_CMD_XIMG
53
54 #define CONFIG_CMD_ENV
55 #define CONFIG_CMD_MMC
56 #define CONFIG_CMD_NAND
57
58 #define CONFIG_CMDLINE_TAG
59 #define CONFIG_SETUP_MEMORY_TAGS
60
61 /*
62 * MMC Card Configuration
63 */
64 #ifdef CONFIG_CMD_MMC
65 #define CONFIG_MMC
66 #define CONFIG_GENERIC_MMC
67 #define CONFIG_PXA_MMC_GENERIC
68
69 #define CONFIG_CMD_FAT
70 #define CONFIG_CMD_EXT2
71 #define CONFIG_DOS_PARTITION
72 #endif
73
74 /*
75 * LCD
76 */
77 #ifdef CONFIG_LCD
78 #define CONFIG_PXA_LCD
79 #define CONFIG_ACX544AKN
80 #define CONFIG_LCD_LOGO
81 #define CONFIG_SYS_LCD_PXA_NO_L_BIAS /* don't configure GPIO77 as L_BIAS */
82 #define LCD_BPP LCD_COLOR16
83 #define CONFIG_FB_ADDR 0x5c000000 /* internal SRAM */
84 #define CONFIG_CMD_BMP
85 #define CONFIG_SPLASH_SCREEN /* requires "splashimage" env var */
86 #define CONFIG_SPLASH_SCREEN_ALIGN /* requires "splashpos" env var */
87 #define CONFIG_VIDEO_BMP_GZIP
88 #define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE (2 << 20)
89
90 #endif
91
92 /*
93 * KGDB
94 */
95 #ifdef CONFIG_CMD_KGDB
96 #define CONFIG_KGDB_BAUDRATE 230400 /* kgdb serial port speed */
97 #define CONFIG_KGDB_SER_INDEX 2 /* which serial port to use */
98 #endif
99
100 /*
101 * HUSH Shell Configuration
102 */
103 #define CONFIG_SYS_HUSH_PARSER 1
104 #define CONFIG_SYS_PROMPT_HUSH_PS2 "> "
105
106 #define CONFIG_SYS_LONGHELP
107 #ifdef CONFIG_SYS_HUSH_PARSER
108 #define CONFIG_SYS_PROMPT "$ "
109 #else
110 #define CONFIG_SYS_PROMPT "=> "
111 #endif
112 #define CONFIG_SYS_CBSIZE 256
113 #define CONFIG_SYS_PBSIZE \
114 (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16)
115 #define CONFIG_SYS_MAXARGS 16
116 #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
117 #define CONFIG_SYS_DEVICE_NULLDEV 1
118
119 /*
120 * Clock Configuration
121 */
122 #undef CONFIG_SYS_CLKS_IN_HZ
123 #define CONFIG_SYS_HZ 1000 /* decrementer freq: 1 ms ticks */
124 #define CONFIG_SYS_CPUSPEED 0x210 /* 416MHz ; N=2,L=16 */
125
126 /*
127 * Stack sizes
128 */
129 #define CONFIG_STACKSIZE (128*1024) /* regular stack */
130 #ifdef CONFIG_USE_IRQ
131 #define CONFIG_STACKSIZE_IRQ (4*1024) /* IRQ stack */
132 #define CONFIG_STACKSIZE_FIQ (4*1024) /* FIQ stack */
133 #endif
134
135 /*
136 * DRAM Map
137 */
138 #define CONFIG_NR_DRAM_BANKS 1 /* 1 bank of DRAM */
139 #define PHYS_SDRAM_1 0xa0000000 /* SDRAM Bank #1 */
140 #define PHYS_SDRAM_1_SIZE 0x04000000 /* 64 MB */
141
142 #define CONFIG_SYS_DRAM_BASE 0xa0000000
143 #define CONFIG_SYS_DRAM_SIZE 0x04000000 /* 64 MB DRAM */
144
145 #define CONFIG_SYS_MEMTEST_START 0xa0400000 /* memtest works on */
146 #define CONFIG_SYS_MEMTEST_END 0xa0800000 /* 4 ... 8 MB in DRAM */
147 #define CONFIG_SYS_LOAD_ADDR CONFIG_SYS_DRAM_BASE
148 #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
149
150 /*
151 * GPIO settings
152 */
153 #define CONFIG_SYS_GAFR0_L_VAL 0x0E000000
154 #define CONFIG_SYS_GAFR0_U_VAL 0xA500001A
155 #define CONFIG_SYS_GAFR1_L_VAL 0x60000002
156 #define CONFIG_SYS_GAFR1_U_VAL 0xAAA07959
157 #define CONFIG_SYS_GAFR2_L_VAL 0x02AAAAAA
158 #define CONFIG_SYS_GAFR2_U_VAL 0x41440F08
159 #define CONFIG_SYS_GAFR3_L_VAL 0x56AA95FF
160 #define CONFIG_SYS_GAFR3_U_VAL 0x00001401
161 #define CONFIG_SYS_GPCR0_VAL 0x1FF80400
162 #define CONFIG_SYS_GPCR1_VAL 0x03003FC1
163 #define CONFIG_SYS_GPCR2_VAL 0x01C1E000
164 #define CONFIG_SYS_GPCR3_VAL 0x01C1E000
165 #define CONFIG_SYS_GPDR0_VAL 0xCFF90400
166 #define CONFIG_SYS_GPDR1_VAL 0xFB22BFC1
167 #define CONFIG_SYS_GPDR2_VAL 0x93CDFFDF
168 #define CONFIG_SYS_GPDR3_VAL 0x0069FF81
169 #define CONFIG_SYS_GPSR0_VAL 0x02000018
170 #define CONFIG_SYS_GPSR1_VAL 0x00000000
171 #define CONFIG_SYS_GPSR2_VAL 0x000C0000
172 #define CONFIG_SYS_GPSR3_VAL 0x00080000
173
174 #define CONFIG_SYS_PSSR_VAL 0x30
175
176 /*
177 * Clock settings
178 */
179 #define CONFIG_SYS_CKEN 0x01ffffff
180 #define CONFIG_SYS_CCCR 0x02000210
181
182 /*
183 * Memory settings
184 */
185 #define CONFIG_SYS_MSC0_VAL 0x7ff844c8
186 #define CONFIG_SYS_MSC1_VAL 0x7ff86ab4
187 #define CONFIG_SYS_MSC2_VAL 0x7ff87ff8
188 #define CONFIG_SYS_MDCNFG_VAL 0x0B880acd
189 #define CONFIG_SYS_MDREFR_VAL 0x201fa031
190 #define CONFIG_SYS_MDMRS_VAL 0x00320032
191 #define CONFIG_SYS_FLYCNFG_VAL 0x00000000
192 #define CONFIG_SYS_SXCNFG_VAL 0x40044004
193 #define CONFIG_SYS_MECR_VAL 0x00000003
194 #define CONFIG_SYS_MCMEM0_VAL 0x0001c391
195 #define CONFIG_SYS_MCMEM1_VAL 0x0001c391
196 #define CONFIG_SYS_MCATT0_VAL 0x0001c391
197 #define CONFIG_SYS_MCATT1_VAL 0x0001c391
198 #define CONFIG_SYS_MCIO0_VAL 0x00014611
199 #define CONFIG_SYS_MCIO1_VAL 0x0001c391
200
201 /*
202 * USB
203 */
204 #define CONFIG_USB_DEVICE
205 #define CONFIG_USB_TTY
206 #define CONFIG_USB_DEV_PULLUP_GPIO 114
207
208 /*
209 * SPL
210 */
211 #define CONFIG_SPL
212 #define CONFIG_SPL_TEXT_BASE 0xa1700000 /* IPL loads SPL here */
213 #define CONFIG_SPL_STACK 0x5c040000 /* end of internal SRAM */
214 #define CONFIG_SPL_NAND_SUPPORT /* build libnand for spl */
215 #define CONFIG_SPL_NAND_DOCG4 /* use lean docg4 nand spl driver */
216 #define CONFIG_SPL_LIBGENERIC_SUPPORT /* spl uses memcpy */
217
218 /*
219 * NAND
220 */
221 #define CONFIG_NAND_DOCG4
222 #define CONFIG_SYS_NAND_SELF_INIT
223 #define CONFIG_SYS_MAX_NAND_DEVICE 1 /* only one device */
224 #define CONFIG_SYS_NAND_BASE 0x00000000 /* mapped to reset vector */
225 #define CONFIG_SYS_NAND_PAGE_SIZE 0x200
226 #define CONFIG_SYS_NAND_BLOCK_SIZE 0x40000
227 #define CONFIG_BITREVERSE /* needed by docg4 driver */
228 #define CONFIG_BCH /* needed by docg4 driver */
229
230 /*
231 * IMPORTANT NOTE: this is the size of the concatenated spl + u-boot image. It
232 * will be rounded up to the next 64k boundary (the spl flash block size), so it
233 * does not have to be exact, but you must ensure that it is not less than the
234 * actual image size, or it may fail to boot (bricked phone)!
235 * (Tip: reduces to three blocks with lcd and mmc support removed from u-boot.)
236 */
237 #define CONFIG_SYS_NAND_U_BOOT_SIZE 0x40000 /* four 64k flash blocks */
238
239 /*
240 * This is the byte offset into the flash at which the concatenated spl + u-boot
241 * image is placed. It must be at the start of a block (256k boundary). Blocks
242 * 0 - 5 are write-protected, so we start at block 6.
243 */
244 #define CONFIG_SYS_NAND_U_BOOT_OFFS 0x180000 /* block 6 */
245
246 /* DRAM address to which u-boot proper is loaded (before it relocates itself) */
247 #define CONFIG_SYS_NAND_U_BOOT_DST 0xa0000000
248 #define CONFIG_SYS_NAND_U_BOOT_START CONFIG_SYS_NAND_U_BOOT_DST
249
250 /* passed to linker by Makefile as arg to -Ttext option */
251 #define CONFIG_SYS_TEXT_BASE 0xa0000000
252
253 #define CONFIG_SYS_INIT_SP_ADDR 0x5c040000 /* end of internal SRAM */
254
255 /*
256 * environment
257 */
258 #define CONFIG_ENV_IS_NOWHERE
259 #define CONFIG_BUILD_ENVCRC
260 #define CONFIG_ENV_SIZE 0x200
261 #define CONFIG_SYS_CONSOLE_IS_IN_ENV
262 #define CONFIG_EXTRA_ENV_SETTINGS \
263 "stdin=usbtty\0" \
264 "stdout=usbtty\0" \
265 "stderr=usbtty"
266 #define CONFIG_BOOTARGS "mtdparts=Msys_Diskonchip_G4:1536k(protected_part)ro,1024k(bootloader_part),-(filesys_part) \
267 ip=192.168.11.102:::255.255.255.0:treo:usb0"
268 #define CONFIG_BOOTDELAY 3
269
270 #if 0 /* example: try 2nd mmc partition, then nand */
271 #define CONFIG_BOOTCOMMAND \
272 "mmc rescan; " \
273 "if mmcinfo && ext2load mmc 0:2 0xa1000000 uImage; then " \
274 "bootm 0xa1000000; " \
275 "elif nand read 0xa1000000 0x280000 0x240000; then " \
276 "bootm 0xa1000000; " \
277 "fi; "
278 #endif
279
280 /* u-boot lives at end of SDRAM, so use start of SDRAM for stand alone apps */
281 #define CONFIG_STANDALONE_LOAD_ADDR 0xa0000000
282
283 #define CONFIG_SYS_DCACHE_OFF
284 #define CONFIG_SYS_ICACHE_OFF
285
286 #endif /* __CONFIG_H */