blob: 1b6fa66491e2ce329bb776b98ea51a2092181fd5 [file] [log] [blame]
Thomas Gleixner16216332019-05-19 15:51:31 +02001// SPDX-License-Identifier: GPL-2.0-or-later
Yoichi Yuasa1097c6a2007-10-22 19:43:15 +09002/*
3 * Cobalt time initialization.
4 *
Yoichi Yuasaada8e952009-07-03 00:39:38 +09005 * Copyright (C) 2007 Yoichi Yuasa <yuasa@linux-mips.org>
Yoichi Yuasa1097c6a2007-10-22 19:43:15 +09006 */
Ralf Baechle334955e2011-06-01 19:04:57 +01007#include <linux/i8253.h>
Yoichi Yuasa1097c6a2007-10-22 19:43:15 +09008#include <linux/init.h>
9
10#include <asm/gt64120.h>
Yoichi Yuasa1097c6a2007-10-22 19:43:15 +090011#include <asm/time.h>
12
13#define GT641XX_BASE_CLOCK 50000000 /* 50MHz */
14
15void __init plat_time_init(void)
16{
Yoichi Yuasa18ca38d2007-12-09 21:22:04 +090017 u32 start, end;
18 int i = HZ / 10;
19
Yoichi Yuasa1097c6a2007-10-22 19:43:15 +090020 setup_pit_timer();
21
22 gt641xx_set_base_clock(GT641XX_BASE_CLOCK);
23
Yoichi Yuasa18ca38d2007-12-09 21:22:04 +090024 /*
25 * MIPS counter frequency is measured during a 100msec interval
26 * using GT64111 timer0.
27 */
28 while (!gt641xx_timer0_state())
29 ;
30
31 start = read_c0_count();
32
33 while (i--)
34 while (!gt641xx_timer0_state())
35 ;
36
37 end = read_c0_count();
38
39 mips_hpt_frequency = (end - start) * 10;
40 printk(KERN_INFO "MIPS counter frequency %dHz\n", mips_hpt_frequency);
Yoichi Yuasa1097c6a2007-10-22 19:43:15 +090041}