public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229
@ 2017-12-19  8:53 Kever Yang
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL Kever Yang
                   ` (11 more replies)
  0 siblings, 12 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot


Add some generic options for TPL support for arm 32bit, and then
and TPL support for rk3229(cortex-A7), and then add OPTEE support
in SPL.

Tested on latest u-boot-rockchip master.


Changes in v3:
- do not init ddr region in spl

Changes in v2:
- update subject with ARCH_MEM info
- Add new image type like ATF
- Using new image type for op-tee
- Make the its as common file used for all armv7 with op-tee
- update defconfig option

Kever Yang (11):
  lib: add TPL_OF_LIBFDT option for TPL
  arm: add option for TPL ARCH_MEM in arm 32bit
  arm: add a separate stack for TPL
  rockchip: rk322x: enable tpl support
  sysreset: enable driver support in SPL/TPL
  image: add os type for OP-TEE
  spl: add support to booting with OP-TEE
  rockchip: rk322x: dts: enable uart2 for SPL/TPL
  rockchip: add fit source file for pack itb with op-tee
  rockchip: evb-rk3229: add README file for OP-TEE support
  rockchip: evb-rk322x: update defconfig with tpl and optee support

 arch/arm/Kconfig                             | 29 +++++++++
 arch/arm/dts/rk3229-evb.dts                  |  1 +
 arch/arm/lib/crt0.S                          |  4 +-
 arch/arm/mach-rockchip/Kconfig               |  9 +++
 arch/arm/mach-rockchip/Makefile              |  3 +-
 arch/arm/mach-rockchip/fit_spl_optee.its     | 50 ++++++++++++++++
 arch/arm/mach-rockchip/rk322x-board-spl.c    | 63 +++++--------------
 arch/arm/mach-rockchip/rk322x-board-tpl.c    | 90 ++++++++++++++++++++++++++++
 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds | 13 ++++
 board/rockchip/evb_rk3229/README             | 72 ++++++++++++++++++++++
 common/image.c                               |  1 +
 common/spl/Kconfig                           |  7 +++
 common/spl/Makefile                          |  1 +
 common/spl/spl.c                             |  8 +++
 common/spl/spl_optee.S                       | 13 ++++
 configs/evb-rk3229_defconfig                 | 26 +++++++-
 drivers/sysreset/Kconfig                     | 18 ++++++
 drivers/sysreset/Makefile                    |  2 +-
 include/configs/rk322x_common.h              |  9 ++-
 include/image.h                              |  1 +
 include/spl.h                                |  9 +++
 lib/Kconfig                                  | 10 ++++
 22 files changed, 381 insertions(+), 58 deletions(-)
 create mode 100644 arch/arm/mach-rockchip/fit_spl_optee.its
 create mode 100644 arch/arm/mach-rockchip/rk322x-board-tpl.c
 create mode 100644 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
 create mode 100644 board/rockchip/evb_rk3229/README
 create mode 100644 common/spl/spl_optee.S

-- 
1.9.1

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 02/11] arm: add option for TPL ARCH_MEM in arm 32bit Kever Yang
                   ` (10 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

TPL may need use libfdt for dt decode, add option for it.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2: None

 lib/Kconfig | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/lib/Kconfig b/lib/Kconfig
index f447c53..b43ef22 100644
--- a/lib/Kconfig
+++ b/lib/Kconfig
@@ -234,6 +234,16 @@ config SPL_OF_LIBFDT
 	  particular compatible nodes. The library operates on a flattened
 	  version of the device tree.
 
+config TPL_OF_LIBFDT
+	bool "Enable the FDT library for TPL"
+	default y if TPL_OF_CONTROL
+	help
+	  This enables the FDT library (libfdt). It provides functions for
+	  accessing binary device tree images in memory, such as adding and
+	  removing nodes and properties, scanning through the tree and finding
+	  particular compatible nodes. The library operates on a flattened
+	  version of the device tree.
+
 config FDT_FIXUP_PARTITIONS
 	bool "overwrite MTD partitions in DTS through defined in 'mtdparts'"
 	depends on OF_LIBFDT
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 02/11] arm: add option for TPL ARCH_MEM in arm 32bit
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 03/11] arm: add a separate stack for TPL Kever Yang
                   ` (9 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

Some options like TPL_SYS_THUMB_BUILD, TPL_USE_ARCH_MEMCPY
and TPL_USE_ARCH_MEMCPY are needed for TPL build in 32bit arm.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2:
- update subject with ARCH_MEM info

 arch/arm/Kconfig | 29 +++++++++++++++++++++++++++++
 1 file changed, 29 insertions(+)

diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig
index 7390995..4069227 100644
--- a/arch/arm/Kconfig
+++ b/arch/arm/Kconfig
@@ -244,6 +244,17 @@ config SPL_SYS_THUMB_BUILD
 	   density. For ARM architectures that support Thumb2 this flag will
 	   result in Thumb2 code generated by GCC.
 
+config TPL_SYS_THUMB_BUILD
+	bool "Build TPL using the Thumb instruction set"
+	default y if SYS_THUMB_BUILD
+	depends on TPL && !ARM64
+	help
+	   Use this flag to build SPL using the Thumb instruction set for
+	   ARM architectures. Thumb instruction set provides better code
+	   density. For ARM architectures that support Thumb2 this flag will
+	   result in Thumb2 code generated by GCC.
+
+
 config SYS_L2CACHE_OFF
 	bool "L2cache off"
 	help
@@ -280,6 +291,15 @@ config SPL_USE_ARCH_MEMCPY
 	  Such implementation may be faster under some conditions
 	  but may increase the binary size.
 
+config TPL_USE_ARCH_MEMCPY
+	bool "Use an assembly optimized implementation of memcpy for TPL"
+	default y if USE_ARCH_MEMCPY
+	depends on !ARM64
+	help
+	  Enable the generation of an optimized version of memcpy.
+	  Such implementation may be faster under some conditions
+	  but may increase the binary size.
+
 config USE_ARCH_MEMSET
 	bool "Use an assembly optimized implementation of memset"
 	default y
@@ -298,6 +318,15 @@ config SPL_USE_ARCH_MEMSET
 	  Such implementation may be faster under some conditions
 	  but may increase the binary size.
 
+config TPL_USE_ARCH_MEMSET
+	bool "Use an assembly optimized implementation of memset for TPL"
+	default y if USE_ARCH_MEMSET
+	depends on !ARM64
+	help
+	  Enable the generation of an optimized version of memset.
+	  Such implementation may be faster under some conditions
+	  but may increase the binary size.
+
 config ARM64_SUPPORT_AARCH32
 	bool "ARM64 system support AArch32 execution state"
 	default y if ARM64 && !TARGET_THUNDERX_88XX
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 03/11] arm: add a separate stack for TPL
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL Kever Yang
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 02/11] arm: add option for TPL ARCH_MEM in arm 32bit Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot,v3,03/11] " Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 04/11] rockchip: rk322x: enable tpl support Kever Yang
                   ` (8 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

TPL stack may different from SPL and sys stack, add support for
separate one when the board defines it.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2: None

 arch/arm/lib/crt0.S | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/arch/arm/lib/crt0.S b/arch/arm/lib/crt0.S
index fa81317..3c1c603 100644
--- a/arch/arm/lib/crt0.S
+++ b/arch/arm/lib/crt0.S
@@ -70,7 +70,9 @@ ENTRY(_main)
  * Set up initial C runtime environment and call board_init_f(0).
  */
 
-#if defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_STACK)
+#if defined(CONFIG_TPL_BUILD) && defined(CONFIG_TPL_NEEDS_SEPARATE_STACK)
+	ldr	r0, =(CONFIG_TPL_STACK)
+#elif defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_STACK)
 	ldr	r0, =(CONFIG_SPL_STACK)
 #else
 	ldr	r0, =(CONFIG_SYS_INIT_SP_ADDR)
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 04/11] rockchip: rk322x: enable tpl support
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (2 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 03/11] arm: add a separate stack for TPL Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:17   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 05/11] sysreset: enable driver support in SPL/TPL Kever Yang
                   ` (7 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

Move original spl to tpl, and add spl to load next stage firmware,
adapt all the address and option for them.

Serial-changes: 2
- update upon latest source

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3:
- do not init ddr region in spl

Changes in v2: None

 arch/arm/mach-rockchip/Kconfig               |  9 +++
 arch/arm/mach-rockchip/Makefile              |  3 +-
 arch/arm/mach-rockchip/rk322x-board-spl.c    | 63 +++++--------------
 arch/arm/mach-rockchip/rk322x-board-tpl.c    | 90 ++++++++++++++++++++++++++++
 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds | 13 ++++
 include/configs/rk322x_common.h              |  9 ++-
 6 files changed, 134 insertions(+), 53 deletions(-)
 create mode 100644 arch/arm/mach-rockchip/rk322x-board-tpl.c
 create mode 100644 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds

diff --git a/arch/arm/mach-rockchip/Kconfig b/arch/arm/mach-rockchip/Kconfig
index 967290f..dbc197c 100644
--- a/arch/arm/mach-rockchip/Kconfig
+++ b/arch/arm/mach-rockchip/Kconfig
@@ -46,9 +46,18 @@ config ROCKCHIP_RK322X
 	bool "Support Rockchip RK3228/RK3229"
 	select CPU_V7
 	select SUPPORT_SPL
+	select SUPPORT_TPL
 	select SPL
+	select TPL
+	select TPL_NEEDS_SEPARATE_TEXT_BASE if SPL
+	select TPL_NEEDS_SEPARATE_STACK if TPL
+	select SPL_DRIVERS_MISC_SUPPORT
+	imply SPL_SERIAL_SUPPORT
+	imply TPL_SERIAL_SUPPORT
 	select ROCKCHIP_BROM_HELPER
 	select DEBUG_UART_BOARD_INIT
+	select TPL_LIBCOMMON_SUPPORT
+	select TPL_LIBGENERIC_SUPPORT
 	help
 	  The Rockchip RK3229 is a ARM-based SoC with a dual-core Cortex-A7
 	  including NEON and GPU, Mali-400 graphics, several DDR3 options
diff --git a/arch/arm/mach-rockchip/Makefile b/arch/arm/mach-rockchip/Makefile
index e1b0519..3c14236 100644
--- a/arch/arm/mach-rockchip/Makefile
+++ b/arch/arm/mach-rockchip/Makefile
@@ -13,10 +13,11 @@ obj-tpl-$(CONFIG_ROCKCHIP_BROM_HELPER) += bootrom.o
 
 obj-tpl-$(CONFIG_ROCKCHIP_RK3288) += rk3288-board-tpl.o
 obj-tpl-$(CONFIG_ROCKCHIP_RK3368) += rk3368-board-tpl.o
+obj-tpl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-tpl.o
 
 obj-spl-$(CONFIG_ROCKCHIP_RK3036) += rk3036-board-spl.o
 obj-spl-$(CONFIG_ROCKCHIP_RK3188) += rk3188-board-spl.o
-obj-spl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-spl.o
+obj-spl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-spl.o spl-boot-order.o
 obj-spl-$(CONFIG_ROCKCHIP_RK3288) += rk3288-board-spl.o
 obj-spl-$(CONFIG_ROCKCHIP_RK3368) += rk3368-board-spl.o spl-boot-order.o
 obj-spl-$(CONFIG_ROCKCHIP_RK3399) += rk3399-board-spl.o spl-boot-order.o
diff --git a/arch/arm/mach-rockchip/rk322x-board-spl.c b/arch/arm/mach-rockchip/rk322x-board-spl.c
index 35f4f97..89af1d9 100644
--- a/arch/arm/mach-rockchip/rk322x-board-spl.c
+++ b/arch/arm/mach-rockchip/rk322x-board-spl.c
@@ -5,77 +5,46 @@
  */
 
 #include <common.h>
-#include <debug_uart.h>
 #include <dm.h>
-#include <ram.h>
 #include <spl.h>
-#include <asm/io.h>
-#include <asm/arch/bootrom.h>
-#include <asm/arch/cru_rk322x.h>
-#include <asm/arch/grf_rk322x.h>
-#include <asm/arch/hardware.h>
-#include <asm/arch/timer.h>
-#include <asm/arch/uart.h>
+
+DECLARE_GLOBAL_DATA_PTR;
 
 u32 spl_boot_device(void)
 {
 	return BOOT_DEVICE_MMC1;
 }
-DECLARE_GLOBAL_DATA_PTR;
 
-#define GRF_BASE	0x11000000
-#define SGRF_BASE	0x10140000
-
-#define DEBUG_UART_BASE	0x11030000
+u32 spl_boot_mode(const u32 boot_device)
+{
+	return MMCSD_MODE_RAW;
+}
 
 void board_debug_uart_init(void)
 {
-static struct rk322x_grf * const grf = (void *)GRF_BASE;
-	/* Enable early UART2 channel 1 on the RK322x */
-	rk_clrsetreg(&grf->gpio1b_iomux,
-		     GPIO1B1_MASK | GPIO1B2_MASK,
-		     GPIO1B2_UART21_SIN << GPIO1B2_SHIFT |
-		     GPIO1B1_UART21_SOUT << GPIO1B1_SHIFT);
-	/* Set channel C as UART2 input */
-	rk_clrsetreg(&grf->con_iomux,
-		     CON_IOMUX_UART2SEL_MASK,
-		     CON_IOMUX_UART2SEL_21 << CON_IOMUX_UART2SEL_SHIFT);
 }
 
-#define SGRF_DDR_CON0 0x10150000
 void board_init_f(ulong dummy)
 {
-	struct udevice *dev;
 	int ret;
 
-	/*
-	 * Debug UART can be used from here if required:
-	 *
-	 * debug_uart_init();
-	 * printch('a');
-	 * printhex8(0x1234);
-	 * printascii("string");
-	 */
-	debug_uart_init();
-	printascii("SPL Init");
-
 	ret = spl_early_init();
 	if (ret) {
-		debug("spl_early_init() failed: %d\n", ret);
+		printf("spl_early_init() failed: %d\n", ret);
 		hang();
 	}
+	preloader_console_init();
+}
 
-	rockchip_timer_init();
-	printf("timer init done\n");
-	ret = uclass_get_device(UCLASS_RAM, 0, &dev);
-	if (ret) {
-		printf("DRAM init failed: %d\n", ret);
-		return;
-	}
+#ifdef CONFIG_SPL_LOAD_FIT
+int board_fit_config_name_match(const char *name)
+{
+	/* Just empty function now - can't decide what to choose */
+	debug("%s: %s\n", __func__, name);
 
-	/* Disable the ddr secure region setting to make it non-secure */
-	rk_clrreg(SGRF_DDR_CON0, 0x4000);
 #if defined(CONFIG_ROCKCHIP_SPL_BACK_TO_BROM) && !defined(CONFIG_SPL_BOARD_INIT)
 	back_to_bootrom(BROM_BOOT_NEXTSTAGE);
 #endif
+	return 0;
 }
+#endif
diff --git a/arch/arm/mach-rockchip/rk322x-board-tpl.c b/arch/arm/mach-rockchip/rk322x-board-tpl.c
new file mode 100644
index 0000000..aa14cef
--- /dev/null
+++ b/arch/arm/mach-rockchip/rk322x-board-tpl.c
@@ -0,0 +1,90 @@
+/*
+ * (C) Copyright 2017 Rockchip Electronics Co., Ltd
+ *
+ * SPDX-License-Identifier:     GPL-2.0+
+ */
+
+#include <common.h>
+#include <debug_uart.h>
+#include <dm.h>
+#include <ram.h>
+#include <spl.h>
+#include <asm/io.h>
+#include <asm/arch/bootrom.h>
+#include <asm/arch/cru_rk322x.h>
+#include <asm/arch/grf_rk322x.h>
+#include <asm/arch/hardware.h>
+#include <asm/arch/timer.h>
+#include <asm/arch/uart.h>
+
+u32 spl_boot_device(void)
+{
+	return BOOT_DEVICE_MMC1;
+}
+DECLARE_GLOBAL_DATA_PTR;
+
+#define GRF_BASE	0x11000000
+#define SGRF_BASE	0x10140000
+#define DEBUG_UART_BASE	0x11030000
+#define SECURE_TIMER_BASE	0x110d0020
+#define SGRF_DDR_CON0 0x10150000
+
+void board_debug_uart_init(void)
+{
+	static struct rk322x_grf * const grf = (void *)GRF_BASE;
+	/* Enable early UART2 channel 1 on the RK322x */
+	rk_clrsetreg(&grf->gpio1b_iomux,
+		     GPIO1B1_MASK | GPIO1B2_MASK,
+		     GPIO1B2_UART21_SIN << GPIO1B2_SHIFT |
+		     GPIO1B1_UART21_SOUT << GPIO1B1_SHIFT);
+	/* Set channel C as UART2 input */
+	rk_clrsetreg(&grf->con_iomux,
+		     CON_IOMUX_UART2SEL_MASK,
+		     CON_IOMUX_UART2SEL_21 << CON_IOMUX_UART2SEL_SHIFT);
+}
+
+void secure_timer_init(void)
+{
+	writel(0, SECURE_TIMER_BASE + 0x10);
+	writel(0xffffffff, SECURE_TIMER_BASE);
+	writel(0xffffffff, SECURE_TIMER_BASE + 4);
+	writel(1, SECURE_TIMER_BASE + 0x10);
+}
+
+void board_init_f(ulong dummy)
+{
+	struct udevice *dev;
+	int ret;
+
+	/*
+	 * Debug UART can be used from here if required:
+	 *
+	 * debug_uart_init();
+	 * printch('a');
+	 * printhex8(0x1234);
+	 * printascii("string");
+	 */
+	debug_uart_init();
+	printascii("TPL Init");
+
+	ret = spl_early_init();
+	if (ret) {
+		debug("spl_early_init() failed: %d\n", ret);
+		hang();
+	}
+
+	secure_timer_init();
+	rockchip_timer_init();
+	printf("timer init done\n");
+	ret = uclass_get_device(UCLASS_RAM, 0, &dev);
+	if (ret) {
+		printf("DRAM init failed: %d\n", ret);
+		return;
+	}
+
+	/* Disable the ddr secure region setting to make it non-secure */
+	rk_clrreg(SGRF_DDR_CON0, 0x4000);
+#if defined(CONFIG_TPL_ROCKCHIP_BACK_TO_BROM) && !defined(CONFIG_TPL_BOARD_INIT)
+	back_to_bootrom(BROM_BOOT_NEXTSTAGE);
+#endif
+}
diff --git a/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds b/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
new file mode 100644
index 0000000..841c803
--- /dev/null
+++ b/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
@@ -0,0 +1,13 @@
+/*
+ * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
+ *
+ * SPDX-License-Identifier:	GPL-2.0+
+ */
+
+#undef CONFIG_SPL_TEXT_BASE
+#define CONFIG_SPL_TEXT_BASE CONFIG_TPL_TEXT_BASE
+
+#undef CONFIG_SPL_MAX_SIZE
+#define CONFIG_SPL_MAX_SIZE CONFIG_TPL_MAX_SIZE
+
+#include "../../cpu/u-boot-spl.lds"
diff --git a/include/configs/rk322x_common.h b/include/configs/rk322x_common.h
index b22169d..5536b58 100644
--- a/include/configs/rk322x_common.h
+++ b/include/configs/rk322x_common.h
@@ -20,11 +20,10 @@
 
 #define CONFIG_SPL_FRAMEWORK
 #define CONFIG_SYS_NS16550_MEM32
-#define CONFIG_SYS_TEXT_BASE		0x60000000
-#define CONFIG_SYS_INIT_SP_ADDR		0x60100000
-#define CONFIG_SYS_LOAD_ADDR		0x60800800
-#define CONFIG_SPL_STACK		0x10088000
-#define CONFIG_SPL_TEXT_BASE		0x10081004
+#define CONFIG_SYS_TEXT_BASE		0x61000000
+#define CONFIG_SYS_INIT_SP_ADDR		0x61100000
+#define CONFIG_SYS_LOAD_ADDR		0x61800800
+#define CONFIG_SPL_TEXT_BASE		0x60000000
 
 #define CONFIG_ROCKCHIP_MAX_INIT_SIZE	(28 << 10)
 #define CONFIG_ROCKCHIP_CHIP_TAG	"RK32"
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 05/11] sysreset: enable driver support in SPL/TPL
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (3 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 04/11] rockchip: rk322x: enable tpl support Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 06/11] image: add os type for OP-TEE Kever Yang
                   ` (6 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

SPL/TPL also need use sysreset for some feature like panic callback.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2: None

 drivers/sysreset/Kconfig  | 18 ++++++++++++++++++
 drivers/sysreset/Makefile |  2 +-
 2 files changed, 19 insertions(+), 1 deletion(-)

diff --git a/drivers/sysreset/Kconfig b/drivers/sysreset/Kconfig
index a6d48e8..a61a7d3 100644
--- a/drivers/sysreset/Kconfig
+++ b/drivers/sysreset/Kconfig
@@ -13,6 +13,24 @@ config SYSRESET
 	  to effect a reset. The uclass will try all available drivers when
 	  reset_walk() is called.
 
+config SPL_SYSRESET
+	bool "Enable support for system reset drivers in SPL mode"
+	depends on SYSRESET && SPL_DM
+	help
+	  Enable system reset drivers which can be used to reset the CPU or
+	  board. Each driver can provide a reset method which will be called
+	  to effect a reset. The uclass will try all available drivers when
+	  reset_walk() is called.
+
+config TPL_SYSRESET
+	bool "Enable support for system reset drivers in TPL mode"
+	depends on SYSRESET && TPL_DM
+	help
+	  Enable system reset drivers which can be used to reset the CPU or
+	  board. Each driver can provide a reset method which will be called
+	  to effect a reset. The uclass will try all available drivers when
+	  reset_walk() is called.
+
 if SYSRESET
 
 config SYSRESET_PSCI
diff --git a/drivers/sysreset/Makefile b/drivers/sysreset/Makefile
index 2e9598e..00be747 100644
--- a/drivers/sysreset/Makefile
+++ b/drivers/sysreset/Makefile
@@ -4,7 +4,7 @@
 # SPDX-License-Identifier:	GPL-2.0+
 #
 
-obj-$(CONFIG_SYSRESET) += sysreset-uclass.o
+obj-$(CONFIG_$(SPL_TPL_)SYSRESET) += sysreset-uclass.o
 obj-$(CONFIG_SYSRESET_PSCI) += sysreset_psci.o
 obj-$(CONFIG_SYSRESET_SYSCON) += sysreset_syscon.o
 obj-$(CONFIG_SYSRESET_WATCHDOG) += sysreset_watchdog.o
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 06/11] image: add os type for OP-TEE
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (4 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 05/11] sysreset: enable driver support in SPL/TPL Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot,v3,06/11] " Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 07/11] spl: add support to booting with OP-TEE Kever Yang
                   ` (5 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

OP-TEE is an open source trust OS maintained here:
https://github.com/OP-TEE/optee_os

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2:
- Add new image type like ATF

 common/image.c  | 1 +
 include/image.h | 1 +
 2 files changed, 2 insertions(+)

diff --git a/common/image.c b/common/image.c
index 4bcf6b3..597c025 100644
--- a/common/image.c
+++ b/common/image.c
@@ -91,6 +91,7 @@ static const table_entry_t uimage_arch[] = {
 
 static const table_entry_t uimage_os[] = {
 	{	IH_OS_INVALID,	"invalid",	"Invalid OS",		},
+	{       IH_OS_OP_TEE, "op-tee", "OP-TEE"  },
 	{       IH_OS_ARM_TRUSTED_FIRMWARE, "arm-trusted-firmware", "ARM Trusted Firmware"  },
 	{	IH_OS_LINUX,	"linux",	"Linux",		},
 #if defined(CONFIG_LYNXKDI) || defined(USE_HOSTCC)
diff --git a/include/image.h b/include/image.h
index a128a62..141ed00 100644
--- a/include/image.h
+++ b/include/image.h
@@ -153,6 +153,7 @@ enum {
 	IH_OS_PLAN9,			/* Plan 9	*/
 	IH_OS_OPENRTOS,		/* OpenRTOS	*/
 	IH_OS_ARM_TRUSTED_FIRMWARE,     /* ARM Trusted Firmware */
+	IH_OS_OP_TEE,			/* OP-TEE	*/
 
 	IH_OS_COUNT,
 };
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 07/11] spl: add support to booting with OP-TEE
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (5 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 06/11] image: add os type for OP-TEE Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:20   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL Kever Yang
                   ` (4 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

OP-TEE is an open source trusted OS, in armv7, its loading and
running are like this:
loading:
- SPL load both OP-TEE and U-Boot
running:
- SPL run into OP-TEE in secure mode;
- OP-TEE run into U-Boot in non-secure mode;

More detail:
https://github.com/OP-TEE/optee_os
and search for 'boot arguments' for detail entry parameter in:
core/arch/arm/kernel/generic_entry_a32.S

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2:
- Using new image type for op-tee

 common/spl/Kconfig     |  7 +++++++
 common/spl/Makefile    |  1 +
 common/spl/spl.c       |  8 ++++++++
 common/spl/spl_optee.S | 13 +++++++++++++
 include/spl.h          |  9 +++++++++
 5 files changed, 38 insertions(+)
 create mode 100644 common/spl/spl_optee.S

diff --git a/common/spl/Kconfig b/common/spl/Kconfig
index aef0034..c9a1ebb 100644
--- a/common/spl/Kconfig
+++ b/common/spl/Kconfig
@@ -725,6 +725,13 @@ config SPL_ATF
 	  is loaded by SPL(which is considered as BL2 in ATF terminology).
 	  More detail at: https://github.com/ARM-software/arm-trusted-firmware
 
+config SPL_OPTEE
+	bool "Support OP-TEE Trusted OS"
+	depends on ARM
+	help
+	  OP-TEE is an open source Trusted OS  which is loaded by SPL.
+	  More detail at: https://github.com/OP-TEE/optee_os
+
 config TPL
 	bool
 	depends on SUPPORT_TPL
diff --git a/common/spl/Makefile b/common/spl/Makefile
index 9bf8a2d..9918a2e 100644
--- a/common/spl/Makefile
+++ b/common/spl/Makefile
@@ -23,6 +23,7 @@ obj-$(CONFIG_$(SPL_TPL_)UBI) += spl_ubi.o
 obj-$(CONFIG_$(SPL_TPL_)NET_SUPPORT) += spl_net.o
 obj-$(CONFIG_$(SPL_TPL_)MMC_SUPPORT) += spl_mmc.o
 obj-$(CONFIG_$(SPL_TPL_)ATF) += spl_atf.o
+obj-$(CONFIG_$(SPL_TPL_)OPTEE) += spl_optee.o
 obj-$(CONFIG_$(SPL_TPL_)USB_SUPPORT) += spl_usb.o
 obj-$(CONFIG_$(SPL_TPL_)FAT_SUPPORT) += spl_fat.o
 obj-$(CONFIG_$(SPL_TPL_)EXT_SUPPORT) += spl_ext.o
diff --git a/common/spl/spl.c b/common/spl/spl.c
index 76c1963..2c8942b 100644
--- a/common/spl/spl.c
+++ b/common/spl/spl.c
@@ -436,6 +436,12 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
 		spl_invoke_atf(&spl_image);
 		break;
 #endif
+#if CONFIG_IS_ENABLED(OPTEE)
+	case IH_OS_OP_TEE:
+		debug("Jumping to U-Boot via OP-TEE\n");
+		spl_optee_entry(0, 0, 0, (void *)spl_image.entry_point);
+		break;
+#endif
 #ifdef CONFIG_SPL_OS_BOOT
 	case IH_OS_LINUX:
 		debug("Jumping to Linux\n");
@@ -450,6 +456,8 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
 	debug("SPL malloc() used %#lx bytes (%ld KB)\n", gd->malloc_ptr,
 	      gd->malloc_ptr / 1024);
 #endif
+
+	debug("loaded - jumping to U-Boot...\n");
 #ifdef CONFIG_BOOTSTAGE_STASH
 	int ret;
 
diff --git a/common/spl/spl_optee.S b/common/spl/spl_optee.S
new file mode 100644
index 0000000..4f7f8ba
--- /dev/null
+++ b/common/spl/spl_optee.S
@@ -0,0 +1,13 @@
+/*
+ * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
+ *
+ * SPDX-License-Identifier:	GPL-2.0+
+ */
+
+#include <linux/linkage.h>
+#include <asm/assembler.h>
+
+ENTRY(spl_optee_entry)
+	ldr lr, =CONFIG_SYS_TEXT_BASE
+	mov pc, r3
+ENDPROC(spl_optee_entry)
diff --git a/include/spl.h b/include/spl.h
index c14448b..551ce43 100644
--- a/include/spl.h
+++ b/include/spl.h
@@ -288,6 +288,15 @@ int spl_mmc_load_image(struct spl_image_info *spl_image,
 void spl_invoke_atf(struct spl_image_info *spl_image);
 
 /**
+ * spl_optee_entry - entry function for optee
+ * entry arg0, pagestore
+ * entry arg1, (ARMv7 standard bootarg #1)
+ * entry arg2, device tree address, (ARMv7 standard bootarg #2)
+ * entry arg3, non-secure entry address (ARMv7 bootarg #0)
+ */
+void spl_optee_entry(void *arg0, void *arg1, void *arg2, void *arg3);
+
+/**
  * board_return_to_bootrom - allow for boards to continue with the boot ROM
  *
  * If a board (e.g. the Rockchip RK3368 boards) provide some
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (6 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 07/11] spl: add support to booting with OP-TEE Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 09/11] rockchip: add fit source file for pack itb with op-tee Kever Yang
                   ` (3 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

When we use DM_SERIAL for serial driver, we need enable the
dts node for the debug console.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2: None

 arch/arm/dts/rk3229-evb.dts | 1 +
 1 file changed, 1 insertion(+)

diff --git a/arch/arm/dts/rk3229-evb.dts b/arch/arm/dts/rk3229-evb.dts
index ae0b0a4..fe4abe9 100644
--- a/arch/arm/dts/rk3229-evb.dts
+++ b/arch/arm/dts/rk3229-evb.dts
@@ -83,6 +83,7 @@
 };
 
 &uart2 {
+	u-boot,dm-pre-reloc;
 	status = "okay";
 };
 
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 09/11] rockchip: add fit source file for pack itb with op-tee
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (7 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 10/11] rockchip: evb-rk3229: add README file for OP-TEE support Kever Yang
                   ` (2 subsequent siblings)
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

We package U-Boot and OP-TEE into one itb file for SPL,
so that we can support OP-TEE in SPL.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2:
- Make the its as common file used for all armv7 with op-tee

 arch/arm/mach-rockchip/fit_spl_optee.its | 50 ++++++++++++++++++++++++++++++++
 1 file changed, 50 insertions(+)
 create mode 100644 arch/arm/mach-rockchip/fit_spl_optee.its

diff --git a/arch/arm/mach-rockchip/fit_spl_optee.its b/arch/arm/mach-rockchip/fit_spl_optee.its
new file mode 100644
index 0000000..3aeecb8
--- /dev/null
+++ b/arch/arm/mach-rockchip/fit_spl_optee.its
@@ -0,0 +1,50 @@
+/*
+ * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
+ *
+ * Simple U-boot fit source file containing U-Boot, dtb and optee
+ */
+
+/dts-v1/;
+
+/ {
+	description = "Simple image with OP-TEE support";
+	#address-cells = <1>;
+
+	images {
+		uboot at 1 {
+			description = "U-Boot";
+			data = /incbin/("../../../u-boot-nodtb.bin");
+			type = "standalone";
+			os = "U-Boot";
+			arch = "arm";
+			compression = "none";
+			load = <0x61000000>;
+		};
+		optee at 1 {
+			description = "OP-TEE";
+			data = /incbin/("../../../tee.bin");
+			type = "firmware";
+			arch = "arm";
+			os = "op-tee";
+			compression = "none";
+			load = <0x68400000>;
+			entry = <0x68400000>;
+		};
+		fdt at 1 {
+			description = "dtb";
+			data = /incbin/("../../../u-boot.dtb");
+			type = "flat_dt";
+			compression = "none";
+		};
+	};
+
+	configurations {
+		default = "conf at 1";
+		conf at 1 {
+			description = "Rockchip armv7 with OP-TEE";
+			firmware = "optee at 1";
+			loadables = "uboot at 1";
+			fdt = "fdt at 1";
+		};
+	};
+};
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 10/11] rockchip: evb-rk3229: add README file for OP-TEE support
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (8 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 09/11] rockchip: add fit source file for pack itb with op-tee Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support Kever Yang
  2017-12-25 20:23 ` [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Heiko Stuebner
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

Detail of step by step to bring up the board with OP-TEE support.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2: None

 board/rockchip/evb_rk3229/README | 72 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 72 insertions(+)
 create mode 100644 board/rockchip/evb_rk3229/README

diff --git a/board/rockchip/evb_rk3229/README b/board/rockchip/evb_rk3229/README
new file mode 100644
index 0000000..46c54c2
--- /dev/null
+++ b/board/rockchip/evb_rk3229/README
@@ -0,0 +1,72 @@
+Get the Source and prebuild binary
+==================================
+
+  > mkdir ~/evb_rk3229
+  > cd ~/evb_rk3229
+  > git clone git://git.denx.de/u-boot.git
+  > git clone https://github.com/OP-TEE/optee_os.git
+  > git clone https://github.com/rockchip-linux/rkbin.git
+  > git clone https://github.com/rockchip-linux/rkdeveloptool.git
+
+Compile the OP-TEE
+===============
+
+  > cd optee_os
+  > make clean
+  > make CROSS_COMPILE_ta_arm32=arm-none-eabi- PLATFORM=rockchip-rk322x
+  Get tee.bin in this step, copy it to U-Boot root dir:
+  > cp out/arm-plat-rockchip/core/tee-pager.bin ../u-boot/tee.bin
+
+Compile the U-Boot
+==================
+
+  > cd ../u-boot
+  > export CROSS_COMPILE=arm-linux-gnueabihf-
+  > export ARCH=arm
+  > make evb-rk3229_defconfig
+  > make
+  > make u-boot.itb
+
+  Get tpl/u-boot-tpl.bin, spl/u-boot-spl.bin and u-boot.itb in this step.
+
+Compile the rkdeveloptool
+=======================
+  Follow instructions in latest README
+  > cd ../rkdeveloptool
+  > autoreconf -i
+  > ./configure
+  > make
+  > sudo make install
+
+  Get rkdeveloptool in you Host in this step.
+
+Both origin binaries and Tool are ready now, choose either option 1 or
+option 2 to deploy U-Boot.
+
+Package the image
+=================
+
+  > cd ../u-boot
+  > tools/mkimage -n rk322x -T rksd -d tpl/u-boot-spl.bin idbloader.img
+  > cat spl/u-boot-spl.bin >> idbloader.img
+
+  Get idbloader.img in this step.
+
+Flash the image to eMMC
+=======================
+Power on(or reset with RESET KEY) with MASKROM KEY preesed, and then:
+  > cd ..
+  > rkdeveloptool db rkbin/rk32/rk322x_loader_v1.04.232.bin
+  > rkdeveloptool wl 64 u-boot/idbloader.img
+  > rkdeveloptool wl 0x4000 u-boot/u-boot.itb
+  > rkdeveloptool rd
+
+Flash the image to SD card
+==========================
+  > dd if=u-boot/idbloader.img of=/dev/sdb seek=64
+  > dd if=u-boot/u-boot.itb of=/dev/sdb seek=16384
+
+You should be able to get U-Boot log message with OP-TEE boot info.
+
+For more detail, please reference to:
+http://opensource.rock-chips.com/wiki_Boot_option
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (9 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 10/11] rockchip: evb-rk3229: add README file for OP-TEE support Kever Yang
@ 2017-12-19  8:53 ` Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  2017-12-25 20:23 ` [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Heiko Stuebner
  11 siblings, 2 replies; 38+ messages in thread
From: Kever Yang @ 2017-12-19  8:53 UTC (permalink / raw)
  To: u-boot

Enable all the options for TPL/SPL and OPTEE.

Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
---

Changes in v3: None
Changes in v2:
- update defconfig option

 configs/evb-rk3229_defconfig | 26 +++++++++++++++++++++++---
 1 file changed, 23 insertions(+), 3 deletions(-)

diff --git a/configs/evb-rk3229_defconfig b/configs/evb-rk3229_defconfig
index b226f66..025822d 100644
--- a/configs/evb-rk3229_defconfig
+++ b/configs/evb-rk3229_defconfig
@@ -4,14 +4,27 @@ CONFIG_SPL_LIBCOMMON_SUPPORT=y
 CONFIG_SPL_LIBGENERIC_SUPPORT=y
 CONFIG_SYS_MALLOC_F_LEN=0x800
 CONFIG_ROCKCHIP_RK322X=y
-CONFIG_SPL_ROCKCHIP_BACK_TO_BROM=y
+CONFIG_TPL_LDSCRIPT="arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds"
+CONFIG_TPL_TEXT_BASE=0x10081000
+CONFIG_TPL_MAX_SIZE=28672
+CONFIG_TPL_STACK=0x10088000
+CONFIG_TPL_ROCKCHIP_BACK_TO_BROM=y
+CONFIG_ROCKCHIP_SPL_RESERVE_IRAM=0x0
 CONFIG_TARGET_EVB_RK3229=y
-CONFIG_SPL_STACK_R_ADDR=0x80000
+CONFIG_SPL_STACK_R_ADDR=0x60600000
 CONFIG_DEFAULT_DEVICE_TREE="rk3229-evb"
 CONFIG_DEBUG_UART=y
+CONFIG_FIT=y
+CONFIG_FIT_VERBOSE=y
+CONFIG_SPL_LOAD_FIT=y
+CONFIG_SPL_FIT_SOURCE="arch/arm/mach-rockchip/fit_spl_optee.its"
 # CONFIG_DISPLAY_CPUINFO is not set
+# CONFIG_SPL_RAW_IMAGE_SUPPORT is not set
+# CONFIG_SPL_LEGACY_IMAGE_SUPPORT is not set
 CONFIG_SPL_STACK_R=y
-CONFIG_SPL_STACK_R_MALLOC_SIMPLE_LEN=0x200
+CONFIG_SPL_STACK_R_MALLOC_SIMPLE_LEN=0x2000
+CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR=0x4000
+CONFIG_SPL_OPTEE=y
 CONFIG_FASTBOOT_FLASH=y
 CONFIG_FASTBOOT_FLASH_MMC_DEV=0
 CONFIG_CMD_GPT=y
@@ -19,14 +32,19 @@ CONFIG_CMD_MMC=y
 # CONFIG_CMD_SETEXPR is not set
 CONFIG_CMD_TIME=y
 CONFIG_SPL_OF_CONTROL=y
+CONFIG_TPL_OF_CONTROL=y
 CONFIG_OF_SPL_REMOVE_PROPS="pinctrl-0 pinctrl-names clock-names interrupt-parent assigned-clocks assigned-clock-rates assigned-clock-parents"
 CONFIG_ENV_IS_IN_MMC=y
+CONFIG_TPL_DM=y
 CONFIG_REGMAP=y
 CONFIG_SPL_REGMAP=y
+CONFIG_TPL_REGMAP=y
 CONFIG_SYSCON=y
 CONFIG_SPL_SYSCON=y
+CONFIG_TPL_SYSCON=y
 CONFIG_CLK=y
 CONFIG_SPL_CLK=y
+CONFIG_TPL_CLK=y
 CONFIG_ROCKCHIP_GPIO=y
 CONFIG_SYS_I2C_ROCKCHIP=y
 CONFIG_MMC_DW=y
@@ -35,12 +53,14 @@ CONFIG_PINCTRL=y
 CONFIG_PINCTRL_ROCKCHIP_RK322X=y
 CONFIG_RAM=y
 CONFIG_SPL_RAM=y
+CONFIG_TPL_RAM=y
 CONFIG_BAUDRATE=1500000
 CONFIG_DEBUG_UART_BASE=0x11030000
 CONFIG_DEBUG_UART_CLOCK=24000000
 CONFIG_DEBUG_UART_SHIFT=2
 CONFIG_SYS_NS16550=y
 CONFIG_SYSRESET=y
+CONFIG_SPL_SYSRESET=y
 CONFIG_USB=y
 CONFIG_USB_GADGET=y
 CONFIG_USB_GADGET_MANUFACTURER="Rockchip"
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 38+ messages in thread

* [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229
  2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
                   ` (10 preceding siblings ...)
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support Kever Yang
@ 2017-12-25 20:23 ` Heiko Stuebner
  11 siblings, 0 replies; 38+ messages in thread
From: Heiko Stuebner @ 2017-12-25 20:23 UTC (permalink / raw)
  To: u-boot

Hi Kever,

Am Dienstag, 19. Dezember 2017, 16:53:13 CET schrieb Kever Yang:
> 
> Add some generic options for TPL support for arm 32bit, and then
> and TPL support for rk3229(cortex-A7), and then add OPTEE support
> in SPL.
> 
> Tested on latest u-boot-rockchip master.

With the now added timer initialization, this works actually pretty well :-).

On my rk3229 tv-box board (some nexbox thing or so), I now get u-boot
loading mainline op-tee and when starting a kernel both core bringuo via
psci and arch-timer working nicely.

So this series
Tested-by: Heiko Stuebner <heiko@sntech.de>


Thanks
Heiko

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 01/11] lib: add TPL_OF_LIBFDT option for TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> TPL may need use libfdt for dt decode, add option for it.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  lib/Kconfig | 10 ++++++++++
>  1 file changed, 10 insertions(+)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 02/11] arm: add option for TPL ARCH_MEM in arm 32bit
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 02/11] arm: add option for TPL ARCH_MEM in arm 32bit Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> Some options like TPL_SYS_THUMB_BUILD, TPL_USE_ARCH_MEMCPY
> and TPL_USE_ARCH_MEMCPY are needed for TPL build in 32bit arm.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - update subject with ARCH_MEM info
> 
>  arch/arm/Kconfig | 29 +++++++++++++++++++++++++++++
>  1 file changed, 29 insertions(+)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 05/11] sysreset: enable driver support in SPL/TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 05/11] sysreset: enable driver support in SPL/TPL Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> SPL/TPL also need use sysreset for some feature like panic callback.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  drivers/sysreset/Kconfig  | 18 ++++++++++++++++++
>  drivers/sysreset/Makefile |  2 +-
>  2 files changed, 19 insertions(+), 1 deletion(-)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 04/11] rockchip: rk322x: enable tpl support
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 04/11] rockchip: rk322x: enable tpl support Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:17   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> Move original spl to tpl, and add spl to load next stage firmware,
> adapt all the address and option for them.
> 
> Serial-changes: 2
> - update upon latest source
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3:
> - do not init ddr region in spl
> 
> Changes in v2: None
> 
>  arch/arm/mach-rockchip/Kconfig               |  9 +++
>  arch/arm/mach-rockchip/Makefile              |  3 +-
>  arch/arm/mach-rockchip/rk322x-board-spl.c    | 63 +++++--------------
>  arch/arm/mach-rockchip/rk322x-board-tpl.c    | 90 ++++++++++++++++++++++++++++
>  arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds | 13 ++++
>  include/configs/rk322x_common.h              |  9 ++-
>  6 files changed, 134 insertions(+), 53 deletions(-)
>  create mode 100644 arch/arm/mach-rockchip/rk322x-board-tpl.c
>  create mode 100644 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot,v3,03/11] arm: add a separate stack for TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 03/11] arm: add a separate stack for TPL Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> TPL stack may different from SPL and sys stack, add support for
> separate one when the board defines it.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  arch/arm/lib/crt0.S | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot,v3,06/11] image: add os type for OP-TEE
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 06/11] image: add os type for OP-TEE Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> OP-TEE is an open source trust OS maintained here:
> https://github.com/OP-TEE/optee_os
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - Add new image type like ATF
> 
>  common/image.c  | 1 +
>  include/image.h | 1 +
>  2 files changed, 2 insertions(+)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 09/11] rockchip: add fit source file for pack itb with op-tee
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 09/11] rockchip: add fit source file for pack itb with op-tee Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> We package U-Boot and OP-TEE into one itb file for SPL,
> so that we can support OP-TEE in SPL.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - Make the its as common file used for all armv7 with op-tee
> 
>  arch/arm/mach-rockchip/fit_spl_optee.its | 50 ++++++++++++++++++++++++++++++++
>  1 file changed, 50 insertions(+)
>  create mode 100644 arch/arm/mach-rockchip/fit_spl_optee.its
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 07/11] spl: add support to booting with OP-TEE
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 07/11] spl: add support to booting with OP-TEE Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:20   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> OP-TEE is an open source trusted OS, in armv7, its loading and
> running are like this:
> loading:
> - SPL load both OP-TEE and U-Boot
> running:
> - SPL run into OP-TEE in secure mode;
> - OP-TEE run into U-Boot in non-secure mode;
> 
> More detail:
> https://github.com/OP-TEE/optee_os
> and search for 'boot arguments' for detail entry parameter in:
> core/arch/arm/kernel/generic_entry_a32.S
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - Using new image type for op-tee
> 
>  common/spl/Kconfig     |  7 +++++++
>  common/spl/Makefile    |  1 +
>  common/spl/spl.c       |  8 ++++++++
>  common/spl/spl_optee.S | 13 +++++++++++++
>  include/spl.h          |  9 +++++++++
>  5 files changed, 38 insertions(+)
>  create mode 100644 common/spl/spl_optee.S
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> When we use DM_SERIAL for serial driver, we need enable the
> dts node for the debug console.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  arch/arm/dts/rk3229-evb.dts | 1 +
>  1 file changed, 1 insertion(+)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 10/11] rockchip: evb-rk3229: add README file for OP-TEE support
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 10/11] rockchip: evb-rk3229: add README file for OP-TEE support Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> Detail of step by step to bring up the board with OP-TEE support.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  board/rockchip/evb_rk3229/README | 72 ++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 72 insertions(+)
>  create mode 100644 board/rockchip/evb_rk3229/README
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support Kever Yang
@ 2018-01-02 17:09   ` Philipp Tomsich
  2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:09 UTC (permalink / raw)
  To: u-boot

> Enable all the options for TPL/SPL and OPTEE.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - update defconfig option
> 
>  configs/evb-rk3229_defconfig | 26 +++++++++++++++++++++++---
>  1 file changed, 23 insertions(+), 3 deletions(-)
> 

Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 04/11] rockchip: rk322x: enable tpl support
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 04/11] rockchip: rk322x: enable tpl support Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:17   ` Philipp Tomsich
  2018-01-04  2:52     ` Kever Yang
  1 sibling, 1 reply; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:17 UTC (permalink / raw)
  To: u-boot



