1
2
3
4
5
6
7
8
9
10
11
12
13#ifndef _SUNXI_COMMON_CONFIG_H
14#define _SUNXI_COMMON_CONFIG_H
15
16#include <asm/arch/cpu.h>
17#include <linux/stringify.h>
18
19#ifdef CONFIG_OLD_SUNXI_KERNEL_COMPAT
20
21
22
23
24
25# define CONFIG_MACH_TYPE_COMPAT_REV 0
26#else
27
28
29
30
31
32# define CONFIG_MACH_TYPE_COMPAT_REV 1
33#endif
34
35#ifdef CONFIG_ARM64
36#define CONFIG_BUILD_TARGET "u-boot.itb"
37#define CONFIG_SYS_BOOTM_LEN (32 << 20)
38#endif
39
40
41#define CONFIG_SYS_NS16550_SERIAL
42
43#define CONFIG_SYS_NS16550_CLK 24000000
44#ifndef CONFIG_DM_SERIAL
45# define CONFIG_SYS_NS16550_REG_SIZE -4
46# define CONFIG_SYS_NS16550_COM1 SUNXI_UART0_BASE
47# define CONFIG_SYS_NS16550_COM2 SUNXI_UART1_BASE
48# define CONFIG_SYS_NS16550_COM3 SUNXI_UART2_BASE
49# define CONFIG_SYS_NS16550_COM4 SUNXI_UART3_BASE
50# define CONFIG_SYS_NS16550_COM5 SUNXI_R_UART_BASE
51#endif
52
53
54#define COUNTER_FREQUENCY 24000000
55
56
57
58
59
60
61
62
63#ifdef CONFIG_MACH_SUN9I
64#define SDRAM_OFFSET(x) 0x2##x
65#define CONFIG_SYS_SDRAM_BASE 0x20000000
66#define CONFIG_SYS_LOAD_ADDR 0x22000000
67#define CONFIG_SYS_TEXT_BASE 0x2a000000
68
69
70
71#define CONFIG_SPL_STACK_R_ADDR 0x2fe00000
72#define CONFIG_SPL_BSS_START_ADDR 0x2ff80000
73#else
74#define SDRAM_OFFSET(x) 0x4##x
75#define CONFIG_SYS_SDRAM_BASE 0x40000000
76#define CONFIG_SYS_LOAD_ADDR 0x42000000
77
78#ifndef CONFIG_MACH_SUN8I_V3S
79#define CONFIG_SYS_TEXT_BASE 0x4a000000
80#else
81#define CONFIG_SYS_TEXT_BASE 0x42e00000
82#endif
83
84
85
86#define CONFIG_SPL_STACK_R_ADDR 0x4fe00000
87#define CONFIG_SPL_BSS_START_ADDR 0x4ff80000
88#endif
89
90#define CONFIG_SPL_BSS_MAX_SIZE 0x00080000
91
92#ifdef CONFIG_SUNXI_HIGH_SRAM
93
94
95
96
97
98
99
100#define CONFIG_SYS_INIT_RAM_ADDR 0x10000
101#define CONFIG_SYS_INIT_RAM_SIZE 0x08000
102#else
103#define CONFIG_SYS_INIT_RAM_ADDR 0x0
104#define CONFIG_SYS_INIT_RAM_SIZE 0x8000
105#endif
106
107#define CONFIG_SYS_INIT_SP_OFFSET \
108 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
109#define CONFIG_SYS_INIT_SP_ADDR \
110 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
111
112#define CONFIG_NR_DRAM_BANKS 1
113#define PHYS_SDRAM_0 CONFIG_SYS_SDRAM_BASE
114#define PHYS_SDRAM_0_SIZE 0x80000000
115
116#ifdef CONFIG_AHCI
117#define CONFIG_SCSI_AHCI_PLAT
118#define CONFIG_SUNXI_AHCI
119#define CONFIG_SYS_64BIT_LBA
120#define CONFIG_SYS_SCSI_MAX_SCSI_ID 1
121#define CONFIG_SYS_SCSI_MAX_LUN 1
122#define CONFIG_SYS_SCSI_MAX_DEVICE (CONFIG_SYS_SCSI_MAX_SCSI_ID * \
123 CONFIG_SYS_SCSI_MAX_LUN)
124#endif
125
126#define CONFIG_SETUP_MEMORY_TAGS
127#define CONFIG_CMDLINE_TAG
128#define CONFIG_INITRD_TAG
129#define CONFIG_SERIAL_TAG
130
131#ifdef CONFIG_NAND_SUNXI
132#define CONFIG_SYS_NAND_MAX_ECCPOS 1664
133#define CONFIG_SYS_NAND_ONFI_DETECTION
134#define CONFIG_SYS_MAX_NAND_DEVICE 8
135
136#define CONFIG_MTD_DEVICE
137#define CONFIG_MTD_PARTITIONS
138#endif
139
140#ifdef CONFIG_SPL_SPI_SUNXI
141#define CONFIG_SYS_SPI_U_BOOT_OFFS 0x8000
142#endif
143
144
145#ifdef CONFIG_MMC
146#define CONFIG_MMC_SUNXI_SLOT 0
147#endif
148
149#if defined(CONFIG_ENV_IS_IN_MMC)
150#if CONFIG_MMC_SUNXI_SLOT_EXTRA != -1
151
152#define CONFIG_SYS_MMC_ENV_DEV 1
153#else
154
155#define CONFIG_SYS_MMC_ENV_DEV 0
156#endif
157#define CONFIG_SYS_MMC_MAX_DEVICE 4
158#elif defined(CONFIG_ENV_IS_NOWHERE)
159#define CONFIG_ENV_SIZE (128 << 10)
160#endif
161
162#ifndef CONFIG_MACH_SUN8I_V3S
163
164#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + (64 << 20))
165#else
166
167#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + (2 << 20))
168#endif
169
170
171
172
173#define CONFIG_SYS_CBSIZE 1024
174#define CONFIG_SYS_PBSIZE 1024
175
176
177#define CONFIG_STANDALONE_LOAD_ADDR CONFIG_SYS_LOAD_ADDR
178
179
180
181#define CONFIG_SYS_MONITOR_LEN (768 << 10)
182
183#define CONFIG_SPL_FRAMEWORK
184
185#ifndef CONFIG_ARM64
186#define CONFIG_SPL_BOARD_LOAD_IMAGE
187#endif
188
189#ifdef CONFIG_SUNXI_HIGH_SRAM
190#define CONFIG_SPL_TEXT_BASE 0x10060
191#define CONFIG_SPL_MAX_SIZE 0x7fa0
192#ifdef CONFIG_ARM64
193
194#define LOW_LEVEL_SRAM_STACK 0x00054000
195#else
196#define LOW_LEVEL_SRAM_STACK 0x00018000
197#endif
198#else
199#define CONFIG_SPL_TEXT_BASE 0x60
200#define CONFIG_SPL_MAX_SIZE 0x5fa0
201#define LOW_LEVEL_SRAM_STACK 0x00008000
202#endif
203
204#define CONFIG_SPL_STACK LOW_LEVEL_SRAM_STACK
205
206#define CONFIG_SPL_PAD_TO 32768
207
208
209
210#if defined CONFIG_AXP152_POWER || defined CONFIG_AXP209_POWER || \
211 defined CONFIG_SY8106A_POWER
212#endif
213
214#if defined CONFIG_I2C0_ENABLE || defined CONFIG_I2C1_ENABLE || \
215 defined CONFIG_I2C2_ENABLE || defined CONFIG_I2C3_ENABLE || \
216 defined CONFIG_I2C4_ENABLE || defined CONFIG_R_I2C_ENABLE
217#define CONFIG_SYS_I2C_MVTWSI
218#ifndef CONFIG_DM_I2C
219#define CONFIG_SYS_I2C
220#define CONFIG_SYS_I2C_SPEED 400000
221#define CONFIG_SYS_I2C_SLAVE 0x7f
222#endif
223#endif
224
225#if defined CONFIG_VIDEO_LCD_PANEL_I2C && !(defined CONFIG_SPL_BUILD)
226#define CONFIG_SYS_I2C_SOFT
227#define CONFIG_SYS_I2C_SOFT_SPEED 50000
228#define CONFIG_SYS_I2C_SOFT_SLAVE 0x00
229
230#define CONFIG_SOFT_I2C_GPIO_SDA soft_i2c_gpio_sda
231#define CONFIG_SOFT_I2C_GPIO_SCL soft_i2c_gpio_scl
232#ifndef __ASSEMBLY__
233extern int soft_i2c_gpio_sda;
234extern int soft_i2c_gpio_scl;
235#endif
236#define CONFIG_VIDEO_LCD_I2C_BUS 0
237#define CONFIG_SYS_SPD_BUS_NUM 1
238#else
239#define CONFIG_SYS_SPD_BUS_NUM 0
240#define CONFIG_VIDEO_LCD_I2C_BUS -1
241#endif
242
243
244#if defined CONFIG_AXP152_POWER || defined CONFIG_AXP209_POWER || \
245 defined CONFIG_AXP221_POWER || defined CONFIG_AXP818_POWER || \
246 defined CONFIG_SY8106A_POWER
247#endif
248
249#ifdef CONFIG_REQUIRE_SERIAL_CONSOLE
250#if CONFIG_CONS_INDEX == 1
251#ifdef CONFIG_MACH_SUN9I
252#define OF_STDOUT_PATH "/soc/serial@07000000:115200"
253#else
254#define OF_STDOUT_PATH "/soc@01c00000/serial@01c28000:115200"
255#endif
256#elif CONFIG_CONS_INDEX == 2 && defined(CONFIG_MACH_SUN5I)
257#define OF_STDOUT_PATH "/soc@01c00000/serial@01c28400:115200"
258#elif CONFIG_CONS_INDEX == 3 && defined(CONFIG_MACH_SUN8I)
259#define OF_STDOUT_PATH "/soc@01c00000/serial@01c28800:115200"
260#elif CONFIG_CONS_INDEX == 5 && defined(CONFIG_MACH_SUN8I)
261#define OF_STDOUT_PATH "/soc@01c00000/serial@01f02800:115200"
262#else
263#error Unsupported console port nr. Please fix stdout-path in sunxi-common.h.
264#endif
265#endif
266
267
268#define CONFIG_SUNXI_GPIO
269
270#ifdef CONFIG_VIDEO_SUNXI
271
272
273
274
275#define CONFIG_SUNXI_MAX_FB_SIZE (16 << 20)
276
277#define CONFIG_VIDEO_LOGO
278#define CONFIG_VIDEO_STD_TIMINGS
279#define CONFIG_I2C_EDID
280#define VIDEO_LINE_LEN (pGD->plnSizeX)
281
282
283
284
285#endif
286
287
288#ifdef CONFIG_SUN4I_EMAC
289#define CONFIG_PHY_ADDR 1
290#define CONFIG_MII
291#endif
292
293#ifdef CONFIG_SUN7I_GMAC
294#define CONFIG_PHY_ADDR 1
295#define CONFIG_MII
296#define CONFIG_PHY_REALTEK
297#endif
298
299#ifdef CONFIG_USB_EHCI_HCD
300#define CONFIG_USB_OHCI_NEW
301#define CONFIG_USB_OHCI_SUNXI
302#define CONFIG_SYS_USB_OHCI_MAX_ROOT_PORTS 1
303#endif
304
305#ifdef CONFIG_USB_MUSB_SUNXI
306#define CONFIG_USB_MUSB_PIO_ONLY
307#endif
308
309#ifdef CONFIG_USB_MUSB_GADGET
310#define CONFIG_USB_FUNCTION_MASS_STORAGE
311#endif
312
313#ifdef CONFIG_USB_FUNCTION_MASS_STORAGE
314#endif
315
316#ifdef CONFIG_USB_KEYBOARD
317#define CONFIG_PREBOOT
318#endif
319
320#define CONFIG_MISC_INIT_R
321
322#ifndef CONFIG_SPL_BUILD
323#include <config_distro_defaults.h>
324
325#ifdef CONFIG_ARM64
326
327
328
329
330
331
332
333
334
335#define BOOTM_SIZE __stringify(0xa000000)
336#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(0080000))
337#define FDT_ADDR_R __stringify(SDRAM_OFFSET(FA00000))
338#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(FC00000))
339#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(FD00000))
340#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(FE00000))
341
342#else
343
344
345
346
347
348#ifndef CONFIG_MACH_SUN8I_V3S
349#define BOOTM_SIZE __stringify(0xa000000)
350#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(2000000))
351#define FDT_ADDR_R __stringify(SDRAM_OFFSET(3000000))
352#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(3100000))
353#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(3200000))
354#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(3300000))
355#else
356
357
358
359
360
361#define BOOTM_SIZE __stringify(0x2e00000)
362#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(1000000))
363#define FDT_ADDR_R __stringify(SDRAM_OFFSET(1800000))
364#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(1900000))
365#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(1A00000))
366#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(1B00000))
367#endif
368#endif
369
370#define MEM_LAYOUT_ENV_SETTINGS \
371 "bootm_size=" BOOTM_SIZE "\0" \
372 "kernel_addr_r=" KERNEL_ADDR_R "\0" \
373 "fdt_addr_r=" FDT_ADDR_R "\0" \
374 "scriptaddr=" SCRIPT_ADDR_R "\0" \
375 "pxefile_addr_r=" PXEFILE_ADDR_R "\0" \
376 "ramdisk_addr_r=" RAMDISK_ADDR_R "\0"
377
378#define DFU_ALT_INFO_RAM \
379 "dfu_alt_info_ram=" \
380 "kernel ram " KERNEL_ADDR_R " 0x1000000;" \
381 "fdt ram " FDT_ADDR_R " 0x100000;" \
382 "ramdisk ram " RAMDISK_ADDR_R " 0x4000000\0"
383
384#ifdef CONFIG_MMC
385#if CONFIG_MMC_SUNXI_SLOT_EXTRA != -1
386#define BOOTENV_DEV_MMC_AUTO(devtypeu, devtypel, instance) \
387 BOOTENV_DEV_MMC(MMC, mmc, 0) \
388 BOOTENV_DEV_MMC(MMC, mmc, 1) \
389 "bootcmd_mmc_auto=" \
390 "if test ${mmc_bootdev} -eq 1; then " \
391 "run bootcmd_mmc1; " \
392 "run bootcmd_mmc0; " \
393 "elif test ${mmc_bootdev} -eq 0; then " \
394 "run bootcmd_mmc0; " \
395 "run bootcmd_mmc1; " \
396 "fi\0"
397
398#define BOOTENV_DEV_NAME_MMC_AUTO(devtypeu, devtypel, instance) \
399 "mmc_auto "
400
401#define BOOT_TARGET_DEVICES_MMC(func) func(MMC_AUTO, mmc_auto, na)
402#else
403#define BOOT_TARGET_DEVICES_MMC(func) func(MMC, mmc, 0)
404#endif
405#else
406#define BOOT_TARGET_DEVICES_MMC(func)
407#endif
408
409#ifdef CONFIG_AHCI
410#define BOOT_TARGET_DEVICES_SCSI(func) func(SCSI, scsi, 0)
411#else
412#define BOOT_TARGET_DEVICES_SCSI(func)
413#endif
414
415#ifdef CONFIG_USB_STORAGE
416#define BOOT_TARGET_DEVICES_USB(func) func(USB, usb, 0)
417#else
418#define BOOT_TARGET_DEVICES_USB(func)
419#endif
420
421
422#define BOOTENV_DEV_FEL(devtypeu, devtypel, instance) \
423 "bootcmd_fel=" \
424 "if test -n ${fel_booted} && test -n ${fel_scriptaddr}; then " \
425 "echo '(FEL boot)'; " \
426 "source ${fel_scriptaddr}; " \
427 "fi\0"
428#define BOOTENV_DEV_NAME_FEL(devtypeu, devtypel, instance) \
429 "fel "
430
431#define BOOT_TARGET_DEVICES(func) \
432 func(FEL, fel, na) \
433 BOOT_TARGET_DEVICES_MMC(func) \
434 BOOT_TARGET_DEVICES_SCSI(func) \
435 BOOT_TARGET_DEVICES_USB(func) \
436 func(PXE, pxe, na) \
437 func(DHCP, dhcp, na)
438
439#ifdef CONFIG_OLD_SUNXI_KERNEL_COMPAT
440#define BOOTCMD_SUNXI_COMPAT \
441 "bootcmd_sunxi_compat=" \
442 "setenv root /dev/mmcblk0p3 rootwait; " \
443 "if ext2load mmc 0 0x44000000 uEnv.txt; then " \
444 "echo Loaded environment from uEnv.txt; " \
445 "env import -t 0x44000000 ${filesize}; " \
446 "fi; " \
447 "setenv bootargs console=${console} root=${root} ${extraargs}; " \
448 "ext2load mmc 0 0x43000000 script.bin && " \
449 "ext2load mmc 0 0x48000000 uImage && " \
450 "bootm 0x48000000\0"
451#else
452#define BOOTCMD_SUNXI_COMPAT
453#endif
454
455#include <config_distro_bootcmd.h>
456
457#ifdef CONFIG_USB_KEYBOARD
458#define CONSOLE_STDIN_SETTINGS \
459 "preboot=usb start\0" \
460 "stdin=serial,usbkbd\0"
461#else
462#define CONSOLE_STDIN_SETTINGS \
463 "stdin=serial\0"
464#endif
465
466#ifdef CONFIG_VIDEO
467#define CONSOLE_STDOUT_SETTINGS \
468 "stdout=serial,vga\0" \
469 "stderr=serial,vga\0"
470#elif CONFIG_DM_VIDEO
471#define CONFIG_SYS_WHITE_ON_BLACK
472#define CONSOLE_STDOUT_SETTINGS \
473 "stdout=serial,vidconsole\0" \
474 "stderr=serial,vidconsole\0"
475#else
476#define CONSOLE_STDOUT_SETTINGS \
477 "stdout=serial\0" \
478 "stderr=serial\0"
479#endif
480
481#ifdef CONFIG_MTDIDS_DEFAULT
482#define SUNXI_MTDIDS_DEFAULT \
483 "mtdids=" CONFIG_MTDIDS_DEFAULT "\0"
484#else
485#define SUNXI_MTDIDS_DEFAULT
486#endif
487
488#ifdef CONFIG_MTDPARTS_DEFAULT
489#define SUNXI_MTDPARTS_DEFAULT \
490 "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0"
491#else
492#define SUNXI_MTDPARTS_DEFAULT
493#endif
494
495#define PARTS_DEFAULT \
496 "name=loader1,start=8k,size=32k,uuid=${uuid_gpt_loader1};" \
497 "name=loader2,size=984k,uuid=${uuid_gpt_loader2};" \
498 "name=esp,size=128M,bootable,uuid=${uuid_gpt_esp};" \
499 "name=system,size=-,uuid=${uuid_gpt_system};"
500
501#define UUID_GPT_ESP "c12a7328-f81f-11d2-ba4b-00a0c93ec93b"
502
503#ifdef CONFIG_ARM64
504#define UUID_GPT_SYSTEM "b921b045-1df0-41c3-af44-4c6f280d3fae"
505#else
506#define UUID_GPT_SYSTEM "69dad710-2ce4-4e3c-b16c-21a1d49abed3"
507#endif
508
509#define CONSOLE_ENV_SETTINGS \
510 CONSOLE_STDIN_SETTINGS \
511 CONSOLE_STDOUT_SETTINGS
512
513#ifdef CONFIG_ARM64
514#define FDTFILE "allwinner/" CONFIG_DEFAULT_DEVICE_TREE ".dtb"
515#else
516#define FDTFILE CONFIG_DEFAULT_DEVICE_TREE ".dtb"
517#endif
518
519#define CONFIG_EXTRA_ENV_SETTINGS \
520 CONSOLE_ENV_SETTINGS \
521 MEM_LAYOUT_ENV_SETTINGS \
522 DFU_ALT_INFO_RAM \
523 "fdtfile=" FDTFILE "\0" \
524 "console=ttyS0,115200\0" \
525 SUNXI_MTDIDS_DEFAULT \
526 SUNXI_MTDPARTS_DEFAULT \
527 "uuid_gpt_esp=" UUID_GPT_ESP "\0" \
528 "uuid_gpt_system=" UUID_GPT_SYSTEM "\0" \
529 "partitions=" PARTS_DEFAULT "\0" \
530 BOOTCMD_SUNXI_COMPAT \
531 BOOTENV
532
533#else
534#define CONFIG_EXTRA_ENV_SETTINGS
535#endif
536
537#endif
538