162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * omap2-restart.c - code common to all OMAP2xxx machines.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2012 Texas Instruments
662306a36Sopenharmony_ci * Paul Walmsley
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci#include <linux/kernel.h>
962306a36Sopenharmony_ci#include <linux/init.h>
1062306a36Sopenharmony_ci#include <linux/clk.h>
1162306a36Sopenharmony_ci#include <linux/io.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include "soc.h"
1462306a36Sopenharmony_ci#include "common.h"
1562306a36Sopenharmony_ci#include "prm.h"
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci/*
1862306a36Sopenharmony_ci * reset_virt_prcm_set_ck, reset_sys_ck: pointers to the virt_prcm_set
1962306a36Sopenharmony_ci * clock and the sys_ck.  Used during the reset process
2062306a36Sopenharmony_ci */
2162306a36Sopenharmony_cistatic struct clk *reset_virt_prcm_set_ck, *reset_sys_ck;
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci/* Reboot handling */
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci/**
2662306a36Sopenharmony_ci * omap2xxx_restart - Set DPLL to bypass mode for reboot to work
2762306a36Sopenharmony_ci *
2862306a36Sopenharmony_ci * Set the DPLL to bypass so that reboot completes successfully.  No
2962306a36Sopenharmony_ci * return value.
3062306a36Sopenharmony_ci */
3162306a36Sopenharmony_civoid omap2xxx_restart(enum reboot_mode mode, const char *cmd)
3262306a36Sopenharmony_ci{
3362306a36Sopenharmony_ci	u32 rate;
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci	rate = clk_get_rate(reset_sys_ck);
3662306a36Sopenharmony_ci	clk_set_rate(reset_virt_prcm_set_ck, rate);
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci	/* XXX Should save the cmd argument for use after the reboot */
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci	omap_prm_reset_system();
4162306a36Sopenharmony_ci}
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci/**
4462306a36Sopenharmony_ci * omap2xxx_common_look_up_clks_for_reset - look up clocks needed for restart
4562306a36Sopenharmony_ci *
4662306a36Sopenharmony_ci * Some clocks need to be looked up in advance for the SoC restart
4762306a36Sopenharmony_ci * operation to work - see omap2xxx_restart().  Returns -EINVAL upon
4862306a36Sopenharmony_ci * error or 0 upon success.
4962306a36Sopenharmony_ci */
5062306a36Sopenharmony_cistatic int __init omap2xxx_common_look_up_clks_for_reset(void)
5162306a36Sopenharmony_ci{
5262306a36Sopenharmony_ci	reset_virt_prcm_set_ck = clk_get(NULL, "virt_prcm_set");
5362306a36Sopenharmony_ci	if (IS_ERR(reset_virt_prcm_set_ck))
5462306a36Sopenharmony_ci		return -EINVAL;
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ci	reset_sys_ck = clk_get(NULL, "sys_ck");
5762306a36Sopenharmony_ci	if (IS_ERR(reset_sys_ck))
5862306a36Sopenharmony_ci		return -EINVAL;
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci	return 0;
6162306a36Sopenharmony_ci}
6262306a36Sopenharmony_ciomap_postcore_initcall(omap2xxx_common_look_up_clks_for_reset);
63