On Tue, 19 Dec 2017, Kever Yang wrote:

> Move original spl to tpl, and add spl to load next stage firmware,
> adapt all the address and option for them.
>
> Serial-changes: 2
> - update upon latest source
>
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

See below for requested changes.

> ---
>
> Changes in v3:
> - do not init ddr region in spl
>
> Changes in v2: None
>
> arch/arm/mach-rockchip/Kconfig               |  9 +++
> arch/arm/mach-rockchip/Makefile              |  3 +-
> arch/arm/mach-rockchip/rk322x-board-spl.c    | 63 +++++--------------
> arch/arm/mach-rockchip/rk322x-board-tpl.c    | 90 ++++++++++++++++++++++++++++
> arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds | 13 ++++
> include/configs/rk322x_common.h              |  9 ++-
> 6 files changed, 134 insertions(+), 53 deletions(-)
> create mode 100644 arch/arm/mach-rockchip/rk322x-board-tpl.c
> create mode 100644 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
>
> diff --git a/arch/arm/mach-rockchip/Kconfig b/arch/arm/mach-rockchip/Kconfig
> index 967290f..dbc197c 100644
> --- a/arch/arm/mach-rockchip/Kconfig
> +++ b/arch/arm/mach-rockchip/Kconfig
> @@ -46,9 +46,18 @@ config ROCKCHIP_RK322X
> 	bool "Support Rockchip RK3228/RK3229"
> 	select CPU_V7
> 	select SUPPORT_SPL
> +	select SUPPORT_TPL
> 	select SPL
> +	select TPL
> +	select TPL_NEEDS_SEPARATE_TEXT_BASE if SPL
> +	select TPL_NEEDS_SEPARATE_STACK if TPL
> +	select SPL_DRIVERS_MISC_SUPPORT
> +	imply SPL_SERIAL_SUPPORT
> +	imply TPL_SERIAL_SUPPORT
> 	select ROCKCHIP_BROM_HELPER
> 	select DEBUG_UART_BOARD_INIT
> +	select TPL_LIBCOMMON_SUPPORT
> +	select TPL_LIBGENERIC_SUPPORT
> 	help
> 	  The Rockchip RK3229 is a ARM-based SoC with a dual-core Cortex-A7
> 	  including NEON and GPU, Mali-400 graphics, several DDR3 options
> diff --git a/arch/arm/mach-rockchip/Makefile b/arch/arm/mach-rockchip/Makefile
> index e1b0519..3c14236 100644
> --- a/arch/arm/mach-rockchip/Makefile
> +++ b/arch/arm/mach-rockchip/Makefile
> @@ -13,10 +13,11 @@ obj-tpl-$(CONFIG_ROCKCHIP_BROM_HELPER) += bootrom.o
>
> obj-tpl-$(CONFIG_ROCKCHIP_RK3288) += rk3288-board-tpl.o
> obj-tpl-$(CONFIG_ROCKCHIP_RK3368) += rk3368-board-tpl.o
> +obj-tpl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-tpl.o
>
> obj-spl-$(CONFIG_ROCKCHIP_RK3036) += rk3036-board-spl.o
> obj-spl-$(CONFIG_ROCKCHIP_RK3188) += rk3188-board-spl.o
> -obj-spl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-spl.o
> +obj-spl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-spl.o spl-boot-order.o
> obj-spl-$(CONFIG_ROCKCHIP_RK3288) += rk3288-board-spl.o
> obj-spl-$(CONFIG_ROCKCHIP_RK3368) += rk3368-board-spl.o spl-boot-order.o
> obj-spl-$(CONFIG_ROCKCHIP_RK3399) += rk3399-board-spl.o spl-boot-order.o
> diff --git a/arch/arm/mach-rockchip/rk322x-board-spl.c b/arch/arm/mach-rockchip/rk322x-board-spl.c
> index 35f4f97..89af1d9 100644
> --- a/arch/arm/mach-rockchip/rk322x-board-spl.c
> +++ b/arch/arm/mach-rockchip/rk322x-board-spl.c
> @@ -5,77 +5,46 @@
>  */
>
> #include <common.h>
> -#include <debug_uart.h>
> #include <dm.h>
> -#include <ram.h>
> #include <spl.h>
> -#include <asm/io.h>
> -#include <asm/arch/bootrom.h>
> -#include <asm/arch/cru_rk322x.h>
> -#include <asm/arch/grf_rk322x.h>
> -#include <asm/arch/hardware.h>
> -#include <asm/arch/timer.h>
> -#include <asm/arch/uart.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
>
> u32 spl_boot_device(void)
> {
> 	return BOOT_DEVICE_MMC1;
> }
> -DECLARE_GLOBAL_DATA_PTR;
>
> -#define GRF_BASE	0x11000000
> -#define SGRF_BASE	0x10140000
> -
> -#define DEBUG_UART_BASE	0x11030000
> +u32 spl_boot_mode(const u32 boot_device)
> +{
> +	return MMCSD_MODE_RAW;
> +}
>
> void board_debug_uart_init(void)
> {
> -static struct rk322x_grf * const grf = (void *)GRF_BASE;
> -	/* Enable early UART2 channel 1 on the RK322x */
> -	rk_clrsetreg(&grf->gpio1b_iomux,
> -		     GPIO1B1_MASK | GPIO1B2_MASK,
> -		     GPIO1B2_UART21_SIN << GPIO1B2_SHIFT |
> -		     GPIO1B1_UART21_SOUT << GPIO1B1_SHIFT);
> -	/* Set channel C as UART2 input */
> -	rk_clrsetreg(&grf->con_iomux,
> -		     CON_IOMUX_UART2SEL_MASK,
> -		     CON_IOMUX_UART2SEL_21 << CON_IOMUX_UART2SEL_SHIFT);
> }
>
> -#define SGRF_DDR_CON0 0x10150000
> void board_init_f(ulong dummy)
> {
> -	struct udevice *dev;
> 	int ret;
>
> -	/*
> -	 * Debug UART can be used from here if required:
> -	 *
> -	 * debug_uart_init();
> -	 * printch('a');
> -	 * printhex8(0x1234);
> -	 * printascii("string");
> -	 */
> -	debug_uart_init();
> -	printascii("SPL Init");
> -
> 	ret = spl_early_init();
> 	if (ret) {
> -		debug("spl_early_init() failed: %d\n", ret);
> +		printf("spl_early_init() failed: %d\n", ret);
> 		hang();
> 	}
> +	preloader_console_init();
> +}
>
> -	rockchip_timer_init();
> -	printf("timer init done\n");
> -	ret = uclass_get_device(UCLASS_RAM, 0, &dev);
> -	if (ret) {
> -		printf("DRAM init failed: %d\n", ret);
> -		return;
> -	}
> +#ifdef CONFIG_SPL_LOAD_FIT
> +int board_fit_config_name_match(const char *name)
> +{
> +	/* Just empty function now - can't decide what to choose */
> +	debug("%s: %s\n", __func__, name);
>
> -	/* Disable the ddr secure region setting to make it non-secure */
> -	rk_clrreg(SGRF_DDR_CON0, 0x4000);
> #if defined(CONFIG_ROCKCHIP_SPL_BACK_TO_BROM) && !defined(CONFIG_SPL_BOARD_INIT)
> 	back_to_bootrom(BROM_BOOT_NEXTSTAGE);
> #endif
> +	return 0;
> }
> +#endif
> diff --git a/arch/arm/mach-rockchip/rk322x-board-tpl.c b/arch/arm/mach-rockchip/rk322x-board-tpl.c
> new file mode 100644
> index 0000000..aa14cef
> --- /dev/null
> +++ b/arch/arm/mach-rockchip/rk322x-board-tpl.c
> @@ -0,0 +1,90 @@
> +/*
> + * (C) Copyright 2017 Rockchip Electronics Co., Ltd
> + *
> + * SPDX-License-Identifier:     GPL-2.0+
> + */
> +
> +#include <common.h>
> +#include <debug_uart.h>
> +#include <dm.h>
> +#include <ram.h>
> +#include <spl.h>
> +#include <asm/io.h>
> +#include <asm/arch/bootrom.h>
> +#include <asm/arch/cru_rk322x.h>
> +#include <asm/arch/grf_rk322x.h>
> +#include <asm/arch/hardware.h>
> +#include <asm/arch/timer.h>
> +#include <asm/arch/uart.h>
> +
> +u32 spl_boot_device(void)
> +{
> +	return BOOT_DEVICE_MMC1;
> +}
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +#define GRF_BASE	0x11000000
> +#define SGRF_BASE	0x10140000
> +#define DEBUG_UART_BASE	0x11030000
> +#define SECURE_TIMER_BASE	0x110d0020
> +#define SGRF_DDR_CON0 0x10150000

