adis16136.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586
  1. /*
  2. * ADIS16133/ADIS16135/ADIS16136 gyroscope driver
  3. *
  4. * Copyright 2012 Analog Devices Inc.
  5. * Author: Lars-Peter Clausen <lars@metafoo.de>
  6. *
  7. * Licensed under the GPL-2.
  8. */
  9. #include <linux/interrupt.h>
  10. #include <linux/delay.h>
  11. #include <linux/mutex.h>
  12. #include <linux/device.h>
  13. #include <linux/kernel.h>
  14. #include <linux/spi/spi.h>
  15. #include <linux/slab.h>
  16. #include <linux/sysfs.h>
  17. #include <linux/module.h>
  18. #include <linux/iio/iio.h>
  19. #include <linux/iio/sysfs.h>
  20. #include <linux/iio/buffer.h>
  21. #include <linux/iio/imu/adis.h>
  22. #include <linux/debugfs.h>
  23. #define ADIS16136_REG_FLASH_CNT 0x00
  24. #define ADIS16136_REG_TEMP_OUT 0x02
  25. #define ADIS16136_REG_GYRO_OUT2 0x04
  26. #define ADIS16136_REG_GYRO_OUT 0x06
  27. #define ADIS16136_REG_GYRO_OFF2 0x08
  28. #define ADIS16136_REG_GYRO_OFF 0x0A
  29. #define ADIS16136_REG_ALM_MAG1 0x10
  30. #define ADIS16136_REG_ALM_MAG2 0x12
  31. #define ADIS16136_REG_ALM_SAMPL1 0x14
  32. #define ADIS16136_REG_ALM_SAMPL2 0x16
  33. #define ADIS16136_REG_ALM_CTRL 0x18
  34. #define ADIS16136_REG_GPIO_CTRL 0x1A
  35. #define ADIS16136_REG_MSC_CTRL 0x1C
  36. #define ADIS16136_REG_SMPL_PRD 0x1E
  37. #define ADIS16136_REG_AVG_CNT 0x20
  38. #define ADIS16136_REG_DEC_RATE 0x22
  39. #define ADIS16136_REG_SLP_CTRL 0x24
  40. #define ADIS16136_REG_DIAG_STAT 0x26
  41. #define ADIS16136_REG_GLOB_CMD 0x28
  42. #define ADIS16136_REG_LOT1 0x32
  43. #define ADIS16136_REG_LOT2 0x34
  44. #define ADIS16136_REG_LOT3 0x36
  45. #define ADIS16136_REG_PROD_ID 0x38
  46. #define ADIS16136_REG_SERIAL_NUM 0x3A
  47. #define ADIS16136_DIAG_STAT_FLASH_UPDATE_FAIL 2
  48. #define ADIS16136_DIAG_STAT_SPI_FAIL 3
  49. #define ADIS16136_DIAG_STAT_SELF_TEST_FAIL 5
  50. #define ADIS16136_DIAG_STAT_FLASH_CHKSUM_FAIL 6
  51. #define ADIS16136_MSC_CTRL_MEMORY_TEST BIT(11)
  52. #define ADIS16136_MSC_CTRL_SELF_TEST BIT(10)
  53. struct adis16136_chip_info {
  54. unsigned int precision;
  55. unsigned int fullscale;
  56. };
  57. struct adis16136 {
  58. const struct adis16136_chip_info *chip_info;
  59. struct adis adis;
  60. };
  61. #ifdef CONFIG_DEBUG_FS
  62. static ssize_t adis16136_show_serial(struct file *file,
  63. char __user *userbuf, size_t count, loff_t *ppos)
  64. {
  65. struct adis16136 *adis16136 = file->private_data;
  66. uint16_t lot1, lot2, lot3, serial;
  67. char buf[20];
  68. size_t len;
  69. int ret;
  70. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_SERIAL_NUM,
  71. &serial);
  72. if (ret < 0)
  73. return ret;
  74. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_LOT1, &lot1);
  75. if (ret < 0)
  76. return ret;
  77. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_LOT2, &lot2);
  78. if (ret < 0)
  79. return ret;
  80. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_LOT3, &lot3);
  81. if (ret < 0)
  82. return ret;
  83. len = snprintf(buf, sizeof(buf), "%.4x%.4x%.4x-%.4x\n", lot1, lot2,
  84. lot3, serial);
  85. return simple_read_from_buffer(userbuf, count, ppos, buf, len);
  86. }
  87. static const struct file_operations adis16136_serial_fops = {
  88. .open = simple_open,
  89. .read = adis16136_show_serial,
  90. .llseek = default_llseek,
  91. .owner = THIS_MODULE,
  92. };
  93. static int adis16136_show_product_id(void *arg, u64 *val)
  94. {
  95. struct adis16136 *adis16136 = arg;
  96. u16 prod_id;
  97. int ret;
  98. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_PROD_ID,
  99. &prod_id);
  100. if (ret < 0)
  101. return ret;
  102. *val = prod_id;
  103. return 0;
  104. }
  105. DEFINE_DEBUGFS_ATTRIBUTE(adis16136_product_id_fops,
  106. adis16136_show_product_id, NULL, "%llu\n");
  107. static int adis16136_show_flash_count(void *arg, u64 *val)
  108. {
  109. struct adis16136 *adis16136 = arg;
  110. uint16_t flash_count;
  111. int ret;
  112. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_FLASH_CNT,
  113. &flash_count);
  114. if (ret < 0)
  115. return ret;
  116. *val = flash_count;
  117. return 0;
  118. }
  119. DEFINE_DEBUGFS_ATTRIBUTE(adis16136_flash_count_fops,
  120. adis16136_show_flash_count, NULL, "%lld\n");
  121. static int adis16136_debugfs_init(struct iio_dev *indio_dev)
  122. {
  123. struct adis16136 *adis16136 = iio_priv(indio_dev);
  124. debugfs_create_file_unsafe("serial_number", 0400,
  125. indio_dev->debugfs_dentry, adis16136,
  126. &adis16136_serial_fops);
  127. debugfs_create_file_unsafe("product_id", 0400,
  128. indio_dev->debugfs_dentry,
  129. adis16136, &adis16136_product_id_fops);
  130. debugfs_create_file_unsafe("flash_count", 0400,
  131. indio_dev->debugfs_dentry,
  132. adis16136, &adis16136_flash_count_fops);
  133. return 0;
  134. }
  135. #else
  136. static int adis16136_debugfs_init(struct iio_dev *indio_dev)
  137. {
  138. return 0;
  139. }
  140. #endif
  141. static int adis16136_set_freq(struct adis16136 *adis16136, unsigned int freq)
  142. {
  143. unsigned int t;
  144. t = 32768 / freq;
  145. if (t < 0xf)
  146. t = 0xf;
  147. else if (t > 0xffff)
  148. t = 0xffff;
  149. else
  150. t--;
  151. return adis_write_reg_16(&adis16136->adis, ADIS16136_REG_SMPL_PRD, t);
  152. }
  153. static int adis16136_get_freq(struct adis16136 *adis16136, unsigned int *freq)
  154. {
  155. uint16_t t;
  156. int ret;
  157. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_SMPL_PRD, &t);
  158. if (ret < 0)
  159. return ret;
  160. *freq = 32768 / (t + 1);
  161. return 0;
  162. }
  163. static ssize_t adis16136_write_frequency(struct device *dev,
  164. struct device_attribute *attr, const char *buf, size_t len)
  165. {
  166. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  167. struct adis16136 *adis16136 = iio_priv(indio_dev);
  168. unsigned int val;
  169. int ret;
  170. ret = kstrtouint(buf, 10, &val);
  171. if (ret)
  172. return ret;
  173. if (val == 0)
  174. return -EINVAL;
  175. ret = adis16136_set_freq(adis16136, val);
  176. return ret ? ret : len;
  177. }
  178. static ssize_t adis16136_read_frequency(struct device *dev,
  179. struct device_attribute *attr, char *buf)
  180. {
  181. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  182. struct adis16136 *adis16136 = iio_priv(indio_dev);
  183. unsigned int freq;
  184. int ret;
  185. ret = adis16136_get_freq(adis16136, &freq);
  186. if (ret < 0)
  187. return ret;
  188. return sprintf(buf, "%d\n", freq);
  189. }
  190. static IIO_DEV_ATTR_SAMP_FREQ(S_IWUSR | S_IRUGO,
  191. adis16136_read_frequency,
  192. adis16136_write_frequency);
  193. static const unsigned adis16136_3db_divisors[] = {
  194. [0] = 2, /* Special case */
  195. [1] = 6,
  196. [2] = 12,
  197. [3] = 25,
  198. [4] = 50,
  199. [5] = 100,
  200. [6] = 200,
  201. [7] = 200, /* Not a valid setting */
  202. };
  203. static int adis16136_set_filter(struct iio_dev *indio_dev, int val)
  204. {
  205. struct adis16136 *adis16136 = iio_priv(indio_dev);
  206. unsigned int freq;
  207. int i, ret;
  208. ret = adis16136_get_freq(adis16136, &freq);
  209. if (ret < 0)
  210. return ret;
  211. for (i = ARRAY_SIZE(adis16136_3db_divisors) - 1; i >= 1; i--) {
  212. if (freq / adis16136_3db_divisors[i] >= val)
  213. break;
  214. }
  215. return adis_write_reg_16(&adis16136->adis, ADIS16136_REG_AVG_CNT, i);
  216. }
  217. static int adis16136_get_filter(struct iio_dev *indio_dev, int *val)
  218. {
  219. struct adis16136 *adis16136 = iio_priv(indio_dev);
  220. unsigned int freq;
  221. uint16_t val16;
  222. int ret;
  223. mutex_lock(&indio_dev->mlock);
  224. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_AVG_CNT, &val16);
  225. if (ret < 0)
  226. goto err_unlock;
  227. ret = adis16136_get_freq(adis16136, &freq);
  228. if (ret < 0)
  229. goto err_unlock;
  230. *val = freq / adis16136_3db_divisors[val16 & 0x07];
  231. err_unlock:
  232. mutex_unlock(&indio_dev->mlock);
  233. return ret ? ret : IIO_VAL_INT;
  234. }
  235. static int adis16136_read_raw(struct iio_dev *indio_dev,
  236. const struct iio_chan_spec *chan, int *val, int *val2, long info)
  237. {
  238. struct adis16136 *adis16136 = iio_priv(indio_dev);
  239. uint32_t val32;
  240. int ret;
  241. switch (info) {
  242. case IIO_CHAN_INFO_RAW:
  243. return adis_single_conversion(indio_dev, chan, 0, val);
  244. case IIO_CHAN_INFO_SCALE:
  245. switch (chan->type) {
  246. case IIO_ANGL_VEL:
  247. *val = adis16136->chip_info->precision;
  248. *val2 = (adis16136->chip_info->fullscale << 16);
  249. return IIO_VAL_FRACTIONAL;
  250. case IIO_TEMP:
  251. *val = 10;
  252. *val2 = 697000; /* 0.010697 degree Celsius */
  253. return IIO_VAL_INT_PLUS_MICRO;
  254. default:
  255. return -EINVAL;
  256. }
  257. case IIO_CHAN_INFO_CALIBBIAS:
  258. ret = adis_read_reg_32(&adis16136->adis,
  259. ADIS16136_REG_GYRO_OFF2, &val32);
  260. if (ret < 0)
  261. return ret;
  262. *val = sign_extend32(val32, 31);
  263. return IIO_VAL_INT;
  264. case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
  265. return adis16136_get_filter(indio_dev, val);
  266. default:
  267. return -EINVAL;
  268. }
  269. }
  270. static int adis16136_write_raw(struct iio_dev *indio_dev,
  271. const struct iio_chan_spec *chan, int val, int val2, long info)
  272. {
  273. struct adis16136 *adis16136 = iio_priv(indio_dev);
  274. switch (info) {
  275. case IIO_CHAN_INFO_CALIBBIAS:
  276. return adis_write_reg_32(&adis16136->adis,
  277. ADIS16136_REG_GYRO_OFF2, val);
  278. case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
  279. return adis16136_set_filter(indio_dev, val);
  280. default:
  281. break;
  282. }
  283. return -EINVAL;
  284. }
  285. enum {
  286. ADIS16136_SCAN_GYRO,
  287. ADIS16136_SCAN_TEMP,
  288. };
  289. static const struct iio_chan_spec adis16136_channels[] = {
  290. {
  291. .type = IIO_ANGL_VEL,
  292. .modified = 1,
  293. .channel2 = IIO_MOD_X,
  294. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
  295. BIT(IIO_CHAN_INFO_CALIBBIAS) |
  296. BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY),
  297. .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),
  298. .address = ADIS16136_REG_GYRO_OUT2,
  299. .scan_index = ADIS16136_SCAN_GYRO,
  300. .scan_type = {
  301. .sign = 's',
  302. .realbits = 32,
  303. .storagebits = 32,
  304. .endianness = IIO_BE,
  305. },
  306. }, {
  307. .type = IIO_TEMP,
  308. .indexed = 1,
  309. .channel = 0,
  310. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
  311. BIT(IIO_CHAN_INFO_SCALE),
  312. .address = ADIS16136_REG_TEMP_OUT,
  313. .scan_index = ADIS16136_SCAN_TEMP,
  314. .scan_type = {
  315. .sign = 's',
  316. .realbits = 16,
  317. .storagebits = 16,
  318. .endianness = IIO_BE,
  319. },
  320. },
  321. IIO_CHAN_SOFT_TIMESTAMP(2),
  322. };
  323. static struct attribute *adis16136_attributes[] = {
  324. &iio_dev_attr_sampling_frequency.dev_attr.attr,
  325. NULL
  326. };
  327. static const struct attribute_group adis16136_attribute_group = {
  328. .attrs = adis16136_attributes,
  329. };
  330. static const struct iio_info adis16136_info = {
  331. .attrs = &adis16136_attribute_group,
  332. .read_raw = &adis16136_read_raw,
  333. .write_raw = &adis16136_write_raw,
  334. .update_scan_mode = adis_update_scan_mode,
  335. .debugfs_reg_access = adis_debugfs_reg_access,
  336. };
  337. static int adis16136_stop_device(struct iio_dev *indio_dev)
  338. {
  339. struct adis16136 *adis16136 = iio_priv(indio_dev);
  340. int ret;
  341. ret = adis_write_reg_16(&adis16136->adis, ADIS16136_REG_SLP_CTRL, 0xff);
  342. if (ret)
  343. dev_err(&indio_dev->dev,
  344. "Could not power down device: %d\n", ret);
  345. return ret;
  346. }
  347. static int adis16136_initial_setup(struct iio_dev *indio_dev)
  348. {
  349. struct adis16136 *adis16136 = iio_priv(indio_dev);
  350. unsigned int device_id;
  351. uint16_t prod_id;
  352. int ret;
  353. ret = adis_initial_startup(&adis16136->adis);
  354. if (ret)
  355. return ret;
  356. ret = adis_read_reg_16(&adis16136->adis, ADIS16136_REG_PROD_ID,
  357. &prod_id);
  358. if (ret)
  359. return ret;
  360. ret = sscanf(indio_dev->name, "adis%u\n", &device_id);
  361. if (ret != 1)
  362. return -EINVAL;
  363. if (prod_id != device_id)
  364. dev_warn(&indio_dev->dev, "Device ID(%u) and product ID(%u) do not match.",
  365. device_id, prod_id);
  366. return 0;
  367. }
  368. static const char * const adis16136_status_error_msgs[] = {
  369. [ADIS16136_DIAG_STAT_FLASH_UPDATE_FAIL] = "Flash update failed",
  370. [ADIS16136_DIAG_STAT_SPI_FAIL] = "SPI failure",
  371. [ADIS16136_DIAG_STAT_SELF_TEST_FAIL] = "Self test error",
  372. [ADIS16136_DIAG_STAT_FLASH_CHKSUM_FAIL] = "Flash checksum error",
  373. };
  374. static const struct adis_data adis16136_data = {
  375. .diag_stat_reg = ADIS16136_REG_DIAG_STAT,
  376. .glob_cmd_reg = ADIS16136_REG_GLOB_CMD,
  377. .msc_ctrl_reg = ADIS16136_REG_MSC_CTRL,
  378. .self_test_mask = ADIS16136_MSC_CTRL_SELF_TEST,
  379. .startup_delay = 80,
  380. .read_delay = 10,
  381. .write_delay = 10,
  382. .status_error_msgs = adis16136_status_error_msgs,
  383. .status_error_mask = BIT(ADIS16136_DIAG_STAT_FLASH_UPDATE_FAIL) |
  384. BIT(ADIS16136_DIAG_STAT_SPI_FAIL) |
  385. BIT(ADIS16136_DIAG_STAT_SELF_TEST_FAIL) |
  386. BIT(ADIS16136_DIAG_STAT_FLASH_CHKSUM_FAIL),
  387. };
  388. enum adis16136_id {
  389. ID_ADIS16133,
  390. ID_ADIS16135,
  391. ID_ADIS16136,
  392. ID_ADIS16137,
  393. };
  394. static const struct adis16136_chip_info adis16136_chip_info[] = {
  395. [ID_ADIS16133] = {
  396. .precision = IIO_DEGREE_TO_RAD(1200),
  397. .fullscale = 24000,
  398. },
  399. [ID_ADIS16135] = {
  400. .precision = IIO_DEGREE_TO_RAD(300),
  401. .fullscale = 24000,
  402. },
  403. [ID_ADIS16136] = {
  404. .precision = IIO_DEGREE_TO_RAD(450),
  405. .fullscale = 24623,
  406. },
  407. [ID_ADIS16137] = {
  408. .precision = IIO_DEGREE_TO_RAD(1000),
  409. .fullscale = 24609,
  410. },
  411. };
  412. static int adis16136_probe(struct spi_device *spi)
  413. {
  414. const struct spi_device_id *id = spi_get_device_id(spi);
  415. struct adis16136 *adis16136;
  416. struct iio_dev *indio_dev;
  417. int ret;
  418. indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*adis16136));
  419. if (indio_dev == NULL)
  420. return -ENOMEM;
  421. spi_set_drvdata(spi, indio_dev);
  422. adis16136 = iio_priv(indio_dev);
  423. adis16136->chip_info = &adis16136_chip_info[id->driver_data];
  424. indio_dev->dev.parent = &spi->dev;
  425. indio_dev->name = spi_get_device_id(spi)->name;
  426. indio_dev->channels = adis16136_channels;
  427. indio_dev->num_channels = ARRAY_SIZE(adis16136_channels);
  428. indio_dev->info = &adis16136_info;
  429. indio_dev->modes = INDIO_DIRECT_MODE;
  430. ret = adis_init(&adis16136->adis, indio_dev, spi, &adis16136_data);
  431. if (ret)
  432. return ret;
  433. ret = adis_setup_buffer_and_trigger(&adis16136->adis, indio_dev, NULL);
  434. if (ret)
  435. return ret;
  436. ret = adis16136_initial_setup(indio_dev);
  437. if (ret)
  438. goto error_cleanup_buffer;
  439. ret = iio_device_register(indio_dev);
  440. if (ret)
  441. goto error_stop_device;
  442. adis16136_debugfs_init(indio_dev);
  443. return 0;
  444. error_stop_device:
  445. adis16136_stop_device(indio_dev);
  446. error_cleanup_buffer:
  447. adis_cleanup_buffer_and_trigger(&adis16136->adis, indio_dev);
  448. return ret;
  449. }
  450. static int adis16136_remove(struct spi_device *spi)
  451. {
  452. struct iio_dev *indio_dev = spi_get_drvdata(spi);
  453. struct adis16136 *adis16136 = iio_priv(indio_dev);
  454. iio_device_unregister(indio_dev);
  455. adis16136_stop_device(indio_dev);
  456. adis_cleanup_buffer_and_trigger(&adis16136->adis, indio_dev);
  457. return 0;
  458. }
  459. static const struct spi_device_id adis16136_ids[] = {
  460. { "adis16133", ID_ADIS16133 },
  461. { "adis16135", ID_ADIS16135 },
  462. { "adis16136", ID_ADIS16136 },
  463. { "adis16137", ID_ADIS16137 },
  464. { }
  465. };
  466. MODULE_DEVICE_TABLE(spi, adis16136_ids);
  467. static struct spi_driver adis16136_driver = {
  468. .driver = {
  469. .name = "adis16136",
  470. },
  471. .id_table = adis16136_ids,
  472. .probe = adis16136_probe,
  473. .remove = adis16136_remove,
  474. };
  475. module_spi_driver(adis16136_driver);
  476. MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");
  477. MODULE_DESCRIPTION("Analog Devices ADIS16133/ADIS16135/ADIS16136 gyroscope driver");
  478. MODULE_LICENSE("GPL v2");