Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Greybus sysfs file functions |
| 3 | * |
| 4 | * Copyright 2014 Google Inc. |
| 5 | * |
| 6 | * Released under the GPLv2 only. |
| 7 | */ |
| 8 | |
| 9 | #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt |
| 10 | |
| 11 | #include <linux/types.h> |
| 12 | #include <linux/module.h> |
| 13 | #include <linux/moduleparam.h> |
| 14 | #include <linux/kernel.h> |
| 15 | #include <linux/slab.h> |
| 16 | #include <linux/kthread.h> |
| 17 | #include <linux/device.h> |
| 18 | |
| 19 | #include "greybus.h" |
Greg Kroah-Hartman | f91121b | 2014-09-11 08:22:06 -0700 | [diff] [blame] | 20 | #include "kernel_ver.h" |
| 21 | |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 22 | /* Module fields */ |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 23 | #define gb_module_attr(field) \ |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 24 | static ssize_t module_##field##_show(struct device *dev, \ |
| 25 | struct device_attribute *attr, \ |
| 26 | char *buf) \ |
| 27 | { \ |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 28 | struct gb_module *gmod = to_gb_module(dev); \ |
Alex Elder | b09c94a | 2014-10-01 21:54:16 -0500 | [diff] [blame] | 29 | return sprintf(buf, "%x\n", gmod->field); \ |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 30 | } \ |
| 31 | static DEVICE_ATTR_RO(module_##field) |
| 32 | |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 33 | gb_module_attr(vendor); |
| 34 | gb_module_attr(product); |
| 35 | gb_module_attr(version); |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 36 | |
Matt Porter | 4fc6454 | 2014-09-26 20:49:49 -0500 | [diff] [blame] | 37 | static ssize_t module_serial_number_show(struct device *dev, |
| 38 | struct device_attribute *attr, |
| 39 | char *buf) |
| 40 | { |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 41 | struct gb_module *gmod = to_gb_module(dev); |
Matt Porter | 4fc6454 | 2014-09-26 20:49:49 -0500 | [diff] [blame] | 42 | |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 43 | return sprintf(buf, "%llX\n", (unsigned long long)gmod->unique_id); |
Matt Porter | 4fc6454 | 2014-09-26 20:49:49 -0500 | [diff] [blame] | 44 | } |
| 45 | static DEVICE_ATTR_RO(module_serial_number); |
| 46 | |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 47 | static ssize_t module_vendor_string_show(struct device *dev, |
| 48 | struct device_attribute *attr, |
| 49 | char *buf) |
| 50 | { |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 51 | struct gb_module *gmod = to_gb_module(dev); |
Greg Kroah-Hartman | 3be03d4 | 2014-09-01 19:10:06 -0700 | [diff] [blame] | 52 | |
Alex Elder | b09c94a | 2014-10-01 21:54:16 -0500 | [diff] [blame] | 53 | return sprintf(buf, "%s", gmod->vendor_string); |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 54 | } |
| 55 | static DEVICE_ATTR_RO(module_vendor_string); |
| 56 | |
| 57 | static ssize_t module_product_string_show(struct device *dev, |
| 58 | struct device_attribute *attr, |
| 59 | char *buf) |
| 60 | { |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 61 | struct gb_module *gmod = to_gb_module(dev); |
Greg Kroah-Hartman | 3be03d4 | 2014-09-01 19:10:06 -0700 | [diff] [blame] | 62 | |
Alex Elder | b09c94a | 2014-10-01 21:54:16 -0500 | [diff] [blame] | 63 | return sprintf(buf, "%s", gmod->product_string); |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 64 | } |
| 65 | static DEVICE_ATTR_RO(module_product_string); |
| 66 | |
| 67 | static struct attribute *module_attrs[] = { |
| 68 | &dev_attr_module_vendor.attr, |
| 69 | &dev_attr_module_product.attr, |
| 70 | &dev_attr_module_version.attr, |
Matt Porter | 4fc6454 | 2014-09-26 20:49:49 -0500 | [diff] [blame] | 71 | &dev_attr_module_serial_number.attr, |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 72 | &dev_attr_module_vendor_string.attr, |
| 73 | &dev_attr_module_product_string.attr, |
| 74 | NULL, |
| 75 | }; |
| 76 | |
| 77 | static umode_t module_attrs_are_visible(struct kobject *kobj, |
| 78 | struct attribute *a, int n) |
| 79 | { |
Alex Elder | e1e9dbd | 2014-10-01 21:54:11 -0500 | [diff] [blame] | 80 | struct gb_module *gmod = to_gb_module(kobj_to_dev(kobj)); |
Alex Elder | b09c94a | 2014-10-01 21:54:16 -0500 | [diff] [blame] | 81 | umode_t mode = a->mode; |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 82 | |
Alex Elder | b09c94a | 2014-10-01 21:54:16 -0500 | [diff] [blame] | 83 | if (a == &dev_attr_module_vendor_string.attr && gmod->vendor_string) |
| 84 | return mode; |
| 85 | if (a == &dev_attr_module_product_string.attr && gmod->product_string) |
| 86 | return mode; |
| 87 | if (gmod->vendor || gmod->product || gmod->version) |
| 88 | return mode; |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 89 | if (gmod->unique_id) |
Alex Elder | b09c94a | 2014-10-01 21:54:16 -0500 | [diff] [blame] | 90 | return mode; |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 91 | |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 92 | return 0; |
| 93 | } |
| 94 | |
| 95 | static struct attribute_group module_attr_grp = { |
| 96 | .attrs = module_attrs, |
| 97 | .is_visible = module_attrs_are_visible, |
| 98 | }; |
| 99 | |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 100 | const struct attribute_group *greybus_module_groups[] = { |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 101 | &module_attr_grp, |
Greg Kroah-Hartman | 06340ef | 2014-09-01 19:05:54 -0700 | [diff] [blame] | 102 | NULL, |
| 103 | }; |
| 104 | |