rockchip: rk3328: add evb-rk3328 support
evb-rk3328 is an evb from Rockchip based on rk3328 SoC: - 2 USB2.0 Host port; - 1 USB3.0 Host port; - 1 HDMI port; - 2 10/100M eth port; - 2GB ddr; - 16GB eMMC; - UART to USB debug port; Signed-off-by: William Zhang <william.zhang@rock-chips.com> Signed-off-by: Kever Yang <kever.yang@rock-chips.com> Acked-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
52f6c17ecb
commit
625ec503cb
|
@ -0,0 +1,23 @@
|
||||||
|
if ROCKCHIP_RK3328
|
||||||
|
|
||||||
|
choice
|
||||||
|
prompt "RK3328 board select"
|
||||||
|
|
||||||
|
config TARGET_EVB_RK3328
|
||||||
|
bool "RK3328 evaluation board"
|
||||||
|
help
|
||||||
|
RK3328evb is a evaluation board for Rockchip rk3328,
|
||||||
|
with full function and phisical connectors support like
|
||||||
|
usb2.0 host ports, LVDS, JTAG, MAC, SDcard, HDMI, USB-2-serial...
|
||||||
|
|
||||||
|
endchoice
|
||||||
|
|
||||||
|
config SYS_SOC
|
||||||
|
default "rockchip"
|
||||||
|
|
||||||
|
config SYS_MALLOC_F_LEN
|
||||||
|
default 0x0800
|
||||||
|
|
||||||
|
source "board/rockchip/evb_rk3328/Kconfig"
|
||||||
|
|
||||||
|
endif
|
|
@ -0,0 +1,15 @@
|
||||||
|
if TARGET_EVB_RK3328
|
||||||
|
|
||||||
|
config SYS_BOARD
|
||||||
|
default "evb_rk3328"
|
||||||
|
|
||||||
|
config SYS_VENDOR
|
||||||
|
default "rockchip"
|
||||||
|
|
||||||
|
config SYS_CONFIG_NAME
|
||||||
|
default "evb_rk3328"
|
||||||
|
|
||||||
|
config BOARD_SPECIFIC_OPTIONS # dummy
|
||||||
|
def_bool y
|
||||||
|
|
||||||
|
endif
|
|
@ -0,0 +1,6 @@
|
||||||
|
EVB-RK3328
|
||||||
|
M: William Zhang <william.zhang@rock-chips.com>
|
||||||
|
S: Maintained
|
||||||
|
F: board/rockchip/evb_rk3328
|
||||||
|
F: include/configs/evb_rk3328.h
|
||||||
|
F: configs/evb-rk3328_defconfig
|
|
@ -0,0 +1,7 @@
|
||||||
|
#
|
||||||
|
# (C) Copyright 2016 Rockchip Electronics Co., Ltd
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: GPL-2.0+
|
||||||
|
#
|
||||||
|
|
||||||
|
obj-y += evb-rk3328.o
|
|
@ -0,0 +1,70 @@
|
||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
|
RK3328 key features we might use in U-Boot:
|
||||||
|
* CPU: ARMv8 64bit quad-core Cortex-A53
|
||||||
|
* IRAM: 36KB
|
||||||
|
* DRAM: 4GB-16MB dual-channel
|
||||||
|
* eMMC: support eMMC 5.0/5.1, suport HS400, HS200, DDR50
|
||||||
|
* SD/MMC: support SD 3.0, MMC 4.51
|
||||||
|
* USB: USB2.0 EHCI host port *2
|
||||||
|
* Display: RGB/HDMI/DP/MIPI/EDP
|
||||||
|
|
||||||
|
evb key features:
|
||||||
|
* regulator: pwm regulator for CPU B/L
|
||||||
|
* PMIC: rk808
|
||||||
|
* debug console: UART2
|
||||||
|
|
||||||
|
In order to support Arm Trust Firmware(ATF), we need to use the
|
||||||
|
miniloader from rockchip which:
|
||||||
|
* do DRAM init
|
||||||
|
* load and verify ATF image
|
||||||
|
* load and verify U-Boot image
|
||||||
|
|
||||||
|
Here is the step-by-step to boot to U-Boot on rk3328.
|
||||||
|
|
||||||
|
Get the Source and prebuild binary
|
||||||
|
==================================
|
||||||
|
|
||||||
|
> mkdir ~/evb_rk3328
|
||||||
|
> cd ~/evb_rk3328
|
||||||
|
> git clone https://github.com/ARM-software/arm-trusted-firmware.git
|
||||||
|
> git clone https://github.com/rockchip-linux/rkbin
|
||||||
|
> git clone https://github.com/rockchip-linux/rkflashtool
|
||||||
|
|
||||||
|
Compile ATF
|
||||||
|
===============
|
||||||
|
|
||||||
|
> cd arm-trusted-firmware
|
||||||
|
> make realclean
|
||||||
|
> make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3328 bl31
|
||||||
|
|
||||||
|
Compile U-Boot
|
||||||
|
==================
|
||||||
|
|
||||||
|
> cd ../u-boot
|
||||||
|
> make CROSS_COMPILE=aarch64-linux-gnu- evb-rk3328_defconfig all
|
||||||
|
|
||||||
|
Compile rkflashtool
|
||||||
|
=======================
|
||||||
|
|
||||||
|
> cd ../rkflashtool
|
||||||
|
> make
|
||||||
|
|
||||||
|
Package image for miniloader
|
||||||
|
================================
|
||||||
|
> cd ..
|
||||||
|
> cp arm-trusted-firmware/build/rk3328/release/bl31.bin rkbin/rk33
|
||||||
|
> ./rkbin/tools/trust_merger rkbin/tools/RK3328TRUST.ini
|
||||||
|
> ./rkbin/tools/loaderimage --pack --uboot u-boot/u-boot-dtb.bin uboot.img
|
||||||
|
> mkdir image
|
||||||
|
> mv trust.img ./image/
|
||||||
|
> mv uboot.img ./image/rk3328evb-uboot.bin
|
||||||
|
|
||||||
|
Flash image
|
||||||
|
===============
|
||||||
|
Power on(or reset with RESET KEY) with MASKROM KEY preesed, and then:
|
||||||
|
|
||||||
|
> ./rkflashtool/rkflashloader rk3328evb
|
||||||
|
|
||||||
|
You should be able to get U-Boot log message in console/UART2 now.
|
|
@ -0,0 +1,40 @@
|
||||||
|
/*
|
||||||
|
* (C) Copyright 2016 Rockchip Electronics Co., Ltd
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0+
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <common.h>
|
||||||
|
#include <asm/armv8/mmu.h>
|
||||||
|
#include <dwc3-uboot.h>
|
||||||
|
#include <usb.h>
|
||||||
|
|
||||||
|
DECLARE_GLOBAL_DATA_PTR;
|
||||||
|
|
||||||
|
int board_init(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int dram_init(void)
|
||||||
|
{
|
||||||
|
gd->ram_size = 0x80000000;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void dram_init_banksize(void)
|
||||||
|
{
|
||||||
|
/* Reserve 0x200000 for ATF bl31 */
|
||||||
|
gd->bd->bi_dram[0].start = 0x200000;
|
||||||
|
gd->bd->bi_dram[0].size = 0x7e000000;
|
||||||
|
}
|
||||||
|
|
||||||
|
int usb_gadget_handle_interrupts(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int board_usb_init(int index, enum usb_init_type init)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -0,0 +1,26 @@
|
||||||
|
/*
|
||||||
|
* (C) Copyright 2016 Rockchip Electronics Co., Ltd
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0+
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __EVB_RK3328_H
|
||||||
|
#define __EVB_RK3328_H
|
||||||
|
|
||||||
|
#include <configs/rk3328_common.h>
|
||||||
|
|
||||||
|
#define CONFIG_ENV_IS_IN_MMC
|
||||||
|
#define CONFIG_SYS_MMC_ENV_DEV 1
|
||||||
|
/*
|
||||||
|
* SPL @ 32k for ~36k
|
||||||
|
* ENV @ 96k
|
||||||
|
* u-boot @ 128K
|
||||||
|
*/
|
||||||
|
#define CONFIG_ENV_OFFSET (96 * 1024)
|
||||||
|
|
||||||
|
#define SDRAM_BANK_SIZE (2UL << 30)
|
||||||
|
|
||||||
|
#define CONFIG_SYS_WHITE_ON_BLACK
|
||||||
|
#define CONFIG_CONSOLE_SCROLL_LINES 10
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue