sensors_class.c 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. /* Copyright (c) 2013, The Linux Foundation. All rights reserved.
  2. *
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License version 2 and
  5. * only version 2 as published by the Free Software Foundation.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. */
  12. #include <linux/module.h>
  13. #include <linux/kernel.h>
  14. #include <linux/init.h>
  15. #include <linux/list.h>
  16. #include <linux/spinlock.h>
  17. #include <linux/device.h>
  18. #include <linux/err.h>
  19. #include <linux/ctype.h>
  20. #include <linux/rwsem.h>
  21. #include <linux/sensors.h>
  22. static struct class *sensors_class;
  23. DECLARE_RWSEM(sensors_list_lock);
  24. LIST_HEAD(sensors_list);
  25. static ssize_t sensors_name_show(struct device *dev,
  26. struct device_attribute *attr, char *buf)
  27. {
  28. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  29. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->name);
  30. }
  31. static ssize_t sensors_vendor_show(struct device *dev,
  32. struct device_attribute *attr, char *buf)
  33. {
  34. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  35. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->vendor);
  36. }
  37. static ssize_t sensors_version_show(struct device *dev,
  38. struct device_attribute *attr, char *buf)
  39. {
  40. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  41. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->version);
  42. }
  43. static ssize_t sensors_handle_show(struct device *dev,
  44. struct device_attribute *attr, char *buf)
  45. {
  46. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  47. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->handle);
  48. }
  49. static ssize_t sensors_type_show(struct device *dev,
  50. struct device_attribute *attr, char *buf)
  51. {
  52. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  53. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->type);
  54. }
  55. static ssize_t sensors_max_range_show(struct device *dev,
  56. struct device_attribute *attr, char *buf)
  57. {
  58. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  59. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->max_range);
  60. }
  61. static ssize_t sensors_resolution_show(struct device *dev,
  62. struct device_attribute *attr, char *buf)
  63. {
  64. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  65. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->resolution);
  66. }
  67. static ssize_t sensors_power_show(struct device *dev,
  68. struct device_attribute *attr, char *buf)
  69. {
  70. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  71. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->sensor_power);
  72. }
  73. static ssize_t sensors_min_delay_show(struct device *dev,
  74. struct device_attribute *attr, char *buf)
  75. {
  76. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  77. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->min_delay);
  78. }
  79. static ssize_t sensors_fifo_event_show(struct device *dev,
  80. struct device_attribute *attr, char *buf)
  81. {
  82. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  83. return snprintf(buf, PAGE_SIZE, "%d\n",
  84. sensors_cdev->fifo_reserved_event_count);
  85. }
  86. static ssize_t sensors_fifo_max_show(struct device *dev,
  87. struct device_attribute *attr, char *buf)
  88. {
  89. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  90. return snprintf(buf, PAGE_SIZE, "%d\n",
  91. sensors_cdev->fifo_max_event_count);
  92. }
  93. static ssize_t sensors_enable_store(struct device *dev,
  94. struct device_attribute *attr, const char *buf, size_t size)
  95. {
  96. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  97. ssize_t ret = -EINVAL;
  98. unsigned long data = 0;
  99. ret = kstrtoul(buf, 10, &data);
  100. if (ret)
  101. return ret;
  102. if (data > 1) {
  103. dev_err(dev, "Invalid value of input, input=%ld\n", data);
  104. return -EINVAL;
  105. }
  106. if (sensors_cdev->sensors_enable == NULL) {
  107. dev_err(dev, "Invalid sensor class enable handle\n");
  108. return -EINVAL;
  109. }
  110. ret = sensors_cdev->sensors_enable(sensors_cdev, data);
  111. if (ret)
  112. return ret;
  113. sensors_cdev->enabled = data;
  114. return size;
  115. }
  116. static ssize_t sensors_enable_show(struct device *dev,
  117. struct device_attribute *attr, char *buf)
  118. {
  119. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  120. return snprintf(buf, PAGE_SIZE, "%u\n",
  121. sensors_cdev->enabled);
  122. }
  123. static ssize_t sensors_delay_store(struct device *dev,
  124. struct device_attribute *attr, const char *buf, size_t size)
  125. {
  126. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  127. ssize_t ret = -EINVAL;
  128. unsigned long data = 0;
  129. ret = kstrtoul(buf, 10, &data);
  130. if (ret)
  131. return ret;
  132. /* The data unit is millisecond, the min_delay unit is microseconds. */
  133. if ((data * 1000) < sensors_cdev->min_delay) {
  134. dev_err(dev, "Invalid value of delay, delay=%ld\n", data);
  135. return -EINVAL;
  136. }
  137. if (sensors_cdev->sensors_poll_delay == NULL) {
  138. dev_err(dev, "Invalid sensor class delay handle\n");
  139. return -EINVAL;
  140. }
  141. ret = sensors_cdev->sensors_poll_delay(sensors_cdev, data);
  142. if (ret)
  143. return ret;
  144. sensors_cdev->delay_msec = data;
  145. return size;
  146. }
  147. static ssize_t sensors_delay_show(struct device *dev,
  148. struct device_attribute *attr, char *buf)
  149. {
  150. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  151. return snprintf(buf, PAGE_SIZE, "%u\n",
  152. sensors_cdev->delay_msec);
  153. }
  154. static struct device_attribute sensors_class_attrs[] = {
  155. __ATTR(name, 0444, sensors_name_show, NULL),
  156. __ATTR(vendor, 0444, sensors_vendor_show, NULL),
  157. __ATTR(version, 0444, sensors_version_show, NULL),
  158. __ATTR(handle, 0444, sensors_handle_show, NULL),
  159. __ATTR(type, 0444, sensors_type_show, NULL),
  160. __ATTR(max_range, 0444, sensors_max_range_show, NULL),
  161. __ATTR(resolution, 0444, sensors_resolution_show, NULL),
  162. __ATTR(sensor_power, 0444, sensors_power_show, NULL),
  163. __ATTR(min_delay, 0444, sensors_min_delay_show, NULL),
  164. __ATTR(fifo_reserved_event_count, 0444, sensors_fifo_event_show, NULL),
  165. __ATTR(fifo_max_event_count, 0444, sensors_fifo_max_show, NULL),
  166. __ATTR(enable, 0664, sensors_enable_show, sensors_enable_store),
  167. __ATTR(poll_delay, 0664, sensors_delay_show, sensors_delay_store),
  168. __ATTR_NULL,
  169. };
  170. /**
  171. * sensors_classdev_register - register a new object of sensors_classdev class.
  172. * @parent: The device to register.
  173. * @sensors_cdev: the sensors_classdev structure for this device.
  174. */
  175. int sensors_classdev_register(struct device *parent,
  176. struct sensors_classdev *sensors_cdev)
  177. {
  178. sensors_cdev->dev = device_create(sensors_class, parent, 0,
  179. sensors_cdev, "%s", sensors_cdev->name);
  180. if (IS_ERR(sensors_cdev->dev))
  181. return PTR_ERR(sensors_cdev->dev);
  182. down_write(&sensors_list_lock);
  183. list_add_tail(&sensors_cdev->node, &sensors_list);
  184. up_write(&sensors_list_lock);
  185. pr_debug("Registered sensors device: %s\n",
  186. sensors_cdev->name);
  187. return 0;
  188. }
  189. EXPORT_SYMBOL(sensors_classdev_register);
  190. /**
  191. * sensors_classdev_unregister - unregister a object of sensors class.
  192. * @sensors_cdev: the sensor device to unregister
  193. * Unregister a previously registered via sensors_classdev_register object.
  194. */
  195. void sensors_classdev_unregister(struct sensors_classdev *sensors_cdev)
  196. {
  197. device_unregister(sensors_cdev->dev);
  198. down_write(&sensors_list_lock);
  199. list_del(&sensors_cdev->node);
  200. up_write(&sensors_list_lock);
  201. }
  202. EXPORT_SYMBOL(sensors_classdev_unregister);
  203. static int __init sensors_init(void)
  204. {
  205. sensors_class = class_create(THIS_MODULE, "sensors");
  206. if (IS_ERR(sensors_class))
  207. return PTR_ERR(sensors_class);
  208. sensors_class->dev_attrs = sensors_class_attrs;
  209. return 0;
  210. }
  211. static void __exit sensors_exit(void)
  212. {
  213. class_destroy(sensors_class);
  214. }
  215. subsys_initcall(sensors_init);
  216. module_exit(sensors_exit);