Most of these defines are not used in the code below.
Please remove.

> +
> +void board_debug_uart_init(void)
> +{
> +	static struct rk322x_grf * const grf = (void *)GRF_BASE;
> +	/* Enable early UART2 channel 1 on the RK322x */
> +	rk_clrsetreg(&grf->gpio1b_iomux,
> +		     GPIO1B1_MASK | GPIO1B2_MASK,
> +		     GPIO1B2_UART21_SIN << GPIO1B2_SHIFT |
> +		     GPIO1B1_UART21_SOUT << GPIO1B1_SHIFT);
> +	/* Set channel C as UART2 input */
> +	rk_clrsetreg(&grf->con_iomux,
> +		     CON_IOMUX_UART2SEL_MASK,
> +		     CON_IOMUX_UART2SEL_21 << CON_IOMUX_UART2SEL_SHIFT);
> +}
> +
> +void secure_timer_init(void)
> +{
> +	writel(0, SECURE_TIMER_BASE + 0x10);
> +	writel(0xffffffff, SECURE_TIMER_BASE);
> +	writel(0xffffffff, SECURE_TIMER_BASE + 4);
> +	writel(1, SECURE_TIMER_BASE + 0x10);
> +}

If possible please use the DM timer class and the rockchip_timer.c
driver as a timebase for U-Boot (I assume that the secure timer will
be set up by OP-TEE anyway)... this should render this initialisation
unnecessary.

