mei: show the HBM protocol versions in the device attributes
authorAlexander Usyskin <alexander.usyskin@intel.com>
Sat, 29 Oct 2016 23:42:18 +0000 (01:42 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 31 Oct 2016 10:00:09 +0000 (04:00 -0600)
The HBM protocol version is negotiated during the setup phase, then settled
on a highest possible common version of the driver and the firmware.
The sysfs API advertises both negotiated and driver supported versions
in the device attributes.

Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com>
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Documentation/ABI/testing/sysfs-class-mei
drivers/misc/mei/main.c

index 80d9888a8ece2673686ead1cda4504ce568a1051..5096a82f4cde6c0ceac7597fcdbdc1b979f5d8c8 100644 (file)
@@ -29,3 +29,19 @@ Description: Display fw status registers content
                Also number of registers varies between 1 and 6
                depending on generation.
 
+What:          /sys/class/mei/meiN/hbm_ver
+Date:          Aug 2016
+KernelVersion: 4.9
+Contact:       Tomas Winkler <tomas.winkler@intel.com>
+Description:   Display the negotiated HBM protocol version.
+
+               The HBM protocol version negotiated
+               between the driver and the device.
+
+What:          /sys/class/mei/meiN/hbm_ver_drv
+Date:          Aug 2016
+KernelVersion: 4.9
+Contact:       Tomas Winkler <tomas.winkler@intel.com>
+Description:   Display the driver HBM protocol version.
+
+               The HBM protocol version supported by the driver.
index fa50635512e88985328849e216923785316ef79e..a1484574cfa8973f01e83a9aa6cd37a0485fe5ae 100644 (file)
@@ -653,7 +653,7 @@ static int mei_fasync(int fd, struct file *file, int band)
 }
 
 /**
- * fw_status_show - mei device attribute show method
+ * fw_status_show - mei device fw_status attribute show method
  *
  * @device: device pointer
  * @attr: attribute pointer
@@ -684,8 +684,49 @@ static ssize_t fw_status_show(struct device *device,
 }
 static DEVICE_ATTR_RO(fw_status);
 
+/**
+ * hbm_ver_show - display HBM protocol version negotiated with FW
+ *
+ * @device: device pointer
+ * @attr: attribute pointer
+ * @buf:  char out buffer
+ *
+ * Return: number of the bytes printed into buf or error
+ */
+static ssize_t hbm_ver_show(struct device *device,
+                           struct device_attribute *attr, char *buf)
+{
+       struct mei_device *dev = dev_get_drvdata(device);
+       struct hbm_version ver;
+
+       mutex_lock(&dev->device_lock);
+       ver = dev->version;
+       mutex_unlock(&dev->device_lock);
+
+       return sprintf(buf, "%u.%u\n", ver.major_version, ver.minor_version);
+}
+static DEVICE_ATTR_RO(hbm_ver);
+
+/**
+ * hbm_ver_drv_show - display HBM protocol version advertised by driver
+ *
+ * @device: device pointer
+ * @attr: attribute pointer
+ * @buf:  char out buffer
+ *
+ * Return: number of the bytes printed into buf or error
+ */
+static ssize_t hbm_ver_drv_show(struct device *device,
+                               struct device_attribute *attr, char *buf)
+{
+       return sprintf(buf, "%u.%u\n", HBM_MAJOR_VERSION, HBM_MINOR_VERSION);
+}
+static DEVICE_ATTR_RO(hbm_ver_drv);
+
 static struct attribute *mei_attrs[] = {
        &dev_attr_fw_status.attr,
+       &dev_attr_hbm_ver.attr,
+       &dev_attr_hbm_ver_drv.attr,
        NULL
 };
 ATTRIBUTE_GROUPS(mei);