2019-06-04 16:11:33 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2013-06-04 04:33:53 +08:00
|
|
|
/*
|
|
|
|
* linux/drivers/clocksource/dummy_timer.c
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013 ARM Ltd.
|
|
|
|
* All Rights Reserved
|
|
|
|
*/
|
|
|
|
#include <linux/clockchips.h>
|
|
|
|
#include <linux/cpu.h>
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/percpu.h>
|
|
|
|
#include <linux/cpumask.h>
|
|
|
|
|
|
|
|
static DEFINE_PER_CPU(struct clock_event_device, dummy_timer_evt);
|
|
|
|
|
2016-07-14 01:16:41 +08:00
|
|
|
static int dummy_timer_starting_cpu(unsigned int cpu)
|
2013-06-04 04:33:53 +08:00
|
|
|
{
|
2016-07-14 01:16:41 +08:00
|
|
|
struct clock_event_device *evt = per_cpu_ptr(&dummy_timer_evt, cpu);
|
2013-06-04 04:33:53 +08:00
|
|
|
|
|
|
|
evt->name = "dummy_timer";
|
|
|
|
evt->features = CLOCK_EVT_FEAT_PERIODIC |
|
|
|
|
CLOCK_EVT_FEAT_ONESHOT |
|
|
|
|
CLOCK_EVT_FEAT_DUMMY;
|
|
|
|
evt->rating = 100;
|
|
|
|
evt->cpumask = cpumask_of(cpu);
|
|
|
|
|
|
|
|
clockevents_register_device(evt);
|
2016-07-14 01:16:41 +08:00
|
|
|
return 0;
|
2013-06-04 04:33:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static int __init dummy_timer_register(void)
|
|
|
|
{
|
2016-07-14 01:16:41 +08:00
|
|
|
return cpuhp_setup_state(CPUHP_AP_DUMMY_TIMER_STARTING,
|
2016-12-22 03:19:54 +08:00
|
|
|
"clockevents/dummy_timer:starting",
|
2016-07-14 01:16:41 +08:00
|
|
|
dummy_timer_starting_cpu, NULL);
|
2013-06-04 04:33:53 +08:00
|
|
|
}
|
|
|
|
early_initcall(dummy_timer_register);
|