aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/plat-versatile/localtimer.c
blob: e156687931597d4800ec8ac97bd0fdc26754f0c1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/*
 *  linux/arch/arm/plat-versatile/localtimer.c
 *
 *  Copyright (C) 2002 ARM Ltd.
 *  All Rights Reserved
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#include <linux/init.h>
#include <linux/smp.h>
#include <linux/clockchips.h>
#include <linux/of.h>
#include <linux/of_address.h>

#include <asm/smp_twd.h>
#include <asm/localtimer.h>
#include <mach/irqs.h>

const static struct of_device_id twd_of_match[] __initconst = {
       { .compatible = "arm,cortex-a9-twd-timer",      },
       { .compatible = "arm,cortex-a5-twd-timer",      },
       { .compatible = "arm,arm11mp-twd-timer",        },
       { },
};

/*
 * Setup the local clock events for a CPU.
 */
int __cpuinit local_timer_setup(struct clock_event_device *evt)
{
#if defined(CONFIG_OF)
	static int dt_node_probed;

	/* Look for TWD node only once */
	if (!dt_node_probed) {
		struct device_node *node = of_find_matching_node(NULL,
				twd_of_match);

		if (node)
			twd_base = of_iomap(node, 0);

		dt_node_probed = 1;
	}
#endif
	if (!twd_base)
		return -ENXIO;

	evt->irq = IRQ_LOCALTIMER;
	twd_timer_setup(evt);
	return 0;
}