aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/plat-pxa
diff options
context:
space:
mode:
authorDaniel Mack <zonque@gmail.com>2013-08-12 04:37:18 -0400
committerMark Brown <broonie@linaro.org>2013-08-14 14:54:30 -0400
commit6446221c14ef3bf58754cf1948631128dbe62700 (patch)
tree85b98c217d9528e1a1771f8599875c4814a3b1db /arch/arm/plat-pxa
parent1c459de1e645b213a07b9492884a54f5861409f5 (diff)
ARM: pxa: ssp: add pxa_ssp_request_of()
Add a function to lookup ssp devices from device tree. This way, users can reference the ssp devices in order to register to them. Signed-off-by: Daniel Mack <zonque@gmail.com> Acked-by: Haojian Zhuang <haojian.zhuang@gmail.com> Signed-off-by: Mark Brown <broonie@linaro.org>
Diffstat (limited to 'arch/arm/plat-pxa')
-rw-r--r--arch/arm/plat-pxa/ssp.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/arch/arm/plat-pxa/ssp.c b/arch/arm/plat-pxa/ssp.c
index f2661355fa4e..c83f27b6bdda 100644
--- a/arch/arm/plat-pxa/ssp.c
+++ b/arch/arm/plat-pxa/ssp.c
@@ -62,6 +62,30 @@ struct ssp_device *pxa_ssp_request(int port, const char *label)
62} 62}
63EXPORT_SYMBOL(pxa_ssp_request); 63EXPORT_SYMBOL(pxa_ssp_request);
64 64
65struct ssp_device *pxa_ssp_request_of(const struct device_node *of_node,
66 const char *label)
67{
68 struct ssp_device *ssp = NULL;
69
70 mutex_lock(&ssp_lock);
71
72 list_for_each_entry(ssp, &ssp_list, node) {
73 if (ssp->of_node == of_node && ssp->use_count == 0) {
74 ssp->use_count++;
75 ssp->label = label;
76 break;
77 }
78 }
79
80 mutex_unlock(&ssp_lock);
81
82 if (&ssp->node == &ssp_list)
83 return NULL;
84
85 return ssp;
86}
87EXPORT_SYMBOL(pxa_ssp_request_of);
88
65void pxa_ssp_free(struct ssp_device *ssp) 89void pxa_ssp_free(struct ssp_device *ssp)
66{ 90{
67 mutex_lock(&ssp_lock); 91 mutex_lock(&ssp_lock);
@@ -185,6 +209,7 @@ static int pxa_ssp_probe(struct platform_device *pdev)
185 } 209 }
186 210
187 ssp->use_count = 0; 211 ssp->use_count = 0;
212 ssp->of_node = dev->of_node;
188 213
189 mutex_lock(&ssp_lock); 214 mutex_lock(&ssp_lock);
190 list_add(&ssp->node, &ssp_list); 215 list_add(&ssp->node, &ssp_list);