aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/of/device.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/of/device.c')
-rw-r--r--drivers/of/device.c16
1 files changed, 6 insertions, 10 deletions
diff --git a/drivers/of/device.c b/drivers/of/device.c
index 275cc9cee14c..c2a98f5ca80d 100644
--- a/drivers/of/device.c
+++ b/drivers/of/device.c
@@ -68,10 +68,7 @@ static ssize_t name_show(struct device *dev,
68static ssize_t modalias_show(struct device *dev, 68static ssize_t modalias_show(struct device *dev,
69 struct device_attribute *attr, char *buf) 69 struct device_attribute *attr, char *buf)
70{ 70{
71 struct of_device *ofdev = to_of_device(dev); 71 ssize_t len = of_device_get_modalias(dev, buf, PAGE_SIZE - 2);
72 ssize_t len = 0;
73
74 len = of_device_get_modalias(ofdev, buf, PAGE_SIZE - 2);
75 buf[len] = '\n'; 72 buf[len] = '\n';
76 buf[len+1] = 0; 73 buf[len+1] = 0;
77 return len+1; 74 return len+1;
@@ -123,19 +120,18 @@ void of_device_unregister(struct of_device *ofdev)
123} 120}
124EXPORT_SYMBOL(of_device_unregister); 121EXPORT_SYMBOL(of_device_unregister);
125 122
126ssize_t of_device_get_modalias(struct of_device *ofdev, 123ssize_t of_device_get_modalias(struct device *dev, char *str, ssize_t len)
127 char *str, ssize_t len)
128{ 124{
129 const char *compat; 125 const char *compat;
130 int cplen, i; 126 int cplen, i;
131 ssize_t tsize, csize, repend; 127 ssize_t tsize, csize, repend;
132 128
133 /* Name & Type */ 129 /* Name & Type */
134 csize = snprintf(str, len, "of:N%sT%s", ofdev->dev.of_node->name, 130 csize = snprintf(str, len, "of:N%sT%s", dev->of_node->name,
135 ofdev->dev.of_node->type); 131 dev->of_node->type);
136 132
137 /* Get compatible property if any */ 133 /* Get compatible property if any */
138 compat = of_get_property(ofdev->dev.of_node, "compatible", &cplen); 134 compat = of_get_property(dev->of_node, "compatible", &cplen);
139 if (!compat) 135 if (!compat)
140 return csize; 136 return csize;
141 137
@@ -210,7 +206,7 @@ int of_device_uevent(struct device *dev, struct kobj_uevent_env *env)
210 if (add_uevent_var(env, "MODALIAS=")) 206 if (add_uevent_var(env, "MODALIAS="))
211 return -ENOMEM; 207 return -ENOMEM;
212 208
213 sl = of_device_get_modalias(to_of_device(dev), &env->buf[env->buflen-1], 209 sl = of_device_get_modalias(dev, &env->buf[env->buflen-1],
214 sizeof(env->buf) - env->buflen); 210 sizeof(env->buf) - env->buflen);
215 if (sl >= (sizeof(env->buf) - env->buflen)) 211 if (sl >= (sizeof(env->buf) - env->buflen))
216 return -ENOMEM; 212 return -ENOMEM;