Merge tag 'u-boot-rockchip-20190912' of https://gitlab.denx.de/u-boot/custodians/u-boot-rockchip
- add idbloader.img target for rockchip tpl+spl; - usb ehci/ohci: go on process if clock driver don't have clk_enable(); - remove clk_enable() for rockchip clock drivers; - add boot order for rockpro64
This commit is contained in:
commit
5ba8b12543
12
Makefile
12
Makefile
@ -882,6 +882,10 @@ ifeq ($(CONFIG_MPC85xx)$(CONFIG_OF_SEPARATE),yy)
|
|||||||
ALL-y += u-boot-with-dtb.bin
|
ALL-y += u-boot-with-dtb.bin
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_ARCH_ROCKCHIP)$(CONFIG_SPL)$(CONFIG_TPL),yyy)
|
||||||
|
ALL-y += idbloader.img
|
||||||
|
endif
|
||||||
|
|
||||||
LDFLAGS_u-boot += $(LDFLAGS_FINAL)
|
LDFLAGS_u-boot += $(LDFLAGS_FINAL)
|
||||||
|
|
||||||
# Avoid 'Not enough room for program headers' error on binutils 2.28 onwards.
|
# Avoid 'Not enough room for program headers' error on binutils 2.28 onwards.
|
||||||
@ -1314,6 +1318,14 @@ OBJCOPYFLAGS_u-boot-with-spl.bin = -I binary -O binary \
|
|||||||
u-boot-with-spl.bin: $(SPL_IMAGE) $(SPL_PAYLOAD) FORCE
|
u-boot-with-spl.bin: $(SPL_IMAGE) $(SPL_PAYLOAD) FORCE
|
||||||
$(call if_changed,pad_cat)
|
$(call if_changed,pad_cat)
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_ARCH_ROCKCHIP),y)
|
||||||
|
MKIMAGEFLAGS_u-boot-tpl.img = -n $(CONFIG_SYS_SOC) -T rksd
|
||||||
|
tpl/u-boot-tpl.img: tpl/u-boot-tpl.bin FORCE
|
||||||
|
$(call if_changed,mkimage)
|
||||||
|
idbloader.img: tpl/u-boot-tpl.img spl/u-boot-spl.bin FORCE
|
||||||
|
$(call if_changed,cat)
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_ARCH_LPC32XX)$(CONFIG_SPL),yy)
|
ifeq ($(CONFIG_ARCH_LPC32XX)$(CONFIG_SPL),yy)
|
||||||
MKIMAGEFLAGS_lpc32xx-spl.img = -T lpc32xximage -a $(CONFIG_SPL_TEXT_BASE)
|
MKIMAGEFLAGS_lpc32xx-spl.img = -T lpc32xximage -a $(CONFIG_SPL_TEXT_BASE)
|
||||||
|
|
||||||
|
@ -5,6 +5,11 @@
|
|||||||
|
|
||||||
#include "rk3399-u-boot.dtsi"
|
#include "rk3399-u-boot.dtsi"
|
||||||
#include "rk3399-sdram-lpddr4-100.dtsi"
|
#include "rk3399-sdram-lpddr4-100.dtsi"
|
||||||
|
/ {
|
||||||
|
chosen {
|
||||||
|
u-boot,spl-boot-order = "same-as-spl", &sdmmc, &sdhci;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
&vdd_log {
|
&vdd_log {
|
||||||
regulator-init-microvolt = <950000>;
|
regulator-init-microvolt = <950000>;
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0+
|
# SPDX-License-Identifier: GPL-2.0+
|
||||||
#
|
#
|
||||||
# Copyright (c) 2014 Google, Inc
|
# Copyright (c) 2014 Google, Inc
|
||||||
|
# Copyright (c) 2019 Rockchip Electronics Co., Ltd.
|
||||||
|
|
||||||
# We don't want the bootrom-helper present in a full U-Boot build, as
|
# We don't want the bootrom-helper present in a full U-Boot build, as
|
||||||
# this may have entered from ATF with the stack-pointer pointing to
|
# this may have entered from ATF with the stack-pointer pointing to
|
||||||
@ -21,19 +22,14 @@ ifeq ($(CONFIG_SPL_BUILD)$(CONFIG_TPL_BUILD),)
|
|||||||
# meaning "turn it off".
|
# meaning "turn it off".
|
||||||
obj-y += boot_mode.o
|
obj-y += boot_mode.o
|
||||||
obj-$(CONFIG_ROCKCHIP_COMMON_BOARD) += board.o
|
obj-$(CONFIG_ROCKCHIP_COMMON_BOARD) += board.o
|
||||||
|
obj-$(CONFIG_MISC_INIT_R) += misc.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
obj-$(CONFIG_$(SPL_TPL_)RAM) += sdram_common.o
|
obj-$(CONFIG_$(SPL_TPL_)RAM) += sdram_common.o
|
||||||
|
|
||||||
ifdef CONFIG_MISC_INIT_R
|
|
||||||
obj-y += misc.o
|
|
||||||
endif
|
|
||||||
|
|
||||||
obj-$(CONFIG_ROCKCHIP_RK3036) += rk3036/
|
obj-$(CONFIG_ROCKCHIP_RK3036) += rk3036/
|
||||||
obj-$(CONFIG_ROCKCHIP_RK3128) += rk3128/
|
obj-$(CONFIG_ROCKCHIP_RK3128) += rk3128/
|
||||||
ifndef CONFIG_TPL_BUILD
|
|
||||||
obj-$(CONFIG_ROCKCHIP_RK3188) += rk3188/
|
obj-$(CONFIG_ROCKCHIP_RK3188) += rk3188/
|
||||||
endif
|
|
||||||
obj-$(CONFIG_ROCKCHIP_RK322X) += rk322x/
|
obj-$(CONFIG_ROCKCHIP_RK322X) += rk322x/
|
||||||
obj-$(CONFIG_ROCKCHIP_RK3288) += rk3288/
|
obj-$(CONFIG_ROCKCHIP_RK3288) += rk3288/
|
||||||
obj-$(CONFIG_ROCKCHIP_RK3328) += rk3328/
|
obj-$(CONFIG_ROCKCHIP_RK3328) += rk3328/
|
||||||
|
@ -18,8 +18,6 @@ Build the TPL/SPL stage
|
|||||||
=======================
|
=======================
|
||||||
|
|
||||||
> make CROSS_COMPILE=aarch64-unknown-elf- ARCH=arm
|
> make CROSS_COMPILE=aarch64-unknown-elf- ARCH=arm
|
||||||
> tools/mkimage -n rk3368 -T rksd -d tpl/u-boot-tpl.bin spl-3368.img
|
|
||||||
> cat spl/u-boot-spl-dtb.bin >> spl-3368.img
|
|
||||||
|
|
||||||
Build the full U-Boot and a FIT image including the ATF
|
Build the full U-Boot and a FIT image including the ATF
|
||||||
=======================================================
|
=======================================================
|
||||||
@ -35,7 +33,7 @@ Copy the SPL to offset 32k and the FIT image containing the payloads
|
|||||||
SD-Card
|
SD-Card
|
||||||
-------
|
-------
|
||||||
|
|
||||||
> dd if=spl-3368.img of=/dev/sdb seek=64
|
> dd if=idbloader.img of=/dev/sdb seek=64
|
||||||
> dd if=u-boot.itb of=/dev/sdb seek=512
|
> dd if=u-boot.itb of=/dev/sdb seek=512
|
||||||
|
|
||||||
eMMC
|
eMMC
|
||||||
|
@ -275,9 +275,7 @@ As of now TPL is added on Vyasa-RK3288 board.
|
|||||||
|
|
||||||
To write an image that boots from an SD card (assumed to be /dev/mmcblk0):
|
To write an image that boots from an SD card (assumed to be /dev/mmcblk0):
|
||||||
|
|
||||||
./tools/mkimage -n rk3288 -T rksd -d ./tpl/u-boot-tpl.bin out &&
|
sudo dd if=idbloader.img of=/dev/mmcblk0 seek=64 &&
|
||||||
cat ./spl/u-boot-spl-dtb.bin >> out &&
|
|
||||||
sudo dd if=out of=/dev/mmcblk0 seek=64 &&
|
|
||||||
sudo dd if=u-boot-dtb.img of=/dev/mmcblk0 seek=16384
|
sudo dd if=u-boot-dtb.img of=/dev/mmcblk0 seek=16384
|
||||||
|
|
||||||
Booting from an SD card on RK3188
|
Booting from an SD card on RK3188
|
||||||
@ -310,11 +308,6 @@ Booting from an SD card on Pine64 Rock64 (RK3328)
|
|||||||
For Rock64 rk3328 board the following three parts are required:
|
For Rock64 rk3328 board the following three parts are required:
|
||||||
TPL, SPL, and the u-boot image tree blob.
|
TPL, SPL, and the u-boot image tree blob.
|
||||||
|
|
||||||
- Create TPL/SPL image
|
|
||||||
|
|
||||||
=> tools/mkimage -n rk3328 -T rksd -d tpl/u-boot-tpl.bin idbloader.img
|
|
||||||
=> cat spl/u-boot-spl.bin >> idbloader.img
|
|
||||||
|
|
||||||
- Write TPL/SPL image at 64 sector
|
- Write TPL/SPL image at 64 sector
|
||||||
|
|
||||||
=> sudo dd if=idbloader.img of=/dev/mmcblk0 seek=64
|
=> sudo dd if=idbloader.img of=/dev/mmcblk0 seek=64
|
||||||
@ -473,19 +466,9 @@ Hit any key to stop autoboot: 0
|
|||||||
|
|
||||||
Option 3: Package the image with TPL:
|
Option 3: Package the image with TPL:
|
||||||
|
|
||||||
- Prefix rk3399 header to TPL image
|
|
||||||
|
|
||||||
=> cd /path/to/u-boot
|
|
||||||
=> ./tools/mkimage -n rk3399 -T rksd -d tpl/u-boot-tpl-dtb.bin out
|
|
||||||
|
|
||||||
- Concatinate tpl with spl
|
|
||||||
|
|
||||||
=> cd /path/to/u-boot
|
|
||||||
=> cat ./spl/u-boot-spl-dtb.bin >> out
|
|
||||||
|
|
||||||
- Write tpl+spl at 64th sector
|
- Write tpl+spl at 64th sector
|
||||||
|
|
||||||
=> sudo dd if=out of=/dev/sdc seek=64
|
=> sudo dd if=idbloader.img of=/dev/sdc seek=64
|
||||||
|
|
||||||
- Write U-Boot proper at 16384 sector
|
- Write U-Boot proper at 16384 sector
|
||||||
|
|
||||||
|
@ -940,35 +940,12 @@ static int __maybe_unused rk3288_clk_set_parent(struct clk *clk, struct clk *par
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rk3288_clk_enable(struct clk *clk)
|
|
||||||
{
|
|
||||||
switch (clk->id) {
|
|
||||||
case HCLK_USBHOST0:
|
|
||||||
case HCLK_HSIC:
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
case SCLK_MAC:
|
|
||||||
case SCLK_MAC_RX:
|
|
||||||
case SCLK_MAC_TX:
|
|
||||||
case SCLK_MACREF:
|
|
||||||
case SCLK_MACREF_OUT:
|
|
||||||
case ACLK_GMAC:
|
|
||||||
case PCLK_GMAC:
|
|
||||||
/* Required to successfully probe the Designware GMAC driver */
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
debug("%s: unsupported clk %ld\n", __func__, clk->id);
|
|
||||||
return -ENOENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct clk_ops rk3288_clk_ops = {
|
static struct clk_ops rk3288_clk_ops = {
|
||||||
.get_rate = rk3288_clk_get_rate,
|
.get_rate = rk3288_clk_get_rate,
|
||||||
.set_rate = rk3288_clk_set_rate,
|
.set_rate = rk3288_clk_set_rate,
|
||||||
#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
|
#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
|
||||||
.set_parent = rk3288_clk_set_parent,
|
.set_parent = rk3288_clk_set_parent,
|
||||||
#endif
|
#endif
|
||||||
.enable = rk3288_clk_enable,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int rk3288_clk_ofdata_to_platdata(struct udevice *dev)
|
static int rk3288_clk_ofdata_to_platdata(struct udevice *dev)
|
||||||
|
@ -745,22 +745,10 @@ static int rk3328_clk_set_parent(struct clk *clk, struct clk *parent)
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rk3328_clk_enable(struct clk *clk)
|
|
||||||
{
|
|
||||||
switch (clk->id) {
|
|
||||||
case HCLK_HOST0:
|
|
||||||
/* Required to successfully probe the ehci generic driver */
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return -ENOENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct clk_ops rk3328_clk_ops = {
|
static struct clk_ops rk3328_clk_ops = {
|
||||||
.get_rate = rk3328_clk_get_rate,
|
.get_rate = rk3328_clk_get_rate,
|
||||||
.set_rate = rk3328_clk_set_rate,
|
.set_rate = rk3328_clk_set_rate,
|
||||||
.set_parent = rk3328_clk_set_parent,
|
.set_parent = rk3328_clk_set_parent,
|
||||||
.enable = rk3328_clk_enable,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int rk3328_clk_probe(struct udevice *dev)
|
static int rk3328_clk_probe(struct udevice *dev)
|
||||||
|
@ -566,31 +566,12 @@ static int __maybe_unused rk3368_clk_set_parent(struct clk *clk, struct clk *par
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rk3368_clk_enable(struct clk *clk)
|
|
||||||
{
|
|
||||||
switch (clk->id) {
|
|
||||||
case SCLK_MAC:
|
|
||||||
case SCLK_MAC_RX:
|
|
||||||
case SCLK_MAC_TX:
|
|
||||||
case SCLK_MACREF:
|
|
||||||
case SCLK_MACREF_OUT:
|
|
||||||
case ACLK_GMAC:
|
|
||||||
case PCLK_GMAC:
|
|
||||||
/* Required to successfully probe the Designware GMAC driver */
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
debug("%s: unsupported clk %ld\n", __func__, clk->id);
|
|
||||||
return -ENOENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct clk_ops rk3368_clk_ops = {
|
static struct clk_ops rk3368_clk_ops = {
|
||||||
.get_rate = rk3368_clk_get_rate,
|
.get_rate = rk3368_clk_get_rate,
|
||||||
.set_rate = rk3368_clk_set_rate,
|
.set_rate = rk3368_clk_set_rate,
|
||||||
#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
|
#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
|
||||||
.set_parent = rk3368_clk_set_parent,
|
.set_parent = rk3368_clk_set_parent,
|
||||||
#endif
|
#endif
|
||||||
.enable = rk3368_clk_enable,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int rk3368_clk_probe(struct udevice *dev)
|
static int rk3368_clk_probe(struct udevice *dev)
|
||||||
|
@ -1062,49 +1062,12 @@ static int __maybe_unused rk3399_clk_set_parent(struct clk *clk,
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rk3399_clk_enable(struct clk *clk)
|
|
||||||
{
|
|
||||||
switch (clk->id) {
|
|
||||||
case HCLK_HOST0:
|
|
||||||
case HCLK_HOST0_ARB:
|
|
||||||
case HCLK_HOST1:
|
|
||||||
case HCLK_HOST1_ARB:
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
case SCLK_MAC:
|
|
||||||
case SCLK_MAC_RX:
|
|
||||||
case SCLK_MAC_TX:
|
|
||||||
case SCLK_MACREF:
|
|
||||||
case SCLK_MACREF_OUT:
|
|
||||||
case ACLK_GMAC:
|
|
||||||
case PCLK_GMAC:
|
|
||||||
/* Required to successfully probe the Designware GMAC driver */
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
case SCLK_USB3OTG0_REF:
|
|
||||||
case SCLK_USB3OTG1_REF:
|
|
||||||
case SCLK_USB3OTG0_SUSPEND:
|
|
||||||
case SCLK_USB3OTG1_SUSPEND:
|
|
||||||
case ACLK_USB3OTG0:
|
|
||||||
case ACLK_USB3OTG1:
|
|
||||||
case ACLK_USB3_RKSOC_AXI_PERF:
|
|
||||||
case ACLK_USB3:
|
|
||||||
case ACLK_USB3_GRF:
|
|
||||||
/* Required to successfully probe the Designware USB3 driver */
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
debug("%s: unsupported clk %ld\n", __func__, clk->id);
|
|
||||||
return -ENOENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct clk_ops rk3399_clk_ops = {
|
static struct clk_ops rk3399_clk_ops = {
|
||||||
.get_rate = rk3399_clk_get_rate,
|
.get_rate = rk3399_clk_get_rate,
|
||||||
.set_rate = rk3399_clk_set_rate,
|
.set_rate = rk3399_clk_set_rate,
|
||||||
#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
|
#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
|
||||||
.set_parent = rk3399_clk_set_parent,
|
.set_parent = rk3399_clk_set_parent,
|
||||||
#endif
|
#endif
|
||||||
.enable = rk3399_clk_enable,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_SPL_BUILD
|
#ifdef CONFIG_SPL_BUILD
|
||||||
|
@ -96,7 +96,7 @@ static int ehci_usb_probe(struct udevice *dev)
|
|||||||
if (err < 0)
|
if (err < 0)
|
||||||
break;
|
break;
|
||||||
err = clk_enable(&priv->clocks[i]);
|
err = clk_enable(&priv->clocks[i]);
|
||||||
if (err) {
|
if (err && err != -ENOSYS) {
|
||||||
dev_err(dev, "failed to enable clock %d\n", i);
|
dev_err(dev, "failed to enable clock %d\n", i);
|
||||||
clk_free(&priv->clocks[i]);
|
clk_free(&priv->clocks[i]);
|
||||||
goto clk_err;
|
goto clk_err;
|
||||||
|
@ -95,7 +95,7 @@ static int ohci_usb_probe(struct udevice *dev)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
err = clk_enable(&priv->clocks[i]);
|
err = clk_enable(&priv->clocks[i]);
|
||||||
if (err) {
|
if (err && err != -ENOSYS) {
|
||||||
dev_err(dev, "failed to enable clock %d\n", i);
|
dev_err(dev, "failed to enable clock %d\n", i);
|
||||||
clk_free(&priv->clocks[i]);
|
clk_free(&priv->clocks[i]);
|
||||||
goto clk_err;
|
goto clk_err;
|
||||||
|
Loading…
Reference in New Issue
Block a user