blob: 74fb74583b4e7e83eec6fdb7d328be7436dd4398 [file] [log] [blame]
Ralf Baechle940f6b42007-11-24 22:33:28 +00001/*
2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
4 * for more details.
5 *
6 * Copyright (C) 2007 by Ralf Baechle
7 */
Ralf Baechlee6a1bb72007-11-28 15:07:42 +00008#include <linux/clocksource.h>
9#include <linux/init.h>
10
11#include <asm/time.h>
Ralf Baechle940f6b42007-11-24 22:33:28 +000012
13static cycle_t c0_hpt_read(void)
14{
15 return read_c0_count();
16}
17
18static struct clocksource clocksource_mips = {
19 .name = "MIPS",
20 .read = c0_hpt_read,
21 .mask = CLOCKSOURCE_MASK(32),
22 .flags = CLOCK_SOURCE_IS_CONTINUOUS,
23};
24
Ralf Baechle69e634f2008-03-12 13:58:10 +000025int __init init_mips_clocksource(void)
Ralf Baechle940f6b42007-11-24 22:33:28 +000026{
Ralf Baechle69e634f2008-03-12 13:58:10 +000027 if (!cpu_has_counter || !mips_hpt_frequency)
28 return -ENXIO;
29
Ralf Baechle664c4bb2008-11-03 11:31:54 +000030 /* Calculate a somewhat reasonable rating value */
Ralf Baechle940f6b42007-11-24 22:33:28 +000031 clocksource_mips.rating = 200 + mips_hpt_frequency / 10000000;
32
33 clocksource_set_clock(&clocksource_mips, mips_hpt_frequency);
34
35 clocksource_register(&clocksource_mips);
Ralf Baechle69e634f2008-03-12 13:58:10 +000036
37 return 0;
Ralf Baechle940f6b42007-11-24 22:33:28 +000038}