diff options
author | Nicolas Ferre <nicolas.ferre@atmel.com> | 2012-01-19 04:13:40 -0500 |
---|---|---|
committer | Nicolas Ferre <nicolas.ferre@atmel.com> | 2012-03-01 07:38:48 -0500 |
commit | 3a61a5dae49bf3d1afb7f75c8acb3607f26565af (patch) | |
tree | 53616025b0d6ff2af767b3f3ca62704774ce09e5 /drivers/misc/atmel_tclib.c | |
parent | 298312971b2fe8b922a1a15e0a6f5b4da89677d8 (diff) |
ARM: at91/tc: add device tree support to atmel_tclib
Device tree support added to atmel_tclib: the generic Timer Counter
library. This is used by the clocksource/clockevent driver tcb_clksrc.
The current DT enabled platforms are also modified to use it:
- .dtsi files are modified to add Timer Counter Block entries
- alias are created to allow identification of each block
- clkdev lookup tables are added for clocks identification.
Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Acked-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Acked-by: Grant Likely <grant.likely@secretlab.ca>
Diffstat (limited to 'drivers/misc/atmel_tclib.c')
-rw-r--r-- | drivers/misc/atmel_tclib.c | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/drivers/misc/atmel_tclib.c b/drivers/misc/atmel_tclib.c index 7a6512a148d4..de6dea7c5d52 100644 --- a/drivers/misc/atmel_tclib.c +++ b/drivers/misc/atmel_tclib.c | |||
@@ -6,8 +6,10 @@ | |||
6 | #include <linux/ioport.h> | 6 | #include <linux/ioport.h> |
7 | #include <linux/kernel.h> | 7 | #include <linux/kernel.h> |
8 | #include <linux/platform_device.h> | 8 | #include <linux/platform_device.h> |
9 | #include <linux/module.h> | ||
9 | #include <linux/slab.h> | 10 | #include <linux/slab.h> |
10 | #include <linux/export.h> | 11 | #include <linux/export.h> |
12 | #include <linux/of.h> | ||
11 | 13 | ||
12 | /* | 14 | /* |
13 | * This is a thin library to solve the problem of how to portably allocate | 15 | * This is a thin library to solve the problem of how to portably allocate |
@@ -48,7 +50,13 @@ struct atmel_tc *atmel_tc_alloc(unsigned block, const char *name) | |||
48 | 50 | ||
49 | spin_lock(&tc_list_lock); | 51 | spin_lock(&tc_list_lock); |
50 | list_for_each_entry(tc, &tc_list, node) { | 52 | list_for_each_entry(tc, &tc_list, node) { |
51 | if (tc->pdev->id == block) { | 53 | if (tc->pdev->dev.of_node) { |
54 | if (of_alias_get_id(tc->pdev->dev.of_node, "tcb") | ||
55 | == block) { | ||
56 | pdev = tc->pdev; | ||
57 | break; | ||
58 | } | ||
59 | } else if (tc->pdev->id == block) { | ||
52 | pdev = tc->pdev; | 60 | pdev = tc->pdev; |
53 | break; | 61 | break; |
54 | } | 62 | } |
@@ -105,6 +113,18 @@ void atmel_tc_free(struct atmel_tc *tc) | |||
105 | } | 113 | } |
106 | EXPORT_SYMBOL_GPL(atmel_tc_free); | 114 | EXPORT_SYMBOL_GPL(atmel_tc_free); |
107 | 115 | ||
116 | #if defined(CONFIG_OF) | ||
117 | static const struct of_device_id atmel_tcb_dt_ids[] = { | ||
118 | { | ||
119 | .compatible = "atmel,at91rm9200-tcb", | ||
120 | }, { | ||
121 | /* sentinel */ | ||
122 | } | ||
123 | }; | ||
124 | |||
125 | MODULE_DEVICE_TABLE(of, atmel_tcb_dt_ids); | ||
126 | #endif | ||
127 | |||
108 | static int __init tc_probe(struct platform_device *pdev) | 128 | static int __init tc_probe(struct platform_device *pdev) |
109 | { | 129 | { |
110 | struct atmel_tc *tc; | 130 | struct atmel_tc *tc; |
@@ -154,7 +174,10 @@ static int __init tc_probe(struct platform_device *pdev) | |||
154 | } | 174 | } |
155 | 175 | ||
156 | static struct platform_driver tc_driver = { | 176 | static struct platform_driver tc_driver = { |
157 | .driver.name = "atmel_tcb", | 177 | .driver = { |
178 | .name = "atmel_tcb", | ||
179 | .of_match_table = of_match_ptr(atmel_tcb_dt_ids), | ||
180 | }, | ||
158 | }; | 181 | }; |
159 | 182 | ||
160 | static int __init tc_init(void) | 183 | static int __init tc_init(void) |