> +
> +void board_init_f(ulong dummy)
> +{
> +	struct udevice *dev;
> +	int ret;
> +
> +	/*
> +	 * Debug UART can be used from here if required:
> +	 *
> +	 * debug_uart_init();
> +	 * printch('a');
> +	 * printhex8(0x1234);
> +	 * printascii("string");
> +	 */
> +	debug_uart_init();
> +	printascii("TPL Init");
> +
> +	ret = spl_early_init();
> +	if (ret) {
> +		debug("spl_early_init() failed: %d\n", ret);
> +		hang();
> +	}
> +
> +	secure_timer_init();
> +	rockchip_timer_init();

Again: by using the DM timer drivers, you won't need to call the
rockchip_timer_init (as the init will be done by the DM timer).

> +	printf("timer init done\n");
> +	ret = uclass_get_device(UCLASS_RAM, 0, &dev);
> +	if (ret) {
> +		printf("DRAM init failed: %d\n", ret);
> +		return;
> +	}
> +
> +	/* Disable the ddr secure region setting to make it non-secure */
> +	rk_clrreg(SGRF_DDR_CON0, 0x4000);

Please use syscon to get the SGRF base-address and access this through
the SGRF structure definition.

> +#if defined(CONFIG_TPL_ROCKCHIP_BACK_TO_BROM) && !defined(CONFIG_TPL_BOARD_INIT)
> +	back_to_bootrom(BROM_BOOT_NEXTSTAGE);
> +#endif
> +}
> diff --git a/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds b/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
> new file mode 100644
> index 0000000..841c803
> --- /dev/null
> +++ b/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
> @@ -0,0 +1,13 @@
> +/*
> + * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
> + *
> + * SPDX-License-Identifier:	GPL-2.0+
> + */
> +
> +#undef CONFIG_SPL_TEXT_BASE
> +#define CONFIG_SPL_TEXT_BASE CONFIG_TPL_TEXT_BASE
> +
> +#undef CONFIG_SPL_MAX_SIZE
> +#define CONFIG_SPL_MAX_SIZE CONFIG_TPL_MAX_SIZE
> +
> +#include "../../cpu/u-boot-spl.lds"
> diff --git a/include/configs/rk322x_common.h b/include/configs/rk322x_common.h
> index b22169d..5536b58 100644
> --- a/include/configs/rk322x_common.h
> +++ b/include/configs/rk322x_common.h
> @@ -20,11 +20,10 @@
>
> #define CONFIG_SPL_FRAMEWORK
> #define CONFIG_SYS_NS16550_MEM32
> -#define CONFIG_SYS_TEXT_BASE		0x60000000
> -#define CONFIG_SYS_INIT_SP_ADDR		0x60100000
> -#define CONFIG_SYS_LOAD_ADDR		0x60800800
> -#define CONFIG_SPL_STACK		0x10088000
> -#define CONFIG_SPL_TEXT_BASE		0x10081004
> +#define CONFIG_SYS_TEXT_BASE		0x61000000
> +#define CONFIG_SYS_INIT_SP_ADDR		0x61100000
> +#define CONFIG_SYS_LOAD_ADDR		0x61800800
> +#define CONFIG_SPL_TEXT_BASE		0x60000000
>
> #define CONFIG_ROCKCHIP_MAX_INIT_SIZE	(28 << 10)
> #define CONFIG_ROCKCHIP_CHIP_TAG	"RK32"
>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 07/11] spl: add support to booting with OP-TEE
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 07/11] spl: add support to booting with OP-TEE Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:20   ` Philipp Tomsich
  2018-01-04  3:51     ` Kever Yang
  1 sibling, 1 reply; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:20 UTC (permalink / raw)
  To: u-boot



On Tue, 19 Dec 2017, Kever Yang wrote:

> OP-TEE is an open source trusted OS, in armv7, its loading and
> running are like this:
> loading:
> - SPL load both OP-TEE and U-Boot
> running:
> - SPL run into OP-TEE in secure mode;
> - OP-TEE run into U-Boot in non-secure mode;
>
> More detail:
> https://github.com/OP-TEE/optee_os
> and search for 'boot arguments' for detail entry parameter in:
> core/arch/arm/kernel/generic_entry_a32.S
>
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

See below for requested changed.

> ---
>
> Changes in v3: None
> Changes in v2:
> - Using new image type for op-tee
>
> common/spl/Kconfig     |  7 +++++++
> common/spl/Makefile    |  1 +
> common/spl/spl.c       |  8 ++++++++
> common/spl/spl_optee.S | 13 +++++++++++++
> include/spl.h          |  9 +++++++++
> 5 files changed, 38 insertions(+)
> create mode 100644 common/spl/spl_optee.S
>
> diff --git a/common/spl/Kconfig b/common/spl/Kconfig
> index aef0034..c9a1ebb 100644
> --- a/common/spl/Kconfig
> +++ b/common/spl/Kconfig
> @@ -725,6 +725,13 @@ config SPL_ATF
> 	  is loaded by SPL(which is considered as BL2 in ATF terminology).
> 	  More detail at: https://github.com/ARM-software/arm-trusted-firmware
>
> +config SPL_OPTEE
> +	bool "Support OP-TEE Trusted OS"
> +	depends on ARM
> +	help
> +	  OP-TEE is an open source Trusted OS  which is loaded by SPL.
> +	  More detail at: https://github.com/OP-TEE/optee_os
> +
> config TPL
> 	bool
> 	depends on SUPPORT_TPL
> diff --git a/common/spl/Makefile b/common/spl/Makefile
> index 9bf8a2d..9918a2e 100644
> --- a/common/spl/Makefile
> +++ b/common/spl/Makefile
> @@ -23,6 +23,7 @@ obj-$(CONFIG_$(SPL_TPL_)UBI) += spl_ubi.o
> obj-$(CONFIG_$(SPL_TPL_)NET_SUPPORT) += spl_net.o
> obj-$(CONFIG_$(SPL_TPL_)MMC_SUPPORT) += spl_mmc.o
> obj-$(CONFIG_$(SPL_TPL_)ATF) += spl_atf.o
> +obj-$(CONFIG_$(SPL_TPL_)OPTEE) += spl_optee.o
> obj-$(CONFIG_$(SPL_TPL_)USB_SUPPORT) += spl_usb.o
> obj-$(CONFIG_$(SPL_TPL_)FAT_SUPPORT) += spl_fat.o
> obj-$(CONFIG_$(SPL_TPL_)EXT_SUPPORT) += spl_ext.o
> diff --git a/common/spl/spl.c b/common/spl/spl.c
> index 76c1963..2c8942b 100644
> --- a/common/spl/spl.c
> +++ b/common/spl/spl.c
> @@ -436,6 +436,12 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
> 		spl_invoke_atf(&spl_image);
> 		break;
> #endif
> +#if CONFIG_IS_ENABLED(OPTEE)
> +	case IH_OS_OP_TEE:
> +		debug("Jumping to U-Boot via OP-TEE\n");
> +		spl_optee_entry(0, 0, 0, (void *)spl_image.entry_point);

Why are you passing '0' for "arg2, device tree address"? This should
be the device-tree pointer from the spl_image...

Also: 0 is not the same as NULL ... the arguments are all defined to
have void* type, so 0 is not the correct type.

