sensors_class.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533
  1. /* Copyright (c) 2013-2015, 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. #include <linux/string.h>
  23. #define APPLY_MASK 0x00000001
  24. #define CMD_W_L_MASK 0x00
  25. #define CMD_W_H_MASK 0x10
  26. #define CMD_W_H_L 0x10
  27. #define CMD_MASK 0xF
  28. #define DATA_MASK 0xFFFF0000
  29. #define DATA_AXIS_SHIFT 17
  30. #define DATA_APPLY_SHIFT 16
  31. /*
  32. * CMD_GET_PARAMS(BIT, PARA, DATA) combine high 16 bit and low 16 bit
  33. * as one params
  34. */
  35. #define CMD_GET_PARAMS(BIT, PARA, DATA) \
  36. ((BIT) ? \
  37. ((DATA) & DATA_MASK) \
  38. : ((PARA) \
  39. | (((DATA) & DATA_MASK) >> 16)))
  40. /*
  41. * CMD_DO_CAL sensor do calibrate command, when do sensor calibrate must use
  42. * this.
  43. * AXIS_X,AXIS_Y,AXIS_Z write axis params to driver like accelerometer
  44. * magnetometer,gyroscope etc.
  45. * CMD_W_THRESHOLD_H,CMD_W_THRESHOLD_L,CMD_W_BIAS write theshold and bias
  46. * params to proximity driver.
  47. * CMD_W_FACTOR,CMD_W_OFFSET write factor and offset params to light
  48. * sensor driver.
  49. * CMD_COMPLETE when one sensor receive calibrate parameters complete, it
  50. * must use this command to end receive the parameters and send the
  51. * parameters to sensor.
  52. */
  53. enum {
  54. CMD_DO_CAL = 0x0,
  55. CMD_W_OFFSET_X,
  56. CMD_W_OFFSET_Y,
  57. CMD_W_OFFSET_Z,
  58. CMD_W_THRESHOLD_H,
  59. CMD_W_THRESHOLD_L,
  60. CMD_W_BIAS,
  61. CMD_W_OFFSET,
  62. CMD_W_FACTOR,
  63. CMD_W_RANGE,
  64. CMD_COMPLETE,
  65. CMD_COUNT
  66. };
  67. int cal_map[] = {
  68. 0,
  69. offsetof(struct cal_result_t, offset_x),
  70. offsetof(struct cal_result_t, offset_y),
  71. offsetof(struct cal_result_t, offset_z),
  72. offsetof(struct cal_result_t, threshold_h),
  73. offsetof(struct cal_result_t, threshold_l),
  74. offsetof(struct cal_result_t, bias),
  75. offsetof(struct cal_result_t, offset[0]),
  76. offsetof(struct cal_result_t, offset[1]),
  77. offsetof(struct cal_result_t, offset[2]),
  78. offsetof(struct cal_result_t, factor),
  79. offsetof(struct cal_result_t, range),
  80. };
  81. static struct class *sensors_class;
  82. DECLARE_RWSEM(sensors_list_lock);
  83. LIST_HEAD(sensors_list);
  84. static ssize_t sensors_name_show(struct device *dev,
  85. struct device_attribute *attr, char *buf)
  86. {
  87. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  88. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->name);
  89. }
  90. static ssize_t sensors_vendor_show(struct device *dev,
  91. struct device_attribute *attr, char *buf)
  92. {
  93. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  94. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->vendor);
  95. }
  96. static ssize_t sensors_version_show(struct device *dev,
  97. struct device_attribute *attr, char *buf)
  98. {
  99. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  100. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->version);
  101. }
  102. static ssize_t sensors_handle_show(struct device *dev,
  103. struct device_attribute *attr, char *buf)
  104. {
  105. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  106. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->handle);
  107. }
  108. static ssize_t sensors_type_show(struct device *dev,
  109. struct device_attribute *attr, char *buf)
  110. {
  111. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  112. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->type);
  113. }
  114. static ssize_t sensors_max_delay_show(struct device *dev,
  115. struct device_attribute *attr, char *buf)
  116. {
  117. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  118. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->max_delay);
  119. }
  120. static ssize_t sensors_flags_show(struct device *dev,
  121. struct device_attribute *attr, char *buf)
  122. {
  123. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  124. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->flags);
  125. }
  126. static ssize_t sensors_max_range_show(struct device *dev,
  127. struct device_attribute *attr, char *buf)
  128. {
  129. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  130. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->max_range);
  131. }
  132. static ssize_t sensors_resolution_show(struct device *dev,
  133. struct device_attribute *attr, char *buf)
  134. {
  135. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  136. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->resolution);
  137. }
  138. static ssize_t sensors_power_show(struct device *dev,
  139. struct device_attribute *attr, char *buf)
  140. {
  141. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  142. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->sensor_power);
  143. }
  144. static ssize_t sensors_min_delay_show(struct device *dev,
  145. struct device_attribute *attr, char *buf)
  146. {
  147. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  148. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->min_delay);
  149. }
  150. static ssize_t sensors_fifo_event_show(struct device *dev,
  151. struct device_attribute *attr, char *buf)
  152. {
  153. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  154. return snprintf(buf, PAGE_SIZE, "%d\n",
  155. sensors_cdev->fifo_reserved_event_count);
  156. }
  157. static ssize_t sensors_fifo_max_show(struct device *dev,
  158. struct device_attribute *attr, char *buf)
  159. {
  160. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  161. return snprintf(buf, PAGE_SIZE, "%d\n",
  162. sensors_cdev->fifo_max_event_count);
  163. }
  164. static ssize_t sensors_enable_store(struct device *dev,
  165. struct device_attribute *attr, const char *buf, size_t size)
  166. {
  167. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  168. ssize_t ret = -EINVAL;
  169. unsigned long data = 0;
  170. ret = kstrtoul(buf, 10, &data);
  171. if (ret)
  172. return ret;
  173. if (data > 1) {
  174. dev_err(dev, "Invalid value of input, input=%ld\n", data);
  175. return -EINVAL;
  176. }
  177. if (sensors_cdev->sensors_enable == NULL) {
  178. dev_err(dev, "Invalid sensor class enable handle\n");
  179. return -EINVAL;
  180. }
  181. ret = sensors_cdev->sensors_enable(sensors_cdev, data);
  182. if (ret)
  183. return ret;
  184. sensors_cdev->enabled = data;
  185. return size;
  186. }
  187. static ssize_t sensors_enable_show(struct device *dev,
  188. struct device_attribute *attr, char *buf)
  189. {
  190. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  191. return snprintf(buf, PAGE_SIZE, "%u\n",
  192. sensors_cdev->enabled);
  193. }
  194. static ssize_t sensors_delay_store(struct device *dev,
  195. struct device_attribute *attr, const char *buf, size_t size)
  196. {
  197. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  198. ssize_t ret = -EINVAL;
  199. unsigned long data = 0;
  200. ret = kstrtoul(buf, 10, &data);
  201. if (ret)
  202. return ret;
  203. /* The data unit is millisecond, the min_delay unit is microseconds. */
  204. if ((data * 1000) < sensors_cdev->min_delay) {
  205. dev_err(dev, "Invalid value of delay, delay=%ld\n", data);
  206. return -EINVAL;
  207. }
  208. if (sensors_cdev->sensors_poll_delay == NULL) {
  209. dev_err(dev, "Invalid sensor class delay handle\n");
  210. return -EINVAL;
  211. }
  212. ret = sensors_cdev->sensors_poll_delay(sensors_cdev, data);
  213. if (ret)
  214. return ret;
  215. sensors_cdev->delay_msec = data;
  216. return size;
  217. }
  218. static ssize_t sensors_delay_show(struct device *dev,
  219. struct device_attribute *attr, char *buf)
  220. {
  221. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  222. return snprintf(buf, PAGE_SIZE, "%u\n",
  223. sensors_cdev->delay_msec);
  224. }
  225. static ssize_t sensors_test_show(struct device *dev,
  226. struct device_attribute *attr, char *buf)
  227. {
  228. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  229. int ret;
  230. if (sensors_cdev->sensors_self_test == NULL) {
  231. dev_err(dev, "Invalid sensor class self test handle\n");
  232. return -EINVAL;
  233. }
  234. ret = sensors_cdev->sensors_self_test(sensors_cdev);
  235. if (ret)
  236. dev_warn(dev, "self test failed.(%d)\n", ret);
  237. return snprintf(buf, PAGE_SIZE, "%s\n",
  238. ret ? "fail" : "pass");
  239. }
  240. static ssize_t sensors_max_latency_store(struct device *dev,
  241. struct device_attribute *attr, const char *buf, size_t size)
  242. {
  243. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  244. unsigned long latency;
  245. int ret = -EINVAL;
  246. ret = kstrtoul(buf, 10, &latency);
  247. if (ret)
  248. return ret;
  249. if (latency > sensors_cdev->max_delay) {
  250. dev_err(dev, "max_latency(%lu) is greater than max_delay(%u)\n",
  251. latency, sensors_cdev->max_delay);
  252. return -EINVAL;
  253. }
  254. if (sensors_cdev->sensors_set_latency == NULL) {
  255. dev_err(dev, "Invalid sensor calss set latency handle\n");
  256. return -EINVAL;
  257. }
  258. /* Disable batching for this sensor */
  259. if (latency < sensors_cdev->delay_msec) {
  260. dev_err(dev, "max_latency is less than delay_msec\n");
  261. return -EINVAL;
  262. }
  263. ret = sensors_cdev->sensors_set_latency(sensors_cdev, latency);
  264. if (ret)
  265. return ret;
  266. sensors_cdev->max_latency = latency;
  267. return size;
  268. }
  269. static ssize_t sensors_max_latency_show(struct device *dev,
  270. struct device_attribute *attr, char *buf)
  271. {
  272. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  273. return snprintf(buf, PAGE_SIZE,
  274. "%u\n", sensors_cdev->max_latency);
  275. }
  276. static ssize_t sensors_flush_store(struct device *dev,
  277. struct device_attribute *attr, const char *buf, size_t size)
  278. {
  279. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  280. ssize_t ret = -EINVAL;
  281. unsigned long data = 0;
  282. ret = kstrtoul(buf, 10, &data);
  283. if (ret)
  284. return ret;
  285. if (data != 1) {
  286. dev_err(dev, "Flush: Invalid value of input, input=%ld\n",
  287. data);
  288. return -EINVAL;
  289. }
  290. if (sensors_cdev->sensors_flush == NULL) {
  291. dev_err(dev, "Invalid sensor class flush handle\n");
  292. return -EINVAL;
  293. }
  294. ret = sensors_cdev->sensors_flush(sensors_cdev);
  295. if (ret)
  296. return ret;
  297. return size;
  298. }
  299. static ssize_t sensors_flush_show(struct device *dev,
  300. struct device_attribute *attr, char *buf)
  301. {
  302. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  303. return snprintf(buf, PAGE_SIZE,
  304. "Flush handler %s\n",
  305. (sensors_cdev->sensors_flush == NULL)
  306. ? "not exist" : "exist");
  307. }
  308. static ssize_t sensors_enable_wakeup_store(struct device *dev,
  309. struct device_attribute *attr, const char *buf, size_t size)
  310. {
  311. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  312. ssize_t ret;
  313. unsigned long enable;
  314. if (sensors_cdev->sensors_enable_wakeup == NULL) {
  315. dev_err(dev, "Invalid sensor class enable_wakeup handle\n");
  316. return -EINVAL;
  317. }
  318. ret = kstrtoul(buf, 10, &enable);
  319. if (ret)
  320. return ret;
  321. enable = enable ? 1 : 0;
  322. ret = sensors_cdev->sensors_enable_wakeup(sensors_cdev, enable);
  323. if (ret)
  324. return ret;
  325. sensors_cdev->wakeup = enable;
  326. return size;
  327. }
  328. static ssize_t sensors_enable_wakeup_show(struct device *dev,
  329. struct device_attribute *attr, char *buf)
  330. {
  331. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  332. return snprintf(buf, PAGE_SIZE, "%d\n", sensors_cdev->wakeup);
  333. }
  334. static ssize_t sensors_calibrate_show(struct device *dev,
  335. struct device_attribute *atte, char *buf)
  336. {
  337. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  338. if (sensors_cdev->params == NULL) {
  339. dev_err(dev, "Invalid sensor params\n");
  340. return -EINVAL;
  341. }
  342. return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->params);
  343. }
  344. static ssize_t sensors_calibrate_store(struct device *dev,
  345. struct device_attribute *attr, const char *buf, size_t size)
  346. {
  347. struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
  348. ssize_t ret = -EINVAL;
  349. long data;
  350. int axis, apply_now;
  351. int cmd, bit_h;
  352. ret = kstrtol(buf, 0, &data);
  353. if (ret)
  354. return ret;
  355. dev_dbg(dev, "data = %lx\n", data);
  356. cmd = data & CMD_MASK;
  357. if (cmd == CMD_DO_CAL) {
  358. if (sensors_cdev->sensors_calibrate == NULL) {
  359. dev_err(dev, "Invalid calibrate handle\n");
  360. return -EINVAL;
  361. }
  362. /* parse the data to get the axis and apply_now value*/
  363. apply_now = (int)(data >> DATA_APPLY_SHIFT) & APPLY_MASK;
  364. axis = (int)data >> DATA_AXIS_SHIFT;
  365. dev_dbg(dev, "apply_now = %d, axis = %d\n", apply_now, axis);
  366. ret = sensors_cdev->sensors_calibrate(sensors_cdev,
  367. axis, apply_now);
  368. if (ret)
  369. return ret;
  370. } else {
  371. if (sensors_cdev->sensors_write_cal_params == NULL) {
  372. dev_err(dev,
  373. "Invalid write_cal_params handle\n");
  374. return -EINVAL;
  375. }
  376. bit_h = (data & CMD_W_H_L) >> 4;
  377. if (cmd > CMD_DO_CAL && cmd < CMD_COMPLETE) {
  378. char *p = (char *)(&sensors_cdev->cal_result)
  379. + cal_map[cmd];
  380. *(int *)p = CMD_GET_PARAMS(bit_h, *(int *)p, data);
  381. } else if (cmd == CMD_COMPLETE) {
  382. ret = sensors_cdev->sensors_write_cal_params
  383. (sensors_cdev, &sensors_cdev->cal_result);
  384. } else {
  385. dev_err(dev, "Invalid command\n");
  386. return -EINVAL;
  387. }
  388. }
  389. return size;
  390. }
  391. static struct device_attribute sensors_class_attrs[] = {
  392. __ATTR(name, 0444, sensors_name_show, NULL),
  393. __ATTR(vendor, 0444, sensors_vendor_show, NULL),
  394. __ATTR(version, 0444, sensors_version_show, NULL),
  395. __ATTR(handle, 0444, sensors_handle_show, NULL),
  396. __ATTR(type, 0444, sensors_type_show, NULL),
  397. __ATTR(max_range, 0444, sensors_max_range_show, NULL),
  398. __ATTR(resolution, 0444, sensors_resolution_show, NULL),
  399. __ATTR(sensor_power, 0444, sensors_power_show, NULL),
  400. __ATTR(min_delay, 0444, sensors_min_delay_show, NULL),
  401. __ATTR(fifo_reserved_event_count, 0444, sensors_fifo_event_show, NULL),
  402. __ATTR(fifo_max_event_count, 0444, sensors_fifo_max_show, NULL),
  403. __ATTR(max_delay, 0444, sensors_max_delay_show, NULL),
  404. __ATTR(flags, 0444, sensors_flags_show, NULL),
  405. __ATTR(enable, 0664, sensors_enable_show, sensors_enable_store),
  406. __ATTR(enable_wakeup, 0664, sensors_enable_wakeup_show,
  407. sensors_enable_wakeup_store),
  408. __ATTR(poll_delay, 0664, sensors_delay_show, sensors_delay_store),
  409. __ATTR(self_test, 0440, sensors_test_show, NULL),
  410. __ATTR(max_latency, 0660, sensors_max_latency_show,
  411. sensors_max_latency_store),
  412. __ATTR(flush, 0660, sensors_flush_show, sensors_flush_store),
  413. __ATTR(calibrate, 0664, sensors_calibrate_show,
  414. sensors_calibrate_store),
  415. __ATTR_NULL,
  416. };
  417. /**
  418. * sensors_classdev_register - register a new object of sensors_classdev class.
  419. * @parent: The device to register.
  420. * @sensors_cdev: the sensors_classdev structure for this device.
  421. */
  422. int sensors_classdev_register(struct device *parent,
  423. struct sensors_classdev *sensors_cdev)
  424. {
  425. sensors_cdev->dev = device_create(sensors_class, parent, 0,
  426. sensors_cdev, "%s", sensors_cdev->name);
  427. if (IS_ERR(sensors_cdev->dev))
  428. return PTR_ERR(sensors_cdev->dev);
  429. down_write(&sensors_list_lock);
  430. list_add_tail(&sensors_cdev->node, &sensors_list);
  431. up_write(&sensors_list_lock);
  432. pr_debug("Registered sensors device: %s\n",
  433. sensors_cdev->name);
  434. return 0;
  435. }
  436. EXPORT_SYMBOL(sensors_classdev_register);
  437. /**
  438. * sensors_classdev_unregister - unregister a object of sensors class.
  439. * @sensors_cdev: the sensor device to unregister
  440. * Unregister a previously registered via sensors_classdev_register object.
  441. */
  442. void sensors_classdev_unregister(struct sensors_classdev *sensors_cdev)
  443. {
  444. device_unregister(sensors_cdev->dev);
  445. down_write(&sensors_list_lock);
  446. list_del(&sensors_cdev->node);
  447. up_write(&sensors_list_lock);
  448. }
  449. EXPORT_SYMBOL(sensors_classdev_unregister);
  450. static int __init sensors_init(void)
  451. {
  452. sensors_class = class_create(THIS_MODULE, "sensors");
  453. if (IS_ERR(sensors_class))
  454. return PTR_ERR(sensors_class);
  455. sensors_class->dev_attrs = sensors_class_attrs;
  456. return 0;
  457. }
  458. static void __exit sensors_exit(void)
  459. {
  460. class_destroy(sensors_class);
  461. }
  462. subsys_initcall(sensors_init);
  463. module_exit(sensors_exit);