blob: b2252f3621918a57e965992189c4e8f280678cd9 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Stephen Warren3c7643c2012-06-04 09:23:55 +00002/*
Thierry Redingce7eb162019-04-15 11:32:25 +02003 * Copyright (c) 2012-2019, NVIDIA CORPORATION. All rights reserved.
Stephen Warren3c7643c2012-06-04 09:23:55 +00004 *
5 * Derived from code (arch/arm/lib/reset.c) that is:
6 *
7 * (C) Copyright 2002
8 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
9 * Marius Groeger <mgroeger@sysgo.de>
10 *
11 * (C) Copyright 2002
12 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
13 * Alex Zuepke <azu@sysgo.de>
14 *
15 * (C) Copyright 2002
16 * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de>
17 *
18 * (C) Copyright 2004
19 * DAVE Srl
20 * http://www.dave-tech.it
21 * http://www.wawnet.biz
22 * mailto:info@wawnet.biz
23 *
24 * (C) Copyright 2004 Texas Insturments
Stephen Warren3c7643c2012-06-04 09:23:55 +000025 */
26
27#include <common.h>
Simon Glassafb02152019-12-28 10:45:01 -070028#include <cpu_func.h>
Simon Glass8f3f7612019-11-14 12:57:42 -070029#include <irq_func.h>
Tom Warrenab371962012-09-19 15:50:56 -070030#include <asm/arch/tegra.h>
31#include <asm/arch-tegra/pmc.h>
Stephen Warren3c7643c2012-06-04 09:23:55 +000032
33static int do_enterrcm(cmd_tbl_t *cmdtp, int flag, int argc,
34 char * const argv[])
35{
Stephen Warren3c7643c2012-06-04 09:23:55 +000036 puts("Entering RCM...\n");
37 udelay(50000);
38
Thierry Redingce7eb162019-04-15 11:32:25 +020039 tegra_pmc_writel(2, PMC_SCRATCH0);
Stephen Warren3c7643c2012-06-04 09:23:55 +000040 disable_interrupts();
41 reset_cpu(0);
42
43 return 0;
44}
45
46U_BOOT_CMD(
47 enterrcm, 1, 0, do_enterrcm,
48 "reset Tegra and enter USB Recovery Mode",
49 ""
50);