Skip to content
Snippets Groups Projects
Commit 3159a6fc authored by Philipp Tomsich's avatar Philipp Tomsich
Browse files

rockchip: rk3368: remove setup of secure timer from TPL/SPL


When using DM timers w/ the timer0 block within the RK3368, we no
longer depend on the ARMv8 generic timer counting.  This allows us to
drop the secure timer initialisation from the TPL and SPL stages.

The secure timer will later be set up by ATF, which starts the ARMv8
generic timer.  Thus, there will be a dependency from Linux to the ATF
through the ARMv8 generic timer... this seems reasonable, as Linux
will require the ATF (and PSCI) to start up the secondary cores anyway
(in other words: we don't add any new dependencies).

Signed-off-by: default avatarPhilipp Tomsich <philipp.tomsich@theobroma-systems.com>
Reviewed-by: default avatarSimon Glass <sjg@chromium.org>
parent fe1c3cd3
No related branches found
No related tags found
No related merge requests found
...@@ -19,23 +19,6 @@ ...@@ -19,23 +19,6 @@
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
/*
* The ARMv8 generic timer uses the STIMER1 as its clock-source.
* Set up the STIMER1 to free-running (i.e. auto-reload) to start
* the generic timer counting (if we don't do this, udelay will not
* work and block indefinitively).
*/
static void secure_timer_init(void)
{
struct rk_timer * const stimer1 =
(struct rk_timer * const)0xff830020;
const u32 TIMER_EN = BIT(0);
writel(~0u, &stimer1->timer_load_count0);
writel(~0u, &stimer1->timer_load_count1);
writel(TIMER_EN, &stimer1->timer_ctrl_reg);
}
void board_debug_uart_init(void) void board_debug_uart_init(void)
{ {
} }
...@@ -52,9 +35,6 @@ void board_init_f(ulong dummy) ...@@ -52,9 +35,6 @@ void board_init_f(ulong dummy)
hang(); hang();
} }
/* Make sure the ARMv8 generic timer counts */
secure_timer_init();
/* Set up our preloader console */ /* Set up our preloader console */
ret = uclass_get_device(UCLASS_PINCTRL, 0, &pinctrl); ret = uclass_get_device(UCLASS_PINCTRL, 0, &pinctrl);
if (ret) { if (ret) {
......
...@@ -20,23 +20,6 @@ ...@@ -20,23 +20,6 @@
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
/*
* The ARMv8 generic timer uses the STIMER1 as its clock-source.
* Set up the STIMER1 to free-running (i.e. auto-reload) to start
* the generic timer counting (if we don't do this, udelay will not
* work and block indefinitively).
*/
static void secure_timer_init(void)
{
struct rk_timer * const stimer1 =
(struct rk_timer * const)0xff830020;
const u32 TIMER_EN = BIT(0);
writel(~0u, &stimer1->timer_load_count0);
writel(~0u, &stimer1->timer_load_count1);
writel(TIMER_EN, &stimer1->timer_ctrl_reg);
}
/* /*
* The SPL (and also the full U-Boot stage on the RK3368) will run in * The SPL (and also the full U-Boot stage on the RK3368) will run in
* secure mode (i.e. EL3) and an ATF will eventually be booted before * secure mode (i.e. EL3) and an ATF will eventually be booted before
...@@ -153,8 +136,6 @@ void board_init_f(ulong dummy) ...@@ -153,8 +136,6 @@ void board_init_f(ulong dummy)
hang(); hang();
} }
/* Make sure the ARMv8 generic timer counts */
secure_timer_init();
/* Reset security, so we can use DMA in the MMC drivers */ /* Reset security, so we can use DMA in the MMC drivers */
sgrf_init(); sgrf_init();
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment