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