1 /* 2 * (C) Copyright 2015 Rockchip Electronics Co., Ltd 3 * 4 * SPDX-License-Identifier: GPL-2.0+ 5 */ 6 #ifndef __CONFIG_RK3036_COMMON_H 7 #define __CONFIG_RK3036_COMMON_H 8 9 #include <asm/arch/hardware.h> 10 11 #define CONFIG_SYS_NO_FLASH 12 #define CONFIG_NR_DRAM_BANKS 1 13 #define CONFIG_ENV_IS_NOWHERE 14 #define CONFIG_ENV_SIZE 0x2000 15 #define CONFIG_SYS_MAXARGS 16 16 #define CONFIG_BAUDRATE 115200 17 #define CONFIG_SYS_MALLOC_LEN (32 << 20) 18 #define CONFIG_SYS_CBSIZE 1024 19 #define CONFIG_SKIP_LOWLEVEL_INIT 20 #define CONFIG_SYS_THUMB_BUILD 21 22 #define CONFIG_SYS_TIMER_RATE (24 * 1000 * 1000) 23 #define CONFIG_SYS_TIMER_BASE 0x200440a0 /* TIMER5 */ 24 #define CONFIG_SYS_TIMER_COUNTER (CONFIG_SYS_TIMER_BASE + 8) 25 26 #define CONFIG_SYS_NS16550 27 #define CONFIG_SYS_NS16550_MEM32 28 29 #define CONFIG_SYS_TEXT_BASE 0x60000000 30 #define CONFIG_SYS_INIT_SP_ADDR 0x60100000 31 #define CONFIG_SYS_LOAD_ADDR 0x60800800 32 #define CONFIG_SPL_STACK 0x10081fff 33 #define CONFIG_SPL_TEXT_BASE 0x10081004 34 35 #define CONFIG_ROCKCHIP_MAX_INIT_SIZE (4 << 10) 36 #define CONFIG_ROCKCHIP_CHIP_TAG "RK30" 37 38 /* MMC/SD IP block */ 39 #define CONFIG_MMC 40 #define CONFIG_GENERIC_MMC 41 #define CONFIG_DWMMC 42 #define CONFIG_BOUNCE_BUFFER 43 44 #define CONFIG_FAT_WRITE 45 #define CONFIG_PARTITION_UUIDS 46 #define CONFIG_CMD_PART 47 48 #define CONFIG_SYS_SDRAM_BASE 0x60000000 49 #define CONFIG_NR_DRAM_BANKS 1 50 #define SDRAM_BANK_SIZE (512UL << 20UL) 51 52 #define CONFIG_SPI_FLASH 53 #define CONFIG_SPI 54 #define CONFIG_SPI_FLASH_GIGADEVICE 55 #define CONFIG_SF_DEFAULT_SPEED 20000000 56 57 #ifndef CONFIG_SPL_BUILD 58 /* usb otg */ 59 #define CONFIG_USB_GADGET 60 #define CONFIG_USB_GADGET_DUALSPEED 61 #define CONFIG_USB_GADGET_DWC2_OTG 62 #define CONFIG_USB_GADGET_VBUS_DRAW 0 63 64 /* fastboot */ 65 #define CONFIG_CMD_FASTBOOT 66 #define CONFIG_USB_FUNCTION_FASTBOOT 67 #define CONFIG_FASTBOOT_FLASH 68 #define CONFIG_FASTBOOT_FLASH_MMC_DEV 0 69 #define CONFIG_FASTBOOT_BUF_ADDR CONFIG_SYS_LOAD_ADDR 70 #define CONFIG_FASTBOOT_BUF_SIZE 0x08000000 71 72 /* usb mass storage */ 73 #define CONFIG_USB_FUNCTION_MASS_STORAGE 74 #define CONFIG_CMD_USB_MASS_STORAGE 75 76 #define CONFIG_USB_GADGET_DOWNLOAD 77 #define CONFIG_G_DNL_MANUFACTURER "Rockchip" 78 #define CONFIG_G_DNL_VENDOR_NUM 0x2207 79 #define CONFIG_G_DNL_PRODUCT_NUM 0x310a 80 81 /* Enable gpt partition table */ 82 #define CONFIG_CMD_GPT 83 84 #include <config_distro_defaults.h> 85 86 #define ENV_MEM_LAYOUT_SETTINGS \ 87 "scriptaddr=0x60000000\0" \ 88 "pxefile_addr_r=0x60100000\0" \ 89 "fdt_addr_r=0x61f00000\0" \ 90 "kernel_addr_r=0x62000000\0" \ 91 "ramdisk_addr_r=0x64000000\0" 92 93 #define CONFIG_RANDOM_UUID 94 #define PARTS_DEFAULT \ 95 "uuid_disk=${uuid_gpt_disk};" \ 96 "name=boot,start=8M,size=64M,bootable,uuid=${uuid_gpt_boot};" \ 97 "name=rootfs,size=-,uuid=${uuid_gpt_rootfs};\0" \ 98 99 /* First try to boot from SD (index 0), then eMMC (index 1 */ 100 #define BOOT_TARGET_DEVICES(func) \ 101 func(MMC, mmc, 0) \ 102 func(MMC, mmc, 1) 103 104 #include <config_distro_bootcmd.h> 105 106 /* Linux fails to load the fdt if it's loaded above 512M on a evb-rk3036 board, 107 * so limit the fdt reallocation to that */ 108 #define CONFIG_EXTRA_ENV_SETTINGS \ 109 "fdt_high=0x7fffffff\0" \ 110 "partitions=" PARTS_DEFAULT \ 111 ENV_MEM_LAYOUT_SETTINGS \ 112 BOOTENV 113 #endif 114 115 #define CONFIG_BOARD_LATE_INIT 116 #define CONFIG_PREBOOT 117 118 #endif 119