[POWERPC] Move of_device_get_modalias to drivers/of
Commit 140b932f8c
("Create modalias file
in sysfs for of_platform bus") needs this to avoid breaking the sparc
builds.
Just move the code and add whitespace around some binary operators.
Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
Acked-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:

committed by
Paul Mackerras

parent
7bc228b1ef
commit
09e67ca2c5
@@ -89,54 +89,6 @@ struct of_device *of_device_alloc(struct device_node *np,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(of_device_alloc);
|
EXPORT_SYMBOL(of_device_alloc);
|
||||||
|
|
||||||
ssize_t of_device_get_modalias(struct of_device *ofdev,
|
|
||||||
char *str, ssize_t len)
|
|
||||||
{
|
|
||||||
const char *compat;
|
|
||||||
int cplen, i;
|
|
||||||
ssize_t tsize, csize, repend;
|
|
||||||
|
|
||||||
/* Name & Type */
|
|
||||||
csize = snprintf(str, len, "of:N%sT%s",
|
|
||||||
ofdev->node->name, ofdev->node->type);
|
|
||||||
|
|
||||||
/* Get compatible property if any */
|
|
||||||
compat = of_get_property(ofdev->node, "compatible", &cplen);
|
|
||||||
if (!compat)
|
|
||||||
return csize;
|
|
||||||
|
|
||||||
/* Find true end (we tolerate multiple \0 at the end */
|
|
||||||
for (i=(cplen-1); i>=0 && !compat[i]; i--)
|
|
||||||
cplen--;
|
|
||||||
if (!cplen)
|
|
||||||
return csize;
|
|
||||||
cplen++;
|
|
||||||
|
|
||||||
/* Check space (need cplen+1 chars including final \0) */
|
|
||||||
tsize = csize + cplen;
|
|
||||||
repend = tsize;
|
|
||||||
|
|
||||||
if (csize>=len) /* @ the limit, all is already filled */
|
|
||||||
return tsize;
|
|
||||||
|
|
||||||
if (tsize>=len) { /* limit compat list */
|
|
||||||
cplen = len-csize-1;
|
|
||||||
repend = len;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Copy and do char replacement */
|
|
||||||
memcpy(&str[csize+1], compat, cplen);
|
|
||||||
for (i=csize; i<repend; i++) {
|
|
||||||
char c = str[i];
|
|
||||||
if (c=='\0')
|
|
||||||
str[i] = 'C';
|
|
||||||
else if (c==' ')
|
|
||||||
str[i] = '_';
|
|
||||||
}
|
|
||||||
|
|
||||||
return tsize;
|
|
||||||
}
|
|
||||||
|
|
||||||
int of_device_uevent(struct device *dev, struct kobj_uevent_env *env)
|
int of_device_uevent(struct device *dev, struct kobj_uevent_env *env)
|
||||||
{
|
{
|
||||||
struct of_device *ofdev;
|
struct of_device *ofdev;
|
||||||
|
@@ -104,3 +104,51 @@ void of_device_unregister(struct of_device *ofdev)
|
|||||||
device_unregister(&ofdev->dev);
|
device_unregister(&ofdev->dev);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(of_device_unregister);
|
EXPORT_SYMBOL(of_device_unregister);
|
||||||
|
|
||||||
|
ssize_t of_device_get_modalias(struct of_device *ofdev,
|
||||||
|
char *str, ssize_t len)
|
||||||
|
{
|
||||||
|
const char *compat;
|
||||||
|
int cplen, i;
|
||||||
|
ssize_t tsize, csize, repend;
|
||||||
|
|
||||||
|
/* Name & Type */
|
||||||
|
csize = snprintf(str, len, "of:N%sT%s",
|
||||||
|
ofdev->node->name, ofdev->node->type);
|
||||||
|
|
||||||
|
/* Get compatible property if any */
|
||||||
|
compat = of_get_property(ofdev->node, "compatible", &cplen);
|
||||||
|
if (!compat)
|
||||||
|
return csize;
|
||||||
|
|
||||||
|
/* Find true end (we tolerate multiple \0 at the end */
|
||||||
|
for (i = (cplen - 1); i >= 0 && !compat[i]; i--)
|
||||||
|
cplen--;
|
||||||
|
if (!cplen)
|
||||||
|
return csize;
|
||||||
|
cplen++;
|
||||||
|
|
||||||
|
/* Check space (need cplen+1 chars including final \0) */
|
||||||
|
tsize = csize + cplen;
|
||||||
|
repend = tsize;
|
||||||
|
|
||||||
|
if (csize >= len) /* @ the limit, all is already filled */
|
||||||
|
return tsize;
|
||||||
|
|
||||||
|
if (tsize >= len) { /* limit compat list */
|
||||||
|
cplen = len - csize - 1;
|
||||||
|
repend = len;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Copy and do char replacement */
|
||||||
|
memcpy(&str[csize + 1], compat, cplen);
|
||||||
|
for (i = csize; i < repend; i++) {
|
||||||
|
char c = str[i];
|
||||||
|
if (c == '\0')
|
||||||
|
str[i] = 'C';
|
||||||
|
else if (c == ' ')
|
||||||
|
str[i] = '_';
|
||||||
|
}
|
||||||
|
|
||||||
|
return tsize;
|
||||||
|
}
|
||||||
|
@@ -21,8 +21,6 @@ extern struct of_device *of_device_alloc(struct device_node *np,
|
|||||||
const char *bus_id,
|
const char *bus_id,
|
||||||
struct device *parent);
|
struct device *parent);
|
||||||
|
|
||||||
extern ssize_t of_device_get_modalias(struct of_device *ofdev,
|
|
||||||
char *str, ssize_t len);
|
|
||||||
extern int of_device_uevent(struct device *dev,
|
extern int of_device_uevent(struct device *dev,
|
||||||
struct kobj_uevent_env *env);
|
struct kobj_uevent_env *env);
|
||||||
|
|
||||||
|
@@ -24,4 +24,7 @@ static inline void of_device_free(struct of_device *dev)
|
|||||||
of_release_dev(&dev->dev);
|
of_release_dev(&dev->dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern ssize_t of_device_get_modalias(struct of_device *ofdev,
|
||||||
|
char *str, ssize_t len);
|
||||||
|
|
||||||
#endif /* _LINUX_OF_DEVICE_H */
|
#endif /* _LINUX_OF_DEVICE_H */
|
||||||
|
Reference in New Issue
Block a user