mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-25 08:39:46 +07:00
15f0c8f2f3
Enable common clk framework for DT-based boards and disable code that depends on the legacy sh clk framework when common clk is enabled. Once legacy drivers are converted over, the old code can be removed entirely. Signed-off-by: Rich Felker <dalias@libc.org>
56 lines
1.2 KiB
C
56 lines
1.2 KiB
C
/*
|
|
* arch/sh/kernel/cpu/clock.c - SuperH clock framework
|
|
*
|
|
* Copyright (C) 2005 - 2009 Paul Mundt
|
|
*
|
|
* This clock framework is derived from the OMAP version by:
|
|
*
|
|
* Copyright (C) 2004 - 2008 Nokia Corporation
|
|
* Written by Tuukka Tikkanen <tuukka.tikkanen@elektrobit.com>
|
|
*
|
|
* Modified for omap shared clock framework by Tony Lindgren <tony@atomide.com>
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*/
|
|
#include <linux/kernel.h>
|
|
#include <linux/init.h>
|
|
#include <linux/clk.h>
|
|
#include <asm/clock.h>
|
|
#include <asm/machvec.h>
|
|
|
|
int __init clk_init(void)
|
|
{
|
|
int ret;
|
|
|
|
#ifndef CONFIG_COMMON_CLK
|
|
ret = arch_clk_init();
|
|
if (unlikely(ret)) {
|
|
pr_err("%s: CPU clock registration failed.\n", __func__);
|
|
return ret;
|
|
}
|
|
#endif
|
|
|
|
if (sh_mv.mv_clk_init) {
|
|
ret = sh_mv.mv_clk_init();
|
|
if (unlikely(ret)) {
|
|
pr_err("%s: machvec clock initialization failed.\n",
|
|
__func__);
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
#ifndef CONFIG_COMMON_CLK
|
|
/* Kick the child clocks.. */
|
|
recalculate_root_clocks();
|
|
|
|
/* Enable the necessary init clocks */
|
|
clk_enable_init_clocks();
|
|
#endif
|
|
|
|
return ret;
|
|
}
|
|
|
|
|