1// SPDX-License-Identifier: GPL-2.0 2#include <linux/kernel.h> 3#include <linux/stat.h> 4#include <asm/macio.h> 5 6static ssize_t 7compatible_show (struct device *dev, struct device_attribute *attr, char *buf) 8{ 9 struct platform_device *of; 10 const char *compat; 11 int cplen; 12 int length = 0; 13 14 of = &to_macio_device (dev)->ofdev; 15 compat = of_get_property(of->dev.of_node, "compatible", &cplen); 16 if (!compat) { 17 *buf = '\0'; 18 return 0; 19 } 20 while (cplen > 0) { 21 int l; 22 length += sprintf (buf, "%s\n", compat); 23 buf += length; 24 l = strlen (compat) + 1; 25 compat += l; 26 cplen -= l; 27 } 28 29 return length; 30} 31static DEVICE_ATTR_RO(compatible); 32 33static ssize_t modalias_show (struct device *dev, struct device_attribute *attr, 34 char *buf) 35{ 36 return of_device_modalias(dev, buf, PAGE_SIZE); 37} 38 39static ssize_t devspec_show(struct device *dev, 40 struct device_attribute *attr, char *buf) 41{ 42 struct platform_device *ofdev; 43 44 ofdev = to_platform_device(dev); 45 return sprintf(buf, "%pOF\n", ofdev->dev.of_node); 46} 47static DEVICE_ATTR_RO(modalias); 48static DEVICE_ATTR_RO(devspec); 49 50static ssize_t name_show(struct device *dev, 51 struct device_attribute *attr, char *buf) 52{ 53 return sprintf(buf, "%pOFn\n", dev->of_node); 54} 55static DEVICE_ATTR_RO(name); 56 57static ssize_t type_show(struct device *dev, 58 struct device_attribute *attr, char *buf) 59{ 60 return sprintf(buf, "%s\n", of_node_get_device_type(dev->of_node)); 61} 62static DEVICE_ATTR_RO(type); 63 64static struct attribute *macio_dev_attrs[] = { 65 &dev_attr_name.attr, 66 &dev_attr_type.attr, 67 &dev_attr_compatible.attr, 68 &dev_attr_modalias.attr, 69 &dev_attr_devspec.attr, 70 NULL, 71}; 72 73static const struct attribute_group macio_dev_group = { 74 .attrs = macio_dev_attrs, 75}; 76 77const struct attribute_group *macio_dev_groups[] = { 78 &macio_dev_group, 79 NULL, 80}; 81