blob: 5358372587b0c2248bec78a34854909a41b33eb9 [file] [log] [blame]
Simon Glassec3be542015-08-30 16:55:41 -06001/*
2 * (C) Copyright 2015 Google, Inc
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7#ifndef __CONFIG_RK3288_COMMON_H
8#define __CONFIG_RK3288_COMMON_H
9
10#include <asm/arch/hardware.h>
Jacob Chen63dc9712016-10-08 13:47:41 +080011#include "rockchip-common.h"
Simon Glassec3be542015-08-30 16:55:41 -060012
Xu Ziyuan68728e82016-08-27 21:53:14 +080013#define CONFIG_SKIP_LOWLEVEL_INIT_ONLY
Simon Glassec3be542015-08-30 16:55:41 -060014#define CONFIG_SYS_NO_FLASH
15#define CONFIG_NR_DRAM_BANKS 1
Simon Glassec3be542015-08-30 16:55:41 -060016#define CONFIG_ENV_SIZE 0x2000
Simon Glassec3be542015-08-30 16:55:41 -060017#define CONFIG_SYS_MAXARGS 16
18#define CONFIG_BAUDRATE 115200
19#define CONFIG_SYS_MALLOC_LEN (32 << 20)
20#define CONFIG_SYS_CBSIZE 1024
Simon Glassec3be542015-08-30 16:55:41 -060021#define CONFIG_SYS_THUMB_BUILD
Simon Glassec3be542015-08-30 16:55:41 -060022
23#define CONFIG_SYS_TIMER_RATE (24 * 1000 * 1000)
huang lin8db3e242015-11-17 14:20:09 +080024#define CONFIG_SYS_TIMER_BASE 0xff810020 /* TIMER7 */
25#define CONFIG_SYS_TIMER_COUNTER (CONFIG_SYS_TIMER_BASE + 8)
Simon Glassec3be542015-08-30 16:55:41 -060026
27#define CONFIG_SPL_FRAMEWORK
Simon Glassec3be542015-08-30 16:55:41 -060028#define CONFIG_SYS_NS16550_MEM32
29#define CONFIG_SPL_BOARD_INIT
30
Xu Ziyuan5401eb82016-07-12 19:09:49 +080031#ifdef CONFIG_ROCKCHIP_SPL_BACK_TO_BROM
32/* Bootrom will load u-boot binary to 0x0 once return from SPL */
33#define CONFIG_SYS_TEXT_BASE 0x00000000
34#else
Simon Glassec3be542015-08-30 16:55:41 -060035#define CONFIG_SYS_TEXT_BASE 0x00100000
Xu Ziyuan5401eb82016-07-12 19:09:49 +080036#endif
Simon Glassec3be542015-08-30 16:55:41 -060037#define CONFIG_SYS_INIT_SP_ADDR 0x00100000
38#define CONFIG_SYS_LOAD_ADDR 0x00800800
39#define CONFIG_SPL_STACK 0xff718000
40#define CONFIG_SPL_TEXT_BASE 0xff704004
41
42/* MMC/SD IP block */
43#define CONFIG_MMC
44#define CONFIG_GENERIC_MMC
Simon Glassec3be542015-08-30 16:55:41 -060045#define CONFIG_DWMMC
46#define CONFIG_BOUNCE_BUFFER
47
Simon Glassec3be542015-08-30 16:55:41 -060048#define CONFIG_FAT_WRITE
Simon Glassec3be542015-08-30 16:55:41 -060049#define CONFIG_PARTITION_UUIDS
50#define CONFIG_CMD_PART
51
52/* RAW SD card / eMMC locations. */
Simon Glassec3be542015-08-30 16:55:41 -060053#define CONFIG_SYS_SPI_U_BOOT_OFFS (128 << 10)
54
55/* FAT sd card locations. */
56#define CONFIG_SYS_MMCSD_FS_BOOT_PARTITION 1
57#define CONFIG_SPL_FS_LOAD_PAYLOAD_NAME "u-boot.img"
58
Simon Glassec3be542015-08-30 16:55:41 -060059#define CONFIG_SYS_SDRAM_BASE 0
60#define CONFIG_NR_DRAM_BANKS 1
61#define SDRAM_BANK_SIZE (2UL << 30)
62
63#define CONFIG_SPI_FLASH
64#define CONFIG_SPI
Simon Glassec3be542015-08-30 16:55:41 -060065#define CONFIG_SF_DEFAULT_SPEED 20000000
66
jk.kernel@gmail.com376bcc62016-07-26 18:28:24 +080067#ifndef CONFIG_SPL_BUILD
Xu Ziyuana11a53f2016-07-15 00:26:59 +080068/* usb otg */
69#define CONFIG_USB_GADGET
70#define CONFIG_USB_GADGET_DUALSPEED
71#define CONFIG_USB_GADGET_DWC2_OTG
72#define CONFIG_ROCKCHIP_USB2_PHY
73#define CONFIG_USB_GADGET_VBUS_DRAW 0
74
75/* fastboot */
76#define CONFIG_CMD_FASTBOOT
77#define CONFIG_USB_FUNCTION_FASTBOOT
78#define CONFIG_FASTBOOT_FLASH
79#define CONFIG_FASTBOOT_FLASH_MMC_DEV 1 /* eMMC */
jk.kernel@gmail.com9a04f282016-07-26 18:28:26 +080080#define CONFIG_FASTBOOT_BUF_ADDR CONFIG_SYS_LOAD_ADDR
Xu Ziyuana11a53f2016-07-15 00:26:59 +080081#define CONFIG_FASTBOOT_BUF_SIZE 0x08000000
82
Xu Ziyuanb653b472016-08-03 11:55:06 +080083/* usb mass storage */
84#define CONFIG_USB_FUNCTION_MASS_STORAGE
85#define CONFIG_CMD_USB_MASS_STORAGE
86
Xu Ziyuana11a53f2016-07-15 00:26:59 +080087#define CONFIG_USB_GADGET_DOWNLOAD
88#define CONFIG_G_DNL_MANUFACTURER "Rockchip"
89#define CONFIG_G_DNL_VENDOR_NUM 0x2207
90#define CONFIG_G_DNL_PRODUCT_NUM 0x320a
91
Sjoerd Simons427418b2015-08-30 16:55:48 -060092#define ENV_MEM_LAYOUT_SETTINGS \
93 "scriptaddr=0x00000000\0" \
94 "pxefile_addr_r=0x00100000\0" \
95 "fdt_addr_r=0x01f00000\0" \
96 "kernel_addr_r=0x02000000\0" \
97 "ramdisk_addr_r=0x04000000\0"
98
Sjoerd Simons427418b2015-08-30 16:55:48 -060099#include <config_distro_bootcmd.h>
100
Sandy Pattersonf4526ef2016-07-11 13:38:52 -0400101/* Linux fails to load the fdt if it's loaded above 256M on a Rock 2 board, so
Sjoerd Simons427418b2015-08-30 16:55:48 -0600102 * limit the fdt reallocation to that */
103#define CONFIG_EXTRA_ENV_SETTINGS \
Sandy Pattersonf4526ef2016-07-11 13:38:52 -0400104 "fdt_high=0x0fffffff\0" \
105 "initrd_high=0x0fffffff\0" \
Xu Ziyuan05c3ca62016-08-03 11:55:05 +0800106 "partitions=" PARTS_DEFAULT \
Sjoerd Simons427418b2015-08-30 16:55:48 -0600107 ENV_MEM_LAYOUT_SETTINGS \
Simon Glasscf88b7c2016-01-21 19:44:13 -0700108 ROCKCHIP_DEVICE_SETTINGS \
Sjoerd Simons427418b2015-08-30 16:55:48 -0600109 BOOTENV
Simon Glassec3be542015-08-30 16:55:41 -0600110#endif
111
Jacob Chenc95f3782016-09-19 18:46:28 +0800112#define CONFIG_BOARD_LATE_INIT
113#define CONFIG_PREBOOT
114
Simon Glassec3be542015-08-30 16:55:41 -0600115#endif