blob: 535797a72ddd215e374a62c3f530e1e4eb04b826 [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 */
Simon Glassec3be542015-08-30 16:55:41 -060043#define CONFIG_GENERIC_MMC
Simon Glassec3be542015-08-30 16:55:41 -060044#define CONFIG_DWMMC
45#define CONFIG_BOUNCE_BUFFER
46
Simon Glassec3be542015-08-30 16:55:41 -060047#define CONFIG_FAT_WRITE
Simon Glassec3be542015-08-30 16:55:41 -060048#define CONFIG_PARTITION_UUIDS
49#define CONFIG_CMD_PART
50
51/* RAW SD card / eMMC locations. */
Simon Glassec3be542015-08-30 16:55:41 -060052#define CONFIG_SYS_SPI_U_BOOT_OFFS (128 << 10)
53
54/* FAT sd card locations. */
55#define CONFIG_SYS_MMCSD_FS_BOOT_PARTITION 1
56#define CONFIG_SPL_FS_LOAD_PAYLOAD_NAME "u-boot.img"
57
Simon Glassec3be542015-08-30 16:55:41 -060058#define CONFIG_SYS_SDRAM_BASE 0
59#define CONFIG_NR_DRAM_BANKS 1
60#define SDRAM_BANK_SIZE (2UL << 30)
61
62#define CONFIG_SPI_FLASH
63#define CONFIG_SPI
Simon Glassec3be542015-08-30 16:55:41 -060064#define CONFIG_SF_DEFAULT_SPEED 20000000
65
jk.kernel@gmail.com376bcc62016-07-26 18:28:24 +080066#ifndef CONFIG_SPL_BUILD
Xu Ziyuana11a53f2016-07-15 00:26:59 +080067/* usb otg */
68#define CONFIG_USB_GADGET
69#define CONFIG_USB_GADGET_DUALSPEED
70#define CONFIG_USB_GADGET_DWC2_OTG
71#define CONFIG_ROCKCHIP_USB2_PHY
72#define CONFIG_USB_GADGET_VBUS_DRAW 0
73
74/* fastboot */
75#define CONFIG_CMD_FASTBOOT
76#define CONFIG_USB_FUNCTION_FASTBOOT
77#define CONFIG_FASTBOOT_FLASH
78#define CONFIG_FASTBOOT_FLASH_MMC_DEV 1 /* eMMC */
jk.kernel@gmail.com9a04f282016-07-26 18:28:26 +080079#define CONFIG_FASTBOOT_BUF_ADDR CONFIG_SYS_LOAD_ADDR
Xu Ziyuana11a53f2016-07-15 00:26:59 +080080#define CONFIG_FASTBOOT_BUF_SIZE 0x08000000
81
Xu Ziyuanb653b472016-08-03 11:55:06 +080082/* usb mass storage */
83#define CONFIG_USB_FUNCTION_MASS_STORAGE
84#define CONFIG_CMD_USB_MASS_STORAGE
85
Xu Ziyuana11a53f2016-07-15 00:26:59 +080086#define CONFIG_USB_GADGET_DOWNLOAD
87#define CONFIG_G_DNL_MANUFACTURER "Rockchip"
88#define CONFIG_G_DNL_VENDOR_NUM 0x2207
89#define CONFIG_G_DNL_PRODUCT_NUM 0x320a
90
Sjoerd Simons427418b2015-08-30 16:55:48 -060091#define ENV_MEM_LAYOUT_SETTINGS \
92 "scriptaddr=0x00000000\0" \
93 "pxefile_addr_r=0x00100000\0" \
94 "fdt_addr_r=0x01f00000\0" \
95 "kernel_addr_r=0x02000000\0" \
96 "ramdisk_addr_r=0x04000000\0"
97
Sjoerd Simons427418b2015-08-30 16:55:48 -060098#include <config_distro_bootcmd.h>
99
Sandy Pattersonf4526ef2016-07-11 13:38:52 -0400100/* 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 -0600101 * limit the fdt reallocation to that */
102#define CONFIG_EXTRA_ENV_SETTINGS \
Sandy Pattersonf4526ef2016-07-11 13:38:52 -0400103 "fdt_high=0x0fffffff\0" \
104 "initrd_high=0x0fffffff\0" \
Xu Ziyuan05c3ca62016-08-03 11:55:05 +0800105 "partitions=" PARTS_DEFAULT \
Sjoerd Simons427418b2015-08-30 16:55:48 -0600106 ENV_MEM_LAYOUT_SETTINGS \
Simon Glasscf88b7c2016-01-21 19:44:13 -0700107 ROCKCHIP_DEVICE_SETTINGS \
Sjoerd Simons427418b2015-08-30 16:55:48 -0600108 BOOTENV
Simon Glassec3be542015-08-30 16:55:41 -0600109#endif
110
Jacob Chenc95f3782016-09-19 18:46:28 +0800111#define CONFIG_BOARD_LATE_INIT
112#define CONFIG_PREBOOT
113
Simon Glassec3be542015-08-30 16:55:41 -0600114#endif