ALSA: aoa: Remove direct OF name and type accesses
Convert soundbus uevent and sysfs OF node name and device type usage to use printf specifier and helper functions instead of directly accessing the name and type pointers. This will allow the eventual removal of the pointers. Signed-off-by: Rob Herring <robh@kernel.org> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
917bb90c65
commit
192a712295
@ -74,7 +74,7 @@ static int soundbus_uevent(struct device *dev, struct kobj_uevent_env *env)
|
|||||||
of = &soundbus_dev->ofdev;
|
of = &soundbus_dev->ofdev;
|
||||||
|
|
||||||
/* stuff we want to pass to /sbin/hotplug */
|
/* stuff we want to pass to /sbin/hotplug */
|
||||||
retval = add_uevent_var(env, "OF_NAME=%s", of->dev.of_node->name);
|
retval = add_uevent_var(env, "OF_NAME=%pOFn", of->dev.of_node);
|
||||||
if (retval)
|
if (retval)
|
||||||
return retval;
|
return retval;
|
||||||
|
|
||||||
|
@ -1,18 +1,10 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/of.h>
|
||||||
#include <linux/stat.h>
|
#include <linux/stat.h>
|
||||||
/* FIX UP */
|
/* FIX UP */
|
||||||
#include "soundbus.h"
|
#include "soundbus.h"
|
||||||
|
|
||||||
#define soundbus_config_of_attr(field, format_string) \
|
|
||||||
static ssize_t \
|
|
||||||
field##_show (struct device *dev, struct device_attribute *attr, \
|
|
||||||
char *buf) \
|
|
||||||
{ \
|
|
||||||
struct soundbus_dev *mdev = to_soundbus_device (dev); \
|
|
||||||
return sprintf (buf, format_string, mdev->ofdev.dev.of_node->field); \
|
|
||||||
}
|
|
||||||
|
|
||||||
static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
|
static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
|
||||||
char *buf)
|
char *buf)
|
||||||
{
|
{
|
||||||
@ -25,17 +17,33 @@ static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
|
|||||||
strcat(buf, "\n");
|
strcat(buf, "\n");
|
||||||
length = strlen(buf);
|
length = strlen(buf);
|
||||||
} else {
|
} else {
|
||||||
length = sprintf(buf, "of:N%sT%s\n",
|
length = sprintf(buf, "of:N%pOFn%c%s\n",
|
||||||
of->dev.of_node->name, of->dev.of_node->type);
|
of->dev.of_node, 'T',
|
||||||
|
of_node_get_device_type(of->dev.of_node));
|
||||||
}
|
}
|
||||||
|
|
||||||
return length;
|
return length;
|
||||||
}
|
}
|
||||||
static DEVICE_ATTR_RO(modalias);
|
static DEVICE_ATTR_RO(modalias);
|
||||||
|
|
||||||
soundbus_config_of_attr (name, "%s\n");
|
static ssize_t name_show(struct device *dev,
|
||||||
|
struct device_attribute *attr, char *buf)
|
||||||
|
{
|
||||||
|
struct soundbus_dev *sdev = to_soundbus_device(dev);
|
||||||
|
struct platform_device *of = &sdev->ofdev;
|
||||||
|
|
||||||
|
return sprintf(buf, "%pOFn\n", of->dev.of_node);
|
||||||
|
}
|
||||||
static DEVICE_ATTR_RO(name);
|
static DEVICE_ATTR_RO(name);
|
||||||
soundbus_config_of_attr (type, "%s\n");
|
|
||||||
|
static ssize_t type_show(struct device *dev,
|
||||||
|
struct device_attribute *attr, char *buf)
|
||||||
|
{
|
||||||
|
struct soundbus_dev *sdev = to_soundbus_device(dev);
|
||||||
|
struct platform_device *of = &sdev->ofdev;
|
||||||
|
|
||||||
|
return sprintf(buf, "%s\n", of_node_get_device_type(of->dev.of_node));
|
||||||
|
}
|
||||||
static DEVICE_ATTR_RO(type);
|
static DEVICE_ATTR_RO(type);
|
||||||
|
|
||||||
struct attribute *soundbus_dev_attrs[] = {
|
struct attribute *soundbus_dev_attrs[] = {
|
||||||
|
Loading…
Reference in New Issue
Block a user