blob: 821a09cbd6054f6d089d6f3062531b7325a7135d [file] [log] [blame]
David Brazdil0f672f62019-12-10 10:32:29 +00001// SPDX-License-Identifier: GPL-2.0
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00002/*
3 * arch/sh/kernel/time.c
4 *
5 * Copyright (C) 1999 Tetsuya Okada & Niibe Yutaka
6 * Copyright (C) 2000 Philipp Rumpf <prumpf@tux.org>
7 * Copyright (C) 2002 - 2009 Paul Mundt
8 * Copyright (C) 2002 M. R. Brown <mrbrown@linux-sh.org>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00009 */
10#include <linux/kernel.h>
11#include <linux/init.h>
12#include <linux/profile.h>
13#include <linux/timex.h>
14#include <linux/sched.h>
15#include <linux/clockchips.h>
16#include <linux/platform_device.h>
17#include <linux/smp.h>
18#include <linux/rtc.h>
19#include <asm/clock.h>
20#include <asm/rtc.h>
Olivier Deprez157378f2022-04-04 15:47:50 +020021#include <asm/platform_early.h>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000022
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000023static void __init sh_late_time_init(void)
24{
25 /*
26 * Make sure all compiled-in early timers register themselves.
27 *
28 * Run probe() for two "earlytimer" devices, these will be the
29 * clockevents and clocksource devices respectively. In the event
30 * that only a clockevents device is available, we -ENODEV on the
31 * clocksource and the jiffies clocksource is used transparently
32 * instead. No error handling is necessary here.
33 */
Olivier Deprez157378f2022-04-04 15:47:50 +020034 sh_early_platform_driver_register_all("earlytimer");
35 sh_early_platform_driver_probe("earlytimer", 2, 0);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000036}
37
38void __init time_init(void)
39{
David Brazdil0f672f62019-12-10 10:32:29 +000040 timer_probe();
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000041
42 clk_init();
43
44 late_time_init = sh_late_time_init;
45}