> +		break;
> +#endif
> #ifdef CONFIG_SPL_OS_BOOT
> 	case IH_OS_LINUX:
> 		debug("Jumping to Linux\n");
> @@ -450,6 +456,8 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
> 	debug("SPL malloc() used %#lx bytes (%ld KB)\n", gd->malloc_ptr,
> 	      gd->malloc_ptr / 1024);
> #endif
> +
> +	debug("loaded - jumping to U-Boot...\n");
> #ifdef CONFIG_BOOTSTAGE_STASH
> 	int ret;
>
> diff --git a/common/spl/spl_optee.S b/common/spl/spl_optee.S
> new file mode 100644
> index 0000000..4f7f8ba
> --- /dev/null
> +++ b/common/spl/spl_optee.S
> @@ -0,0 +1,13 @@
> +/*
> + * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
> + *
> + * SPDX-License-Identifier:	GPL-2.0+
> + */
> +
> +#include <linux/linkage.h>
> +#include <asm/assembler.h>
> +
> +ENTRY(spl_optee_entry)
> +	ldr lr, =CONFIG_SYS_TEXT_BASE
> +	mov pc, r3
> +ENDPROC(spl_optee_entry)
> diff --git a/include/spl.h b/include/spl.h
> index c14448b..551ce43 100644
> --- a/include/spl.h
> +++ b/include/spl.h
> @@ -288,6 +288,15 @@ int spl_mmc_load_image(struct spl_image_info *spl_image,
> void spl_invoke_atf(struct spl_image_info *spl_image);
>
> /**
> + * spl_optee_entry - entry function for optee
> + * entry arg0, pagestore
> + * entry arg1, (ARMv7 standard bootarg #1)
> + * entry arg2, device tree address, (ARMv7 standard bootarg #2)
> + * entry arg3, non-secure entry address (ARMv7 bootarg #0)
> + */
> +void spl_optee_entry(void *arg0, void *arg1, void *arg2, void *arg3);

This doesn't look like a documentation comment for a U-Boot function.
Also: the purpose of arg0 and arg1 are not clear from this comment.

> +
> +/**
>  * board_return_to_bootrom - allow for boards to continue with the boot ROM
>  *
>  * If a board (e.g. the Rockchip RK3368 boards) provide some
>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 01/11] lib: add TPL_OF_LIBFDT option for TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:25 UTC (permalink / raw)
  To: u-boot

> TPL may need use libfdt for dt decode, add option for it.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  lib/Kconfig | 10 ++++++++++
>  1 file changed, 10 insertions(+)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 05/11] sysreset: enable driver support in SPL/TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 05/11] sysreset: enable driver support in SPL/TPL Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:25 UTC (permalink / raw)
  To: u-boot

> SPL/TPL also need use sysreset for some feature like panic callback.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  drivers/sysreset/Kconfig  | 18 ++++++++++++++++++
>  drivers/sysreset/Makefile |  2 +-
>  2 files changed, 19 insertions(+), 1 deletion(-)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 02/11] arm: add option for TPL ARCH_MEM in arm 32bit
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 02/11] arm: add option for TPL ARCH_MEM in arm 32bit Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:25 UTC (permalink / raw)
  To: u-boot

> Some options like TPL_SYS_THUMB_BUILD, TPL_USE_ARCH_MEMCPY
> and TPL_USE_ARCH_MEMCPY are needed for TPL build in 32bit arm.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - update subject with ARCH_MEM info
> 
>  arch/arm/Kconfig | 29 +++++++++++++++++++++++++++++
>  1 file changed, 29 insertions(+)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot,v3,03/11] arm: add a separate stack for TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 03/11] arm: add a separate stack for TPL Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot,v3,03/11] " Philipp Tomsich
@ 2018-01-02 17:25   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:25 UTC (permalink / raw)
  To: u-boot

> TPL stack may different from SPL and sys stack, add support for
> separate one when the board defines it.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  arch/arm/lib/crt0.S | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot,v3,06/11] image: add os type for OP-TEE
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 06/11] image: add os type for OP-TEE Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot,v3,06/11] " Philipp Tomsich
@ 2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:26 UTC (permalink / raw)
  To: u-boot

> OP-TEE is an open source trust OS maintained here:
> https://github.com/OP-TEE/optee_os
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - Add new image type like ATF
> 
>  common/image.c  | 1 +
>  include/image.h | 1 +
>  2 files changed, 2 insertions(+)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 09/11] rockchip: add fit source file for pack itb with op-tee
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 09/11] rockchip: add fit source file for pack itb with op-tee Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:26 UTC (permalink / raw)
  To: u-boot

> We package U-Boot and OP-TEE into one itb file for SPL,
> so that we can support OP-TEE in SPL.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - Make the its as common file used for all armv7 with op-tee
> 
>  arch/arm/mach-rockchip/fit_spl_optee.its | 50 ++++++++++++++++++++++++++++++++
>  1 file changed, 50 insertions(+)
>  create mode 100644 arch/arm/mach-rockchip/fit_spl_optee.its
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:26 UTC (permalink / raw)
  To: u-boot

> When we use DM_SERIAL for serial driver, we need enable the
> dts node for the debug console.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  arch/arm/dts/rk3229-evb.dts | 1 +
>  1 file changed, 1 insertion(+)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 10/11] rockchip: evb-rk3229: add README file for OP-TEE support
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 10/11] rockchip: evb-rk3229: add README file for OP-TEE support Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:26 UTC (permalink / raw)
  To: u-boot

> Detail of step by step to bring up the board with OP-TEE support.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  board/rockchip/evb_rk3229/README | 72 ++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 72 insertions(+)
>  create mode 100644 board/rockchip/evb_rk3229/README
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support
  2017-12-19  8:53 ` [U-Boot] [PATCH v3 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support Kever Yang
  2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
@ 2018-01-02 17:26   ` Philipp Tomsich
  1 sibling, 0 replies; 38+ messages in thread
From: Philipp Tomsich @ 2018-01-02 17:26 UTC (permalink / raw)
  To: u-boot

> Enable all the options for TPL/SPL and OPTEE.
> 
> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
> ---
> 
> Changes in v3: None
> Changes in v2:
> - update defconfig option
> 
>  configs/evb-rk3229_defconfig | 26 +++++++++++++++++++++++---
>  1 file changed, 23 insertions(+), 3 deletions(-)
> 

Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 04/11] rockchip: rk322x: enable tpl support
  2018-01-02 17:17   ` Philipp Tomsich
@ 2018-01-04  2:52     ` Kever Yang
  0 siblings, 0 replies; 38+ messages in thread
From: Kever Yang @ 2018-01-04  2:52 UTC (permalink / raw)
  To: u-boot



On 01/03/2018 01:17 AM, Philipp Tomsich wrote:
>
>
> On Tue, 19 Dec 2017, Kever Yang wrote:
>
>> Move original spl to tpl, and add spl to load next stage firmware,
>> adapt all the address and option for them.
>>
>> Serial-changes: 2
>> - update upon latest source
>>
>> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
>
> Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
>
> See below for requested changes.
>
>> ---
>>
>> Changes in v3:
>> - do not init ddr region in spl
>>
>> Changes in v2: None
>>
>> arch/arm/mach-rockchip/Kconfig               |  9 +++
>> arch/arm/mach-rockchip/Makefile              |  3 +-
>> arch/arm/mach-rockchip/rk322x-board-spl.c    | 63 +++++--------------
>> arch/arm/mach-rockchip/rk322x-board-tpl.c    | 90 
>> ++++++++++++++++++++++++++++
>> arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds | 13 ++++
>> include/configs/rk322x_common.h              |  9 ++-
>> 6 files changed, 134 insertions(+), 53 deletions(-)
>> create mode 100644 arch/arm/mach-rockchip/rk322x-board-tpl.c
>> create mode 100644 arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
>>
>> diff --git a/arch/arm/mach-rockchip/Kconfig 
>> b/arch/arm/mach-rockchip/Kconfig
>> index 967290f..dbc197c 100644
>> --- a/arch/arm/mach-rockchip/Kconfig
>> +++ b/arch/arm/mach-rockchip/Kconfig
>> @@ -46,9 +46,18 @@ config ROCKCHIP_RK322X
>>     bool "Support Rockchip RK3228/RK3229"
>>     select CPU_V7
>>     select SUPPORT_SPL
>> +    select SUPPORT_TPL
>>     select SPL
>> +    select TPL
>> +    select TPL_NEEDS_SEPARATE_TEXT_BASE if SPL
>> +    select TPL_NEEDS_SEPARATE_STACK if TPL
>> +    select SPL_DRIVERS_MISC_SUPPORT
>> +    imply SPL_SERIAL_SUPPORT
>> +    imply TPL_SERIAL_SUPPORT
>>     select ROCKCHIP_BROM_HELPER
>>     select DEBUG_UART_BOARD_INIT
>> +    select TPL_LIBCOMMON_SUPPORT
>> +    select TPL_LIBGENERIC_SUPPORT
>>     help
>>       The Rockchip RK3229 is a ARM-based SoC with a dual-core Cortex-A7
>>       including NEON and GPU, Mali-400 graphics, several DDR3 options
>> diff --git a/arch/arm/mach-rockchip/Makefile 
>> b/arch/arm/mach-rockchip/Makefile
>> index e1b0519..3c14236 100644
>> --- a/arch/arm/mach-rockchip/Makefile
>> +++ b/arch/arm/mach-rockchip/Makefile
>> @@ -13,10 +13,11 @@ obj-tpl-$(CONFIG_ROCKCHIP_BROM_HELPER) += bootrom.o
>>
>> obj-tpl-$(CONFIG_ROCKCHIP_RK3288) += rk3288-board-tpl.o
>> obj-tpl-$(CONFIG_ROCKCHIP_RK3368) += rk3368-board-tpl.o
>> +obj-tpl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-tpl.o
>>
>> obj-spl-$(CONFIG_ROCKCHIP_RK3036) += rk3036-board-spl.o
>> obj-spl-$(CONFIG_ROCKCHIP_RK3188) += rk3188-board-spl.o
>> -obj-spl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-spl.o
>> +obj-spl-$(CONFIG_ROCKCHIP_RK322X) += rk322x-board-spl.o 
>> spl-boot-order.o
>> obj-spl-$(CONFIG_ROCKCHIP_RK3288) += rk3288-board-spl.o
>> obj-spl-$(CONFIG_ROCKCHIP_RK3368) += rk3368-board-spl.o spl-boot-order.o
>> obj-spl-$(CONFIG_ROCKCHIP_RK3399) += rk3399-board-spl.o spl-boot-order.o
>> diff --git a/arch/arm/mach-rockchip/rk322x-board-spl.c 
>> b/arch/arm/mach-rockchip/rk322x-board-spl.c
>> index 35f4f97..89af1d9 100644
>> --- a/arch/arm/mach-rockchip/rk322x-board-spl.c
>> +++ b/arch/arm/mach-rockchip/rk322x-board-spl.c
>> @@ -5,77 +5,46 @@
>>  */
>>
>> #include <common.h>
>> -#include <debug_uart.h>
>> #include <dm.h>
>> -#include <ram.h>
>> #include <spl.h>
>> -#include <asm/io.h>
>> -#include <asm/arch/bootrom.h>
>> -#include <asm/arch/cru_rk322x.h>
>> -#include <asm/arch/grf_rk322x.h>
>> -#include <asm/arch/hardware.h>
>> -#include <asm/arch/timer.h>
>> -#include <asm/arch/uart.h>
>> +
>> +DECLARE_GLOBAL_DATA_PTR;
>>
>> u32 spl_boot_device(void)
>> {
>>     return BOOT_DEVICE_MMC1;
>> }
>> -DECLARE_GLOBAL_DATA_PTR;
>>
>> -#define GRF_BASE    0x11000000
>> -#define SGRF_BASE    0x10140000
>> -
>> -#define DEBUG_UART_BASE    0x11030000
>> +u32 spl_boot_mode(const u32 boot_device)
>> +{
>> +    return MMCSD_MODE_RAW;
>> +}
>>
>> void board_debug_uart_init(void)
>> {
>> -static struct rk322x_grf * const grf = (void *)GRF_BASE;
>> -    /* Enable early UART2 channel 1 on the RK322x */
>> -    rk_clrsetreg(&grf->gpio1b_iomux,
>> -             GPIO1B1_MASK | GPIO1B2_MASK,
>> -             GPIO1B2_UART21_SIN << GPIO1B2_SHIFT |
>> -             GPIO1B1_UART21_SOUT << GPIO1B1_SHIFT);
>> -    /* Set channel C as UART2 input */
>> -    rk_clrsetreg(&grf->con_iomux,
>> -             CON_IOMUX_UART2SEL_MASK,
>> -             CON_IOMUX_UART2SEL_21 << CON_IOMUX_UART2SEL_SHIFT);
>> }
>>
>> -#define SGRF_DDR_CON0 0x10150000
>> void board_init_f(ulong dummy)
>> {
>> -    struct udevice *dev;
>>     int ret;
>>
>> -    /*
>> -     * Debug UART can be used from here if required:
>> -     *
>> -     * debug_uart_init();
>> -     * printch('a');
>> -     * printhex8(0x1234);
>> -     * printascii("string");
>> -     */
>> -    debug_uart_init();
>> -    printascii("SPL Init");
>> -
>>     ret = spl_early_init();
>>     if (ret) {
>> -        debug("spl_early_init() failed: %d\n", ret);
>> +        printf("spl_early_init() failed: %d\n", ret);
>>         hang();
>>     }
>> +    preloader_console_init();
>> +}
>>
>> -    rockchip_timer_init();
>> -    printf("timer init done\n");
>> -    ret = uclass_get_device(UCLASS_RAM, 0, &dev);
>> -    if (ret) {
>> -        printf("DRAM init failed: %d\n", ret);
>> -        return;
>> -    }
>> +#ifdef CONFIG_SPL_LOAD_FIT
>> +int board_fit_config_name_match(const char *name)
>> +{
>> +    /* Just empty function now - can't decide what to choose */
>> +    debug("%s: %s\n", __func__, name);
>>
>> -    /* Disable the ddr secure region setting to make it non-secure */
>> -    rk_clrreg(SGRF_DDR_CON0, 0x4000);
>> #if defined(CONFIG_ROCKCHIP_SPL_BACK_TO_BROM) && 
>> !defined(CONFIG_SPL_BOARD_INIT)
>>     back_to_bootrom(BROM_BOOT_NEXTSTAGE);
>> #endif
>> +    return 0;
>> }
>> +#endif
>> diff --git a/arch/arm/mach-rockchip/rk322x-board-tpl.c 
>> b/arch/arm/mach-rockchip/rk322x-board-tpl.c
>> new file mode 100644
>> index 0000000..aa14cef
>> --- /dev/null
>> +++ b/arch/arm/mach-rockchip/rk322x-board-tpl.c
>> @@ -0,0 +1,90 @@
>> +/*
>> + * (C) Copyright 2017 Rockchip Electronics Co., Ltd
>> + *
>> + * SPDX-License-Identifier:     GPL-2.0+
>> + */
>> +
>> +#include <common.h>
>> +#include <debug_uart.h>
>> +#include <dm.h>
>> +#include <ram.h>
>> +#include <spl.h>
>> +#include <asm/io.h>
>> +#include <asm/arch/bootrom.h>
>> +#include <asm/arch/cru_rk322x.h>
>> +#include <asm/arch/grf_rk322x.h>
>> +#include <asm/arch/hardware.h>
>> +#include <asm/arch/timer.h>
>> +#include <asm/arch/uart.h>
>> +
>> +u32 spl_boot_device(void)
>> +{
>> +    return BOOT_DEVICE_MMC1;
>> +}
>> +DECLARE_GLOBAL_DATA_PTR;
>> +
>> +#define GRF_BASE    0x11000000
>> +#define SGRF_BASE    0x10140000
>> +#define DEBUG_UART_BASE    0x11030000
>> +#define SECURE_TIMER_BASE    0x110d0020
>> +#define SGRF_DDR_CON0 0x10150000
>
> Most of these defines are not used in the code below.
> Please remove.

I will remove those non-used next version, thanks.
>
>> +
>> +void board_debug_uart_init(void)
>> +{
>> +    static struct rk322x_grf * const grf = (void *)GRF_BASE;
>> +    /* Enable early UART2 channel 1 on the RK322x */
>> +    rk_clrsetreg(&grf->gpio1b_iomux,
>> +             GPIO1B1_MASK | GPIO1B2_MASK,
>> +             GPIO1B2_UART21_SIN << GPIO1B2_SHIFT |
>> +             GPIO1B1_UART21_SOUT << GPIO1B1_SHIFT);
>> +    /* Set channel C as UART2 input */
>> +    rk_clrsetreg(&grf->con_iomux,
>> +             CON_IOMUX_UART2SEL_MASK,
>> +             CON_IOMUX_UART2SEL_21 << CON_IOMUX_UART2SEL_SHIFT);
>> +}
>> +
>> +void secure_timer_init(void)
>> +{
>> +    writel(0, SECURE_TIMER_BASE + 0x10);
>> +    writel(0xffffffff, SECURE_TIMER_BASE);
>> +    writel(0xffffffff, SECURE_TIMER_BASE + 4);
>> +    writel(1, SECURE_TIMER_BASE + 0x10);
>> +}
>
> If possible please use the DM timer class and the rockchip_timer.c
> driver as a timebase for U-Boot (I assume that the secure timer will
> be set up by OP-TEE anyway)... this should render this initialisation
> unnecessary.

I agree DM is good framework in U-Boot proper, but maybe not in TPL/SPL.
Framework cost more code space and running time, but we get benefit for its
comment code and compatibility.
To be honest, I don't like use too much framework in TPL which is in IRAM,
I want to make it as simple as possible, and also need clear enough with 
comments.
I will consider what to use framework and what to use hard code in TPL/SPL,
we need to balance it but not use DM everywhere:
DEBUG_UART/SERIAL/SYSCON/PINCTRL/CLOCK/

Secure timer must be setup before trust(OPTEE/ATF) for all rockchip 
platform now,
U-Boot proper can not access it, it's the clock source of arm generic timer.
we can consider using arm generic timer as time base and drop 
rockchip_timer.c when we
use DM framework, I think the rockchp_timer.c is used for chip like 
rk3036 who can not
use any framework because of the IRAM size limit.

>
>> +
>> +void board_init_f(ulong dummy)
>> +{
>> +    struct udevice *dev;
>> +    int ret;
>> +
>> +    /*
>> +     * Debug UART can be used from here if required:
>> +     *
>> +     * debug_uart_init();
>> +     * printch('a');
>> +     * printhex8(0x1234);
>> +     * printascii("string");
>> +     */
>> +    debug_uart_init();
>> +    printascii("TPL Init");
>> +
>> +    ret = spl_early_init();
>> +    if (ret) {
>> +        debug("spl_early_init() failed: %d\n", ret);
>> +        hang();
>> +    }
>> +
>> +    secure_timer_init();
>> +    rockchip_timer_init();
>
> Again: by using the DM timer drivers, you won't need to call the
> rockchip_timer_init (as the init will be done by the DM timer).
>
>> +    printf("timer init done\n");
>> +    ret = uclass_get_device(UCLASS_RAM, 0, &dev);
>> +    if (ret) {
>> +        printf("DRAM init failed: %d\n", ret);
>> +        return;
>> +    }
>> +
>> +    /* Disable the ddr secure region setting to make it non-secure */
>> +    rk_clrreg(SGRF_DDR_CON0, 0x4000);
>
> Please use syscon to get the SGRF base-address and access this through
> the SGRF structure definition.

Sorry, I don't think this one time init, need introduce syscon(more code 
space and instructions with
no any other help), it's different in different soc, and it's only 
available in TPL or SPL(if no TPL support).
I would like to make it as-is and with clear enough comments.

Thanks,
- Kever
>
>> +#if defined(CONFIG_TPL_ROCKCHIP_BACK_TO_BROM) && 
>> !defined(CONFIG_TPL_BOARD_INIT)
>> +    back_to_bootrom(BROM_BOOT_NEXTSTAGE);
>> +#endif
>> +}
>> diff --git a/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds 
>> b/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
>> new file mode 100644
>> index 0000000..841c803
>> --- /dev/null
>> +++ b/arch/arm/mach-rockchip/rk322x/u-boot-tpl.lds
>> @@ -0,0 +1,13 @@
>> +/*
>> + * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
>> + *
>> + * SPDX-License-Identifier:    GPL-2.0+
>> + */
>> +
>> +#undef CONFIG_SPL_TEXT_BASE
>> +#define CONFIG_SPL_TEXT_BASE CONFIG_TPL_TEXT_BASE
>> +
>> +#undef CONFIG_SPL_MAX_SIZE
>> +#define CONFIG_SPL_MAX_SIZE CONFIG_TPL_MAX_SIZE
>> +
>> +#include "../../cpu/u-boot-spl.lds"
>> diff --git a/include/configs/rk322x_common.h 
>> b/include/configs/rk322x_common.h
>> index b22169d..5536b58 100644
>> --- a/include/configs/rk322x_common.h
>> +++ b/include/configs/rk322x_common.h
>> @@ -20,11 +20,10 @@
>>
>> #define CONFIG_SPL_FRAMEWORK
>> #define CONFIG_SYS_NS16550_MEM32
>> -#define CONFIG_SYS_TEXT_BASE        0x60000000
>> -#define CONFIG_SYS_INIT_SP_ADDR        0x60100000
>> -#define CONFIG_SYS_LOAD_ADDR        0x60800800
>> -#define CONFIG_SPL_STACK        0x10088000
>> -#define CONFIG_SPL_TEXT_BASE        0x10081004
>> +#define CONFIG_SYS_TEXT_BASE        0x61000000
>> +#define CONFIG_SYS_INIT_SP_ADDR        0x61100000
>> +#define CONFIG_SYS_LOAD_ADDR        0x61800800
>> +#define CONFIG_SPL_TEXT_BASE        0x60000000
>>
>> #define CONFIG_ROCKCHIP_MAX_INIT_SIZE    (28 << 10)
>> #define CONFIG_ROCKCHIP_CHIP_TAG    "RK32"
>>
>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 07/11] spl: add support to booting with OP-TEE
  2018-01-02 17:20   ` Philipp Tomsich
@ 2018-01-04  3:51     ` Kever Yang
  2018-01-04 10:48       ` Dr. Philipp Tomsich
  0 siblings, 1 reply; 38+ messages in thread
From: Kever Yang @ 2018-01-04  3:51 UTC (permalink / raw)
  To: u-boot



On 01/03/2018 01:20 AM, Philipp Tomsich wrote:
>
>
> On Tue, 19 Dec 2017, Kever Yang wrote:
>
>> OP-TEE is an open source trusted OS, in armv7, its loading and
>> running are like this:
>> loading:
>> - SPL load both OP-TEE and U-Boot
>> running:
>> - SPL run into OP-TEE in secure mode;
>> - OP-TEE run into U-Boot in non-secure mode;
>>
>> More detail:
>> https://github.com/OP-TEE/optee_os
>> and search for 'boot arguments' for detail entry parameter in:
>> core/arch/arm/kernel/generic_entry_a32.S
>>
>> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
>
> Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
>
> See below for requested changed.
>
>> ---
>>
>> Changes in v3: None
>> Changes in v2:
>> - Using new image type for op-tee
>>
>> common/spl/Kconfig     |  7 +++++++
>> common/spl/Makefile    |  1 +
>> common/spl/spl.c       |  8 ++++++++
>> common/spl/spl_optee.S | 13 +++++++++++++
>> include/spl.h          |  9 +++++++++
>> 5 files changed, 38 insertions(+)
>> create mode 100644 common/spl/spl_optee.S
>>
>> diff --git a/common/spl/Kconfig b/common/spl/Kconfig
>> index aef0034..c9a1ebb 100644
>> --- a/common/spl/Kconfig
>> +++ b/common/spl/Kconfig
>> @@ -725,6 +725,13 @@ config SPL_ATF
>>       is loaded by SPL(which is considered as BL2 in ATF terminology).
>>       More detail at: 
>> https://github.com/ARM-software/arm-trusted-firmware
>>
>> +config SPL_OPTEE
>> +    bool "Support OP-TEE Trusted OS"
>> +    depends on ARM
>> +    help
>> +      OP-TEE is an open source Trusted OS  which is loaded by SPL.
>> +      More detail at: https://github.com/OP-TEE/optee_os
>> +
>> config TPL
>>     bool
>>     depends on SUPPORT_TPL
>> diff --git a/common/spl/Makefile b/common/spl/Makefile
>> index 9bf8a2d..9918a2e 100644
>> --- a/common/spl/Makefile
>> +++ b/common/spl/Makefile
>> @@ -23,6 +23,7 @@ obj-$(CONFIG_$(SPL_TPL_)UBI) += spl_ubi.o
>> obj-$(CONFIG_$(SPL_TPL_)NET_SUPPORT) += spl_net.o
>> obj-$(CONFIG_$(SPL_TPL_)MMC_SUPPORT) += spl_mmc.o
>> obj-$(CONFIG_$(SPL_TPL_)ATF) += spl_atf.o
>> +obj-$(CONFIG_$(SPL_TPL_)OPTEE) += spl_optee.o
>> obj-$(CONFIG_$(SPL_TPL_)USB_SUPPORT) += spl_usb.o
>> obj-$(CONFIG_$(SPL_TPL_)FAT_SUPPORT) += spl_fat.o
>> obj-$(CONFIG_$(SPL_TPL_)EXT_SUPPORT) += spl_ext.o
>> diff --git a/common/spl/spl.c b/common/spl/spl.c
>> index 76c1963..2c8942b 100644
>> --- a/common/spl/spl.c
>> +++ b/common/spl/spl.c
>> @@ -436,6 +436,12 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
>>         spl_invoke_atf(&spl_image);
>>         break;
>> #endif
>> +#if CONFIG_IS_ENABLED(OPTEE)
>> +    case IH_OS_OP_TEE:
>> +        debug("Jumping to U-Boot via OP-TEE\n");
>> +        spl_optee_entry(0, 0, 0, (void *)spl_image.entry_point);
>
> Why are you passing '0' for "arg2, device tree address"? This should
> be the device-tree pointer from the spl_image...

I will add dt pointer for entry next version.
>
> Also: 0 is not the same as NULL ... the arguments are all defined to
> have void* type, so 0 is not the correct type.
>
>> +        break;
>> +#endif
>> #ifdef CONFIG_SPL_OS_BOOT
>>     case IH_OS_LINUX:
>>         debug("Jumping to Linux\n");
>> @@ -450,6 +456,8 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
>>     debug("SPL malloc() used %#lx bytes (%ld KB)\n", gd->malloc_ptr,
>>           gd->malloc_ptr / 1024);
>> #endif
>> +
>> +    debug("loaded - jumping to U-Boot...\n");
>> #ifdef CONFIG_BOOTSTAGE_STASH
>>     int ret;
>>
>> diff --git a/common/spl/spl_optee.S b/common/spl/spl_optee.S
>> new file mode 100644
>> index 0000000..4f7f8ba
>> --- /dev/null
>> +++ b/common/spl/spl_optee.S
>> @@ -0,0 +1,13 @@
>> +/*
>> + * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
>> + *
>> + * SPDX-License-Identifier:    GPL-2.0+
>> + */
>> +
>> +#include <linux/linkage.h>
>> +#include <asm/assembler.h>
>> +
>> +ENTRY(spl_optee_entry)
>> +    ldr lr, =CONFIG_SYS_TEXT_BASE
>> +    mov pc, r3
>> +ENDPROC(spl_optee_entry)
>> diff --git a/include/spl.h b/include/spl.h
>> index c14448b..551ce43 100644
>> --- a/include/spl.h
>> +++ b/include/spl.h
>> @@ -288,6 +288,15 @@ int spl_mmc_load_image(struct spl_image_info 
>> *spl_image,
>> void spl_invoke_atf(struct spl_image_info *spl_image);
>>
>> /**
>> + * spl_optee_entry - entry function for optee
>> + * entry arg0, pagestore
>> + * entry arg1, (ARMv7 standard bootarg #1)
>> + * entry arg2, device tree address, (ARMv7 standard bootarg #2)
>> + * entry arg3, non-secure entry address (ARMv7 bootarg #0)
>> + */
>> +void spl_optee_entry(void *arg0, void *arg1, void *arg2, void *arg3);
>
> This doesn't look like a documentation comment for a U-Boot function.
> Also: the purpose of arg0 and arg1 are not clear from this comment.

This is a copy from OP-TEE project, we only use the entry address now.
https://github.com/OP-TEE/optee_os/blob/master/core/arch/arm/kernel/generic_entry_a32.S#L208

Thanks,
- Kever
>
>> +
>> +/**
>>  * board_return_to_bootrom - allow for boards to continue with the 
>> boot ROM
>>  *
>>  * If a board (e.g. the Rockchip RK3368 boards) provide some
>>
>

^ permalink raw reply	[flat|nested] 38+ messages in thread

* [U-Boot] [U-Boot, v3, 07/11] spl: add support to booting with OP-TEE
  2018-01-04  3:51     ` Kever Yang
