blob: 4a889f0e3422fc1261f37bc37c7a52161cc32d26 [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>
Tom Warrenab371962012-09-19 15:50:56 -070028#include <asm/arch/tegra.h>
29#include <asm/arch-tegra/pmc.h>
Stephen Warren3c7643c2012-06-04 09:23:55 +000030
31static int do_enterrcm(cmd_tbl_t *cmdtp, int flag, int argc,
32 char * const argv[])
33{
Stephen Warren3c7643c2012-06-04 09:23:55 +000034 puts("Entering RCM...\n");
35 udelay(50000);
36
Thierry Redingce7eb162019-04-15 11:32:25 +020037 tegra_pmc_writel(2, PMC_SCRATCH0);
Stephen Warren3c7643c2012-06-04 09:23:55 +000038 disable_interrupts();
39 reset_cpu(0);
40
41 return 0;
42}
43
44U_BOOT_CMD(
45 enterrcm, 1, 0, do_enterrcm,
46 "reset Tegra and enter USB Recovery Mode",
47 ""
48);