@ 2018-01-04 10:48       ` Dr. Philipp Tomsich
  0 siblings, 0 replies; 38+ messages in thread
From: Dr. Philipp Tomsich @ 2018-01-04 10:48 UTC (permalink / raw)
  To: u-boot


> On 4 Jan 2018, at 04:51, Kever Yang <kever.yang@rock-chips.com> wrote:
> 
> 
> 
> On 01/03/2018 01:20 AM, Philipp Tomsich wrote:
>> 
>> 
>> On Tue, 19 Dec 2017, Kever Yang wrote:
>> 
>>> OP-TEE is an open source trusted OS, in armv7, its loading and
>>> running are like this:
>>> loading:
>>> - SPL load both OP-TEE and U-Boot
>>> running:
>>> - SPL run into OP-TEE in secure mode;
>>> - OP-TEE run into U-Boot in non-secure mode;
>>> 
>>> More detail:
>>> https://github.com/OP-TEE/optee_os
>>> and search for 'boot arguments' for detail entry parameter in:
>>> core/arch/arm/kernel/generic_entry_a32.S
>>> 
>>> Signed-off-by: Kever Yang <kever.yang@rock-chips.com>
>> 
>> Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
>> 
>> See below for requested changed.
>> 
>>> ---
>>> 
>>> Changes in v3: None
>>> Changes in v2:
>>> - Using new image type for op-tee
>>> 
>>> common/spl/Kconfig     |  7 +++++++
>>> common/spl/Makefile    |  1 +
>>> common/spl/spl.c       |  8 ++++++++
>>> common/spl/spl_optee.S | 13 +++++++++++++
>>> include/spl.h          |  9 +++++++++
>>> 5 files changed, 38 insertions(+)
>>> create mode 100644 common/spl/spl_optee.S
>>> 
>>> diff --git a/common/spl/Kconfig b/common/spl/Kconfig
>>> index aef0034..c9a1ebb 100644
>>> --- a/common/spl/Kconfig
>>> +++ b/common/spl/Kconfig
>>> @@ -725,6 +725,13 @@ config SPL_ATF
>>>      is loaded by SPL(which is considered as BL2 in ATF terminology).
>>>      More detail at: https://github.com/ARM-software/arm-trusted-firmware
>>> 
>>> +config SPL_OPTEE
>>> +    bool "Support OP-TEE Trusted OS"
>>> +    depends on ARM
>>> +    help
>>> +      OP-TEE is an open source Trusted OS  which is loaded by SPL.
>>> +      More detail at: https://github.com/OP-TEE/optee_os
>>> +
>>> config TPL
>>>    bool
>>>    depends on SUPPORT_TPL
>>> diff --git a/common/spl/Makefile b/common/spl/Makefile
>>> index 9bf8a2d..9918a2e 100644
>>> --- a/common/spl/Makefile
>>> +++ b/common/spl/Makefile
>>> @@ -23,6 +23,7 @@ obj-$(CONFIG_$(SPL_TPL_)UBI) += spl_ubi.o
>>> obj-$(CONFIG_$(SPL_TPL_)NET_SUPPORT) += spl_net.o
>>> obj-$(CONFIG_$(SPL_TPL_)MMC_SUPPORT) += spl_mmc.o
>>> obj-$(CONFIG_$(SPL_TPL_)ATF) += spl_atf.o
>>> +obj-$(CONFIG_$(SPL_TPL_)OPTEE) += spl_optee.o
>>> obj-$(CONFIG_$(SPL_TPL_)USB_SUPPORT) += spl_usb.o
>>> obj-$(CONFIG_$(SPL_TPL_)FAT_SUPPORT) += spl_fat.o
>>> obj-$(CONFIG_$(SPL_TPL_)EXT_SUPPORT) += spl_ext.o
>>> diff --git a/common/spl/spl.c b/common/spl/spl.c
>>> index 76c1963..2c8942b 100644
>>> --- a/common/spl/spl.c
>>> +++ b/common/spl/spl.c
>>> @@ -436,6 +436,12 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
>>>        spl_invoke_atf(&spl_image);
>>>        break;
>>> #endif
>>> +#if CONFIG_IS_ENABLED(OPTEE)
>>> +    case IH_OS_OP_TEE:
>>> +        debug("Jumping to U-Boot via OP-TEE\n");
>>> +        spl_optee_entry(0, 0, 0, (void *)spl_image.entry_point);
>> 
>> Why are you passing '0' for "arg2, device tree address"? This should
>> be the device-tree pointer from the spl_image...
> 
> I will add dt pointer for entry next version.
>> 
>> Also: 0 is not the same as NULL ... the arguments are all defined to
>> have void* type, so 0 is not the correct type.
>> 
>>> +        break;
>>> +#endif
>>> #ifdef CONFIG_SPL_OS_BOOT
>>>    case IH_OS_LINUX:
>>>        debug("Jumping to Linux\n");
>>> @@ -450,6 +456,8 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
>>>    debug("SPL malloc() used %#lx bytes (%ld KB)\n", gd->malloc_ptr,
>>>          gd->malloc_ptr / 1024);
>>> #endif
>>> +
>>> +    debug("loaded - jumping to U-Boot...\n");
>>> #ifdef CONFIG_BOOTSTAGE_STASH
>>>    int ret;
>>> 
>>> diff --git a/common/spl/spl_optee.S b/common/spl/spl_optee.S
>>> new file mode 100644
>>> index 0000000..4f7f8ba
>>> --- /dev/null
>>> +++ b/common/spl/spl_optee.S
>>> @@ -0,0 +1,13 @@
>>> +/*
>>> + * Copyright (C) 2017 Rockchip Electronic Co.,Ltd
>>> + *
>>> + * SPDX-License-Identifier:    GPL-2.0+
>>> + */
>>> +
>>> +#include <linux/linkage.h>
>>> +#include <asm/assembler.h>
>>> +
>>> +ENTRY(spl_optee_entry)
>>> +    ldr lr, =CONFIG_SYS_TEXT_BASE
>>> +    mov pc, r3
>>> +ENDPROC(spl_optee_entry)
>>> diff --git a/include/spl.h b/include/spl.h
>>> index c14448b..551ce43 100644
>>> --- a/include/spl.h
>>> +++ b/include/spl.h
>>> @@ -288,6 +288,15 @@ int spl_mmc_load_image(struct spl_image_info *spl_image,
>>> void spl_invoke_atf(struct spl_image_info *spl_image);
>>> 
>>> /**
>>> + * spl_optee_entry - entry function for optee
>>> + * entry arg0, pagestore
>>> + * entry arg1, (ARMv7 standard bootarg #1)
>>> + * entry arg2, device tree address, (ARMv7 standard bootarg #2)
>>> + * entry arg3, non-secure entry address (ARMv7 bootarg #0)
>>> + */
>>> +void spl_optee_entry(void *arg0, void *arg1, void *arg2, void *arg3);
>> 
>> This doesn't look like a documentation comment for a U-Boot function.
>> Also: the purpose of arg0 and arg1 are not clear from this comment.
> 
> This is a copy from OP-TEE project, we only use the entry address now.
> https://github.com/OP-TEE/optee_os/blob/master/core/arch/arm/kernel/generic_entry_a32.S#L208 <https://github.com/OP-TEE/optee_os/blob/master/core/arch/arm/kernel/generic_entry_a32.S#L208>
You can add a back-reference to the original source (i.e. the link into the OP-TEE
GIT) as well, which may be a good idea so people know what this links up with.

However, you should reformat the comment here anyway:
(a)	U-Boot documentation should be consistent (automated tools may harvest
	the comments documenting our exposed functions)
(b)	The meaning of the arguments should be understandable to anyone reading
	the U-Boot source-code without referring to the source of OP-TEE.

Regards,
Philipp.

>>> +
>>> +/**
>>> * board_return_to_bootrom - allow for boards to continue with the boot ROM
>>> *
>>> * If a board (e.g. the Rockchip RK3368 boards) provide some

^ permalink raw reply	[flat|nested] 38+ messages in thread

end of thread, other threads:[~2018-01-04 10:48 UTC | newest]

Thread overview: 38+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-12-19  8:53 [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Kever Yang
2017-12-19  8:53 ` [U-Boot] [PATCH v3 01/11] lib: add TPL_OF_LIBFDT option for TPL Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:25   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 02/11] arm: add option for TPL ARCH_MEM in arm 32bit Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:25   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 03/11] arm: add a separate stack for TPL Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot,v3,03/11] " Philipp Tomsich
2018-01-02 17:25   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 04/11] rockchip: rk322x: enable tpl support Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:17   ` Philipp Tomsich
2018-01-04  2:52     ` Kever Yang
2017-12-19  8:53 ` [U-Boot] [PATCH v3 05/11] sysreset: enable driver support in SPL/TPL Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:25   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 06/11] image: add os type for OP-TEE Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot,v3,06/11] " Philipp Tomsich
2018-01-02 17:26   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 07/11] spl: add support to booting with OP-TEE Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:20   ` Philipp Tomsich
2018-01-04  3:51     ` Kever Yang
2018-01-04 10:48       ` Dr. Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 08/11] rockchip: rk322x: dts: enable uart2 for SPL/TPL Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:26   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 09/11] rockchip: add fit source file for pack itb with op-tee Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:26   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 10/11] rockchip: evb-rk3229: add README file for OP-TEE support Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:26   ` Philipp Tomsich
2017-12-19  8:53 ` [U-Boot] [PATCH v3 11/11] rockchip: evb-rk322x: update defconfig with tpl and optee support Kever Yang
2018-01-02 17:09   ` [U-Boot] [U-Boot, v3, " Philipp Tomsich
2018-01-02 17:26   ` Philipp Tomsich
2017-12-25 20:23 ` [U-Boot] [PATCH v3 00/11] rockchip: add tpl and OPTEE support for rk3229 Heiko Stuebner

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox