adxl372.c 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * ADXL372 3-Axis Digital Accelerometer core driver
  4. *
  5. * Copyright 2018 Analog Devices Inc.
  6. */
  7. #include <linux/bitfield.h>
  8. #include <linux/bitops.h>
  9. #include <linux/interrupt.h>
  10. #include <linux/irq.h>
  11. #include <linux/module.h>
  12. #include <linux/regmap.h>
  13. #include <linux/spi/spi.h>
  14. #include <linux/iio/iio.h>
  15. #include <linux/iio/sysfs.h>
  16. #include <linux/iio/buffer.h>
  17. #include <linux/iio/events.h>
  18. #include <linux/iio/trigger.h>
  19. #include <linux/iio/trigger_consumer.h>
  20. #include <linux/iio/triggered_buffer.h>
  21. #include "adxl372.h"
  22. /* ADXL372 registers definition */
  23. #define ADXL372_DEVID 0x00
  24. #define ADXL372_DEVID_MST 0x01
  25. #define ADXL372_PARTID 0x02
  26. #define ADXL372_STATUS_1 0x04
  27. #define ADXL372_STATUS_2 0x05
  28. #define ADXL372_FIFO_ENTRIES_2 0x06
  29. #define ADXL372_FIFO_ENTRIES_1 0x07
  30. #define ADXL372_X_DATA_H 0x08
  31. #define ADXL372_X_DATA_L 0x09
  32. #define ADXL372_Y_DATA_H 0x0A
  33. #define ADXL372_Y_DATA_L 0x0B
  34. #define ADXL372_Z_DATA_H 0x0C
  35. #define ADXL372_Z_DATA_L 0x0D
  36. #define ADXL372_X_MAXPEAK_H 0x15
  37. #define ADXL372_X_MAXPEAK_L 0x16
  38. #define ADXL372_Y_MAXPEAK_H 0x17
  39. #define ADXL372_Y_MAXPEAK_L 0x18
  40. #define ADXL372_Z_MAXPEAK_H 0x19
  41. #define ADXL372_Z_MAXPEAK_L 0x1A
  42. #define ADXL372_OFFSET_X 0x20
  43. #define ADXL372_OFFSET_Y 0x21
  44. #define ADXL372_OFFSET_Z 0x22
  45. #define ADXL372_X_THRESH_ACT_H 0x23
  46. #define ADXL372_X_THRESH_ACT_L 0x24
  47. #define ADXL372_Y_THRESH_ACT_H 0x25
  48. #define ADXL372_Y_THRESH_ACT_L 0x26
  49. #define ADXL372_Z_THRESH_ACT_H 0x27
  50. #define ADXL372_Z_THRESH_ACT_L 0x28
  51. #define ADXL372_TIME_ACT 0x29
  52. #define ADXL372_X_THRESH_INACT_H 0x2A
  53. #define ADXL372_X_THRESH_INACT_L 0x2B
  54. #define ADXL372_Y_THRESH_INACT_H 0x2C
  55. #define ADXL372_Y_THRESH_INACT_L 0x2D
  56. #define ADXL372_Z_THRESH_INACT_H 0x2E
  57. #define ADXL372_Z_THRESH_INACT_L 0x2F
  58. #define ADXL372_TIME_INACT_H 0x30
  59. #define ADXL372_TIME_INACT_L 0x31
  60. #define ADXL372_X_THRESH_ACT2_H 0x32
  61. #define ADXL372_X_THRESH_ACT2_L 0x33
  62. #define ADXL372_Y_THRESH_ACT2_H 0x34
  63. #define ADXL372_Y_THRESH_ACT2_L 0x35
  64. #define ADXL372_Z_THRESH_ACT2_H 0x36
  65. #define ADXL372_Z_THRESH_ACT2_L 0x37
  66. #define ADXL372_HPF 0x38
  67. #define ADXL372_FIFO_SAMPLES 0x39
  68. #define ADXL372_FIFO_CTL 0x3A
  69. #define ADXL372_INT1_MAP 0x3B
  70. #define ADXL372_INT2_MAP 0x3C
  71. #define ADXL372_TIMING 0x3D
  72. #define ADXL372_MEASURE 0x3E
  73. #define ADXL372_POWER_CTL 0x3F
  74. #define ADXL372_SELF_TEST 0x40
  75. #define ADXL372_RESET 0x41
  76. #define ADXL372_FIFO_DATA 0x42
  77. #define ADXL372_DEVID_VAL 0xAD
  78. #define ADXL372_PARTID_VAL 0xFA
  79. #define ADXL372_RESET_CODE 0x52
  80. /* ADXL372_POWER_CTL */
  81. #define ADXL372_POWER_CTL_MODE_MSK GENMASK_ULL(1, 0)
  82. #define ADXL372_POWER_CTL_MODE(x) (((x) & 0x3) << 0)
  83. /* ADXL372_MEASURE */
  84. #define ADXL372_MEASURE_LINKLOOP_MSK GENMASK_ULL(5, 4)
  85. #define ADXL372_MEASURE_LINKLOOP_MODE(x) (((x) & 0x3) << 4)
  86. #define ADXL372_MEASURE_BANDWIDTH_MSK GENMASK_ULL(2, 0)
  87. #define ADXL372_MEASURE_BANDWIDTH_MODE(x) (((x) & 0x7) << 0)
  88. /* ADXL372_TIMING */
  89. #define ADXL372_TIMING_ODR_MSK GENMASK_ULL(7, 5)
  90. #define ADXL372_TIMING_ODR_MODE(x) (((x) & 0x7) << 5)
  91. /* ADXL372_FIFO_CTL */
  92. #define ADXL372_FIFO_CTL_FORMAT_MSK GENMASK(5, 3)
  93. #define ADXL372_FIFO_CTL_FORMAT_MODE(x) (((x) & 0x7) << 3)
  94. #define ADXL372_FIFO_CTL_MODE_MSK GENMASK(2, 1)
  95. #define ADXL372_FIFO_CTL_MODE_MODE(x) (((x) & 0x3) << 1)
  96. #define ADXL372_FIFO_CTL_SAMPLES_MSK BIT(1)
  97. #define ADXL372_FIFO_CTL_SAMPLES_MODE(x) (((x) > 0xFF) ? 1 : 0)
  98. /* ADXL372_STATUS_1 */
  99. #define ADXL372_STATUS_1_DATA_RDY(x) (((x) >> 0) & 0x1)
  100. #define ADXL372_STATUS_1_FIFO_RDY(x) (((x) >> 1) & 0x1)
  101. #define ADXL372_STATUS_1_FIFO_FULL(x) (((x) >> 2) & 0x1)
  102. #define ADXL372_STATUS_1_FIFO_OVR(x) (((x) >> 3) & 0x1)
  103. #define ADXL372_STATUS_1_USR_NVM_BUSY(x) (((x) >> 5) & 0x1)
  104. #define ADXL372_STATUS_1_AWAKE(x) (((x) >> 6) & 0x1)
  105. #define ADXL372_STATUS_1_ERR_USR_REGS(x) (((x) >> 7) & 0x1)
  106. /* ADXL372_STATUS_2 */
  107. #define ADXL372_STATUS_2_INACT(x) (((x) >> 4) & 0x1)
  108. #define ADXL372_STATUS_2_ACT(x) (((x) >> 5) & 0x1)
  109. #define ADXL372_STATUS_2_AC2(x) (((x) >> 6) & 0x1)
  110. /* ADXL372_INT1_MAP */
  111. #define ADXL372_INT1_MAP_DATA_RDY_MSK BIT(0)
  112. #define ADXL372_INT1_MAP_DATA_RDY_MODE(x) (((x) & 0x1) << 0)
  113. #define ADXL372_INT1_MAP_FIFO_RDY_MSK BIT(1)
  114. #define ADXL372_INT1_MAP_FIFO_RDY_MODE(x) (((x) & 0x1) << 1)
  115. #define ADXL372_INT1_MAP_FIFO_FULL_MSK BIT(2)
  116. #define ADXL372_INT1_MAP_FIFO_FULL_MODE(x) (((x) & 0x1) << 2)
  117. #define ADXL372_INT1_MAP_FIFO_OVR_MSK BIT(3)
  118. #define ADXL372_INT1_MAP_FIFO_OVR_MODE(x) (((x) & 0x1) << 3)
  119. #define ADXL372_INT1_MAP_INACT_MSK BIT(4)
  120. #define ADXL372_INT1_MAP_INACT_MODE(x) (((x) & 0x1) << 4)
  121. #define ADXL372_INT1_MAP_ACT_MSK BIT(5)
  122. #define ADXL372_INT1_MAP_ACT_MODE(x) (((x) & 0x1) << 5)
  123. #define ADXL372_INT1_MAP_AWAKE_MSK BIT(6)
  124. #define ADXL372_INT1_MAP_AWAKE_MODE(x) (((x) & 0x1) << 6)
  125. #define ADXL372_INT1_MAP_LOW_MSK BIT(7)
  126. #define ADXL372_INT1_MAP_LOW_MODE(x) (((x) & 0x1) << 7)
  127. /* ADX372_THRESH */
  128. #define ADXL372_THRESH_VAL_H_MSK GENMASK(10, 3)
  129. #define ADXL372_THRESH_VAL_H_SEL(x) FIELD_GET(ADXL372_THRESH_VAL_H_MSK, x)
  130. #define ADXL372_THRESH_VAL_L_MSK GENMASK(2, 0)
  131. #define ADXL372_THRESH_VAL_L_SEL(x) FIELD_GET(ADXL372_THRESH_VAL_L_MSK, x)
  132. /* The ADXL372 includes a deep, 512 sample FIFO buffer */
  133. #define ADXL372_FIFO_SIZE 512
  134. #define ADXL372_X_AXIS_EN(x) ((x) & BIT(0))
  135. #define ADXL372_Y_AXIS_EN(x) ((x) & BIT(1))
  136. #define ADXL372_Z_AXIS_EN(x) ((x) & BIT(2))
  137. /*
  138. * At +/- 200g with 12-bit resolution, scale is computed as:
  139. * (200 + 200) * 9.81 / (2^12 - 1) = 0.958241
  140. */
  141. #define ADXL372_USCALE 958241
  142. enum adxl372_op_mode {
  143. ADXL372_STANDBY,
  144. ADXL372_WAKE_UP,
  145. ADXL372_INSTANT_ON,
  146. ADXL372_FULL_BW_MEASUREMENT,
  147. };
  148. enum adxl372_act_proc_mode {
  149. ADXL372_DEFAULT,
  150. ADXL372_LINKED,
  151. ADXL372_LOOPED,
  152. };
  153. enum adxl372_th_activity {
  154. ADXL372_ACTIVITY,
  155. ADXL372_ACTIVITY2,
  156. ADXL372_INACTIVITY,
  157. };
  158. enum adxl372_odr {
  159. ADXL372_ODR_400HZ,
  160. ADXL372_ODR_800HZ,
  161. ADXL372_ODR_1600HZ,
  162. ADXL372_ODR_3200HZ,
  163. ADXL372_ODR_6400HZ,
  164. };
  165. enum adxl372_bandwidth {
  166. ADXL372_BW_200HZ,
  167. ADXL372_BW_400HZ,
  168. ADXL372_BW_800HZ,
  169. ADXL372_BW_1600HZ,
  170. ADXL372_BW_3200HZ,
  171. };
  172. static const unsigned int adxl372_th_reg_high_addr[3] = {
  173. [ADXL372_ACTIVITY] = ADXL372_X_THRESH_ACT_H,
  174. [ADXL372_ACTIVITY2] = ADXL372_X_THRESH_ACT2_H,
  175. [ADXL372_INACTIVITY] = ADXL372_X_THRESH_INACT_H,
  176. };
  177. enum adxl372_fifo_format {
  178. ADXL372_XYZ_FIFO,
  179. ADXL372_X_FIFO,
  180. ADXL372_Y_FIFO,
  181. ADXL372_XY_FIFO,
  182. ADXL372_Z_FIFO,
  183. ADXL372_XZ_FIFO,
  184. ADXL372_YZ_FIFO,
  185. ADXL372_XYZ_PEAK_FIFO,
  186. };
  187. enum adxl372_fifo_mode {
  188. ADXL372_FIFO_BYPASSED,
  189. ADXL372_FIFO_STREAMED,
  190. ADXL372_FIFO_TRIGGERED,
  191. ADXL372_FIFO_OLD_SAVED
  192. };
  193. static const int adxl372_samp_freq_tbl[5] = {
  194. 400, 800, 1600, 3200, 6400,
  195. };
  196. static const int adxl372_bw_freq_tbl[5] = {
  197. 200, 400, 800, 1600, 3200,
  198. };
  199. struct adxl372_axis_lookup {
  200. unsigned int bits;
  201. enum adxl372_fifo_format fifo_format;
  202. };
  203. static const struct adxl372_axis_lookup adxl372_axis_lookup_table[] = {
  204. { BIT(0), ADXL372_X_FIFO },
  205. { BIT(1), ADXL372_Y_FIFO },
  206. { BIT(2), ADXL372_Z_FIFO },
  207. { BIT(0) | BIT(1), ADXL372_XY_FIFO },
  208. { BIT(0) | BIT(2), ADXL372_XZ_FIFO },
  209. { BIT(1) | BIT(2), ADXL372_YZ_FIFO },
  210. { BIT(0) | BIT(1) | BIT(2), ADXL372_XYZ_FIFO },
  211. };
  212. static const struct iio_event_spec adxl372_events[] = {
  213. {
  214. .type = IIO_EV_TYPE_THRESH,
  215. .dir = IIO_EV_DIR_RISING,
  216. .mask_separate = BIT(IIO_EV_INFO_VALUE),
  217. .mask_shared_by_all = BIT(IIO_EV_INFO_PERIOD) | BIT(IIO_EV_INFO_ENABLE),
  218. }, {
  219. .type = IIO_EV_TYPE_THRESH,
  220. .dir = IIO_EV_DIR_FALLING,
  221. .mask_separate = BIT(IIO_EV_INFO_VALUE),
  222. .mask_shared_by_all = BIT(IIO_EV_INFO_PERIOD) | BIT(IIO_EV_INFO_ENABLE),
  223. },
  224. };
  225. #define ADXL372_ACCEL_CHANNEL(index, reg, axis) { \
  226. .type = IIO_ACCEL, \
  227. .address = reg, \
  228. .modified = 1, \
  229. .channel2 = IIO_MOD_##axis, \
  230. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
  231. .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \
  232. BIT(IIO_CHAN_INFO_SAMP_FREQ) | \
  233. BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY), \
  234. .scan_index = index, \
  235. .scan_type = { \
  236. .sign = 's', \
  237. .realbits = 12, \
  238. .storagebits = 16, \
  239. .shift = 4, \
  240. .endianness = IIO_BE, \
  241. }, \
  242. .event_spec = adxl372_events, \
  243. .num_event_specs = ARRAY_SIZE(adxl372_events) \
  244. }
  245. static const struct iio_chan_spec adxl372_channels[] = {
  246. ADXL372_ACCEL_CHANNEL(0, ADXL372_X_DATA_H, X),
  247. ADXL372_ACCEL_CHANNEL(1, ADXL372_Y_DATA_H, Y),
  248. ADXL372_ACCEL_CHANNEL(2, ADXL372_Z_DATA_H, Z),
  249. };
  250. struct adxl372_state {
  251. int irq;
  252. struct device *dev;
  253. struct regmap *regmap;
  254. struct iio_trigger *dready_trig;
  255. struct iio_trigger *peak_datardy_trig;
  256. enum adxl372_fifo_mode fifo_mode;
  257. enum adxl372_fifo_format fifo_format;
  258. unsigned int fifo_axis_mask;
  259. enum adxl372_op_mode op_mode;
  260. enum adxl372_act_proc_mode act_proc_mode;
  261. enum adxl372_odr odr;
  262. enum adxl372_bandwidth bw;
  263. u32 act_time_ms;
  264. u32 inact_time_ms;
  265. u8 fifo_set_size;
  266. unsigned long int1_bitmask;
  267. u16 watermark;
  268. __be16 fifo_buf[ADXL372_FIFO_SIZE];
  269. bool peak_fifo_mode_en;
  270. struct mutex threshold_m; /* lock for threshold */
  271. };
  272. static const unsigned long adxl372_channel_masks[] = {
  273. BIT(0), BIT(1), BIT(2),
  274. BIT(0) | BIT(1),
  275. BIT(0) | BIT(2),
  276. BIT(1) | BIT(2),
  277. BIT(0) | BIT(1) | BIT(2),
  278. 0
  279. };
  280. static ssize_t adxl372_read_threshold_value(struct iio_dev *indio_dev, unsigned int addr,
  281. u16 *threshold)
  282. {
  283. struct adxl372_state *st = iio_priv(indio_dev);
  284. __be16 raw_regval;
  285. u16 regval;
  286. int ret;
  287. ret = regmap_bulk_read(st->regmap, addr, &raw_regval, sizeof(raw_regval));
  288. if (ret < 0)
  289. return ret;
  290. regval = be16_to_cpu(raw_regval);
  291. regval >>= 5;
  292. *threshold = regval;
  293. return 0;
  294. }
  295. static ssize_t adxl372_write_threshold_value(struct iio_dev *indio_dev, unsigned int addr,
  296. u16 threshold)
  297. {
  298. struct adxl372_state *st = iio_priv(indio_dev);
  299. int ret;
  300. mutex_lock(&st->threshold_m);
  301. ret = regmap_write(st->regmap, addr, ADXL372_THRESH_VAL_H_SEL(threshold));
  302. if (ret < 0)
  303. goto unlock;
  304. ret = regmap_update_bits(st->regmap, addr + 1, GENMASK(7, 5),
  305. ADXL372_THRESH_VAL_L_SEL(threshold) << 5);
  306. unlock:
  307. mutex_unlock(&st->threshold_m);
  308. return ret;
  309. }
  310. static int adxl372_read_axis(struct adxl372_state *st, u8 addr)
  311. {
  312. __be16 regval;
  313. int ret;
  314. ret = regmap_bulk_read(st->regmap, addr, &regval, sizeof(regval));
  315. if (ret < 0)
  316. return ret;
  317. return be16_to_cpu(regval);
  318. }
  319. static int adxl372_set_op_mode(struct adxl372_state *st,
  320. enum adxl372_op_mode op_mode)
  321. {
  322. int ret;
  323. ret = regmap_update_bits(st->regmap, ADXL372_POWER_CTL,
  324. ADXL372_POWER_CTL_MODE_MSK,
  325. ADXL372_POWER_CTL_MODE(op_mode));
  326. if (ret < 0)
  327. return ret;
  328. st->op_mode = op_mode;
  329. return ret;
  330. }
  331. static int adxl372_set_odr(struct adxl372_state *st,
  332. enum adxl372_odr odr)
  333. {
  334. int ret;
  335. ret = regmap_update_bits(st->regmap, ADXL372_TIMING,
  336. ADXL372_TIMING_ODR_MSK,
  337. ADXL372_TIMING_ODR_MODE(odr));
  338. if (ret < 0)
  339. return ret;
  340. st->odr = odr;
  341. return ret;
  342. }
  343. static int adxl372_find_closest_match(const int *array,
  344. unsigned int size, int val)
  345. {
  346. int i;
  347. for (i = 0; i < size; i++) {
  348. if (val <= array[i])
  349. return i;
  350. }
  351. return size - 1;
  352. }
  353. static int adxl372_set_bandwidth(struct adxl372_state *st,
  354. enum adxl372_bandwidth bw)
  355. {
  356. int ret;
  357. ret = regmap_update_bits(st->regmap, ADXL372_MEASURE,
  358. ADXL372_MEASURE_BANDWIDTH_MSK,
  359. ADXL372_MEASURE_BANDWIDTH_MODE(bw));
  360. if (ret < 0)
  361. return ret;
  362. st->bw = bw;
  363. return ret;
  364. }
  365. static int adxl372_set_act_proc_mode(struct adxl372_state *st,
  366. enum adxl372_act_proc_mode mode)
  367. {
  368. int ret;
  369. ret = regmap_update_bits(st->regmap,
  370. ADXL372_MEASURE,
  371. ADXL372_MEASURE_LINKLOOP_MSK,
  372. ADXL372_MEASURE_LINKLOOP_MODE(mode));
  373. if (ret < 0)
  374. return ret;
  375. st->act_proc_mode = mode;
  376. return ret;
  377. }
  378. static int adxl372_set_activity_threshold(struct adxl372_state *st,
  379. enum adxl372_th_activity act,
  380. bool ref_en, bool enable,
  381. unsigned int threshold)
  382. {
  383. unsigned char buf[6];
  384. unsigned char th_reg_high_val, th_reg_low_val, th_reg_high_addr;
  385. /* scale factor is 100 mg/code */
  386. th_reg_high_val = (threshold / 100) >> 3;
  387. th_reg_low_val = ((threshold / 100) << 5) | (ref_en << 1) | enable;
  388. th_reg_high_addr = adxl372_th_reg_high_addr[act];
  389. buf[0] = th_reg_high_val;
  390. buf[1] = th_reg_low_val;
  391. buf[2] = th_reg_high_val;
  392. buf[3] = th_reg_low_val;
  393. buf[4] = th_reg_high_val;
  394. buf[5] = th_reg_low_val;
  395. return regmap_bulk_write(st->regmap, th_reg_high_addr,
  396. buf, ARRAY_SIZE(buf));
  397. }
  398. static int adxl372_set_activity_time_ms(struct adxl372_state *st,
  399. unsigned int act_time_ms)
  400. {
  401. unsigned int reg_val, scale_factor;
  402. int ret;
  403. /*
  404. * 3.3 ms per code is the scale factor of the TIME_ACT register for
  405. * ODR = 6400 Hz. It is 6.6 ms per code for ODR = 3200 Hz and below.
  406. */
  407. if (st->odr == ADXL372_ODR_6400HZ)
  408. scale_factor = 3300;
  409. else
  410. scale_factor = 6600;
  411. reg_val = DIV_ROUND_CLOSEST(act_time_ms * 1000, scale_factor);
  412. /* TIME_ACT register is 8 bits wide */
  413. if (reg_val > 0xFF)
  414. reg_val = 0xFF;
  415. ret = regmap_write(st->regmap, ADXL372_TIME_ACT, reg_val);
  416. if (ret < 0)
  417. return ret;
  418. st->act_time_ms = act_time_ms;
  419. return ret;
  420. }
  421. static int adxl372_set_inactivity_time_ms(struct adxl372_state *st,
  422. unsigned int inact_time_ms)
  423. {
  424. unsigned int reg_val_h, reg_val_l, res, scale_factor;
  425. int ret;
  426. /*
  427. * 13 ms per code is the scale factor of the TIME_INACT register for
  428. * ODR = 6400 Hz. It is 26 ms per code for ODR = 3200 Hz and below.
  429. */
  430. if (st->odr == ADXL372_ODR_6400HZ)
  431. scale_factor = 13;
  432. else
  433. scale_factor = 26;
  434. res = DIV_ROUND_CLOSEST(inact_time_ms, scale_factor);
  435. reg_val_h = (res >> 8) & 0xFF;
  436. reg_val_l = res & 0xFF;
  437. ret = regmap_write(st->regmap, ADXL372_TIME_INACT_H, reg_val_h);
  438. if (ret < 0)
  439. return ret;
  440. ret = regmap_write(st->regmap, ADXL372_TIME_INACT_L, reg_val_l);
  441. if (ret < 0)
  442. return ret;
  443. st->inact_time_ms = inact_time_ms;
  444. return ret;
  445. }
  446. static int adxl372_set_interrupts(struct adxl372_state *st,
  447. unsigned long int1_bitmask,
  448. unsigned long int2_bitmask)
  449. {
  450. int ret;
  451. ret = regmap_write(st->regmap, ADXL372_INT1_MAP, int1_bitmask);
  452. if (ret < 0)
  453. return ret;
  454. return regmap_write(st->regmap, ADXL372_INT2_MAP, int2_bitmask);
  455. }
  456. static int adxl372_configure_fifo(struct adxl372_state *st)
  457. {
  458. unsigned int fifo_samples, fifo_ctl;
  459. int ret;
  460. /* FIFO must be configured while in standby mode */
  461. ret = adxl372_set_op_mode(st, ADXL372_STANDBY);
  462. if (ret < 0)
  463. return ret;
  464. /*
  465. * watermark stores the number of sets; we need to write the FIFO
  466. * registers with the number of samples
  467. */
  468. fifo_samples = (st->watermark * st->fifo_set_size);
  469. fifo_ctl = ADXL372_FIFO_CTL_FORMAT_MODE(st->fifo_format) |
  470. ADXL372_FIFO_CTL_MODE_MODE(st->fifo_mode) |
  471. ADXL372_FIFO_CTL_SAMPLES_MODE(fifo_samples);
  472. ret = regmap_write(st->regmap,
  473. ADXL372_FIFO_SAMPLES, fifo_samples & 0xFF);
  474. if (ret < 0)
  475. return ret;
  476. ret = regmap_write(st->regmap, ADXL372_FIFO_CTL, fifo_ctl);
  477. if (ret < 0)
  478. return ret;
  479. return adxl372_set_op_mode(st, ADXL372_FULL_BW_MEASUREMENT);
  480. }
  481. static int adxl372_get_status(struct adxl372_state *st,
  482. u8 *status1, u8 *status2,
  483. u16 *fifo_entries)
  484. {
  485. __be32 buf;
  486. u32 val;
  487. int ret;
  488. /* STATUS1, STATUS2, FIFO_ENTRIES2 and FIFO_ENTRIES are adjacent regs */
  489. ret = regmap_bulk_read(st->regmap, ADXL372_STATUS_1,
  490. &buf, sizeof(buf));
  491. if (ret < 0)
  492. return ret;
  493. val = be32_to_cpu(buf);
  494. *status1 = (val >> 24) & 0x0F;
  495. *status2 = (val >> 16) & 0x0F;
  496. /*
  497. * FIFO_ENTRIES contains the least significant byte, and FIFO_ENTRIES2
  498. * contains the two most significant bits
  499. */
  500. *fifo_entries = val & 0x3FF;
  501. return ret;
  502. }
  503. static void adxl372_arrange_axis_data(struct adxl372_state *st, __be16 *sample)
  504. {
  505. __be16 axis_sample[3] = { };
  506. int i = 0;
  507. if (ADXL372_X_AXIS_EN(st->fifo_axis_mask))
  508. axis_sample[i++] = sample[0];
  509. if (ADXL372_Y_AXIS_EN(st->fifo_axis_mask))
  510. axis_sample[i++] = sample[1];
  511. if (ADXL372_Z_AXIS_EN(st->fifo_axis_mask))
  512. axis_sample[i++] = sample[2];
  513. memcpy(sample, axis_sample, 3 * sizeof(__be16));
  514. }
  515. static void adxl372_push_event(struct iio_dev *indio_dev, s64 timestamp, u8 status2)
  516. {
  517. unsigned int ev_dir = IIO_EV_DIR_NONE;
  518. if (ADXL372_STATUS_2_ACT(status2))
  519. ev_dir = IIO_EV_DIR_RISING;
  520. if (ADXL372_STATUS_2_INACT(status2))
  521. ev_dir = IIO_EV_DIR_FALLING;
  522. if (ev_dir != IIO_EV_DIR_NONE)
  523. iio_push_event(indio_dev,
  524. IIO_MOD_EVENT_CODE(IIO_ACCEL, 0, IIO_MOD_X_OR_Y_OR_Z,
  525. IIO_EV_TYPE_THRESH, ev_dir),
  526. timestamp);
  527. }
  528. static irqreturn_t adxl372_trigger_handler(int irq, void *p)
  529. {
  530. struct iio_poll_func *pf = p;
  531. struct iio_dev *indio_dev = pf->indio_dev;
  532. struct adxl372_state *st = iio_priv(indio_dev);
  533. u8 status1, status2;
  534. u16 fifo_entries;
  535. int i, ret;
  536. ret = adxl372_get_status(st, &status1, &status2, &fifo_entries);
  537. if (ret < 0)
  538. goto err;
  539. adxl372_push_event(indio_dev, iio_get_time_ns(indio_dev), status2);
  540. if (st->fifo_mode != ADXL372_FIFO_BYPASSED &&
  541. ADXL372_STATUS_1_FIFO_FULL(status1)) {
  542. /*
  543. * When reading data from multiple axes from the FIFO,
  544. * to ensure that data is not overwritten and stored out
  545. * of order at least one sample set must be left in the
  546. * FIFO after every read.
  547. */
  548. fifo_entries -= st->fifo_set_size;
  549. /* Read data from the FIFO */
  550. ret = regmap_noinc_read(st->regmap, ADXL372_FIFO_DATA,
  551. st->fifo_buf,
  552. fifo_entries * sizeof(u16));
  553. if (ret < 0)
  554. goto err;
  555. /* Each sample is 2 bytes */
  556. for (i = 0; i < fifo_entries; i += st->fifo_set_size) {
  557. /* filter peak detection data */
  558. if (st->peak_fifo_mode_en)
  559. adxl372_arrange_axis_data(st, &st->fifo_buf[i]);
  560. iio_push_to_buffers(indio_dev, &st->fifo_buf[i]);
  561. }
  562. }
  563. err:
  564. iio_trigger_notify_done(indio_dev->trig);
  565. return IRQ_HANDLED;
  566. }
  567. static int adxl372_setup(struct adxl372_state *st)
  568. {
  569. unsigned int regval;
  570. int ret;
  571. ret = regmap_read(st->regmap, ADXL372_DEVID, &regval);
  572. if (ret < 0)
  573. return ret;
  574. if (regval != ADXL372_DEVID_VAL) {
  575. dev_err(st->dev, "Invalid chip id %x\n", regval);
  576. return -ENODEV;
  577. }
  578. /*
  579. * Perform a software reset to make sure the device is in a consistent
  580. * state after start up.
  581. */
  582. ret = regmap_write(st->regmap, ADXL372_RESET, ADXL372_RESET_CODE);
  583. if (ret < 0)
  584. return ret;
  585. ret = adxl372_set_op_mode(st, ADXL372_STANDBY);
  586. if (ret < 0)
  587. return ret;
  588. /* Set threshold for activity detection to 1g */
  589. ret = adxl372_set_activity_threshold(st, ADXL372_ACTIVITY,
  590. true, true, 1000);
  591. if (ret < 0)
  592. return ret;
  593. /* Set threshold for inactivity detection to 100mg */
  594. ret = adxl372_set_activity_threshold(st, ADXL372_INACTIVITY,
  595. true, true, 100);
  596. if (ret < 0)
  597. return ret;
  598. /* Set activity processing in Looped mode */
  599. ret = adxl372_set_act_proc_mode(st, ADXL372_LOOPED);
  600. if (ret < 0)
  601. return ret;
  602. ret = adxl372_set_odr(st, ADXL372_ODR_6400HZ);
  603. if (ret < 0)
  604. return ret;
  605. ret = adxl372_set_bandwidth(st, ADXL372_BW_3200HZ);
  606. if (ret < 0)
  607. return ret;
  608. /* Set activity timer to 1ms */
  609. ret = adxl372_set_activity_time_ms(st, 1);
  610. if (ret < 0)
  611. return ret;
  612. /* Set inactivity timer to 10s */
  613. ret = adxl372_set_inactivity_time_ms(st, 10000);
  614. if (ret < 0)
  615. return ret;
  616. /* Set the mode of operation to full bandwidth measurement mode */
  617. return adxl372_set_op_mode(st, ADXL372_FULL_BW_MEASUREMENT);
  618. }
  619. static int adxl372_reg_access(struct iio_dev *indio_dev,
  620. unsigned int reg,
  621. unsigned int writeval,
  622. unsigned int *readval)
  623. {
  624. struct adxl372_state *st = iio_priv(indio_dev);
  625. if (readval)
  626. return regmap_read(st->regmap, reg, readval);
  627. else
  628. return regmap_write(st->regmap, reg, writeval);
  629. }
  630. static int adxl372_read_raw(struct iio_dev *indio_dev,
  631. struct iio_chan_spec const *chan,
  632. int *val, int *val2, long info)
  633. {
  634. struct adxl372_state *st = iio_priv(indio_dev);
  635. int ret;
  636. switch (info) {
  637. case IIO_CHAN_INFO_RAW:
  638. if (!iio_device_claim_direct(indio_dev))
  639. return -EBUSY;
  640. ret = adxl372_read_axis(st, chan->address);
  641. iio_device_release_direct(indio_dev);
  642. if (ret < 0)
  643. return ret;
  644. *val = sign_extend32(ret >> chan->scan_type.shift,
  645. chan->scan_type.realbits - 1);
  646. return IIO_VAL_INT;
  647. case IIO_CHAN_INFO_SCALE:
  648. *val = 0;
  649. *val2 = ADXL372_USCALE;
  650. return IIO_VAL_INT_PLUS_MICRO;
  651. case IIO_CHAN_INFO_SAMP_FREQ:
  652. *val = adxl372_samp_freq_tbl[st->odr];
  653. return IIO_VAL_INT;
  654. case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
  655. *val = adxl372_bw_freq_tbl[st->bw];
  656. return IIO_VAL_INT;
  657. }
  658. return -EINVAL;
  659. }
  660. static int adxl372_write_raw(struct iio_dev *indio_dev,
  661. struct iio_chan_spec const *chan,
  662. int val, int val2, long info)
  663. {
  664. struct adxl372_state *st = iio_priv(indio_dev);
  665. int odr_index, bw_index, ret;
  666. switch (info) {
  667. case IIO_CHAN_INFO_SAMP_FREQ:
  668. odr_index = adxl372_find_closest_match(adxl372_samp_freq_tbl,
  669. ARRAY_SIZE(adxl372_samp_freq_tbl),
  670. val);
  671. ret = adxl372_set_odr(st, odr_index);
  672. if (ret < 0)
  673. return ret;
  674. /*
  675. * The timer period depends on the ODR selected.
  676. * At 3200 Hz and below, it is 6.6 ms; at 6400 Hz, it is 3.3 ms
  677. */
  678. ret = adxl372_set_activity_time_ms(st, st->act_time_ms);
  679. if (ret < 0)
  680. return ret;
  681. /*
  682. * The timer period depends on the ODR selected.
  683. * At 3200 Hz and below, it is 26 ms; at 6400 Hz, it is 13 ms
  684. */
  685. ret = adxl372_set_inactivity_time_ms(st, st->inact_time_ms);
  686. if (ret < 0)
  687. return ret;
  688. /*
  689. * The maximum bandwidth is constrained to at most half of
  690. * the ODR to ensure that the Nyquist criteria is not violated
  691. */
  692. if (st->bw > odr_index)
  693. ret = adxl372_set_bandwidth(st, odr_index);
  694. return ret;
  695. case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
  696. bw_index = adxl372_find_closest_match(adxl372_bw_freq_tbl,
  697. ARRAY_SIZE(adxl372_bw_freq_tbl),
  698. val);
  699. return adxl372_set_bandwidth(st, bw_index);
  700. default:
  701. return -EINVAL;
  702. }
  703. }
  704. static int adxl372_read_event_value(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  705. enum iio_event_type type, enum iio_event_direction dir,
  706. enum iio_event_info info, int *val, int *val2)
  707. {
  708. struct adxl372_state *st = iio_priv(indio_dev);
  709. unsigned int addr;
  710. u16 raw_value;
  711. int ret;
  712. switch (info) {
  713. case IIO_EV_INFO_VALUE:
  714. switch (dir) {
  715. case IIO_EV_DIR_RISING:
  716. addr = ADXL372_X_THRESH_ACT_H + 2 * chan->scan_index;
  717. ret = adxl372_read_threshold_value(indio_dev, addr, &raw_value);
  718. if (ret < 0)
  719. return ret;
  720. *val = raw_value * ADXL372_USCALE;
  721. *val2 = 1000000;
  722. return IIO_VAL_FRACTIONAL;
  723. case IIO_EV_DIR_FALLING:
  724. addr = ADXL372_X_THRESH_INACT_H + 2 * chan->scan_index;
  725. ret = adxl372_read_threshold_value(indio_dev, addr, &raw_value);
  726. if (ret < 0)
  727. return ret;
  728. *val = raw_value * ADXL372_USCALE;
  729. *val2 = 1000000;
  730. return IIO_VAL_FRACTIONAL;
  731. default:
  732. return -EINVAL;
  733. }
  734. case IIO_EV_INFO_PERIOD:
  735. switch (dir) {
  736. case IIO_EV_DIR_RISING:
  737. *val = st->act_time_ms;
  738. *val2 = 1000;
  739. return IIO_VAL_FRACTIONAL;
  740. case IIO_EV_DIR_FALLING:
  741. *val = st->inact_time_ms;
  742. *val2 = 1000;
  743. return IIO_VAL_FRACTIONAL;
  744. default:
  745. return -EINVAL;
  746. }
  747. default:
  748. return -EINVAL;
  749. }
  750. }
  751. static int adxl372_write_event_value(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  752. enum iio_event_type type, enum iio_event_direction dir,
  753. enum iio_event_info info, int val, int val2)
  754. {
  755. struct adxl372_state *st = iio_priv(indio_dev);
  756. unsigned int val_ms;
  757. unsigned int addr;
  758. u16 raw_val;
  759. switch (info) {
  760. case IIO_EV_INFO_VALUE:
  761. raw_val = DIV_ROUND_UP(val * 1000000, ADXL372_USCALE);
  762. switch (dir) {
  763. case IIO_EV_DIR_RISING:
  764. addr = ADXL372_X_THRESH_ACT_H + 2 * chan->scan_index;
  765. return adxl372_write_threshold_value(indio_dev, addr, raw_val);
  766. case IIO_EV_DIR_FALLING:
  767. addr = ADXL372_X_THRESH_INACT_H + 2 * chan->scan_index;
  768. return adxl372_write_threshold_value(indio_dev, addr, raw_val);
  769. default:
  770. return -EINVAL;
  771. }
  772. case IIO_EV_INFO_PERIOD:
  773. val_ms = val * 1000 + DIV_ROUND_UP(val2, 1000);
  774. switch (dir) {
  775. case IIO_EV_DIR_RISING:
  776. return adxl372_set_activity_time_ms(st, val_ms);
  777. case IIO_EV_DIR_FALLING:
  778. return adxl372_set_inactivity_time_ms(st, val_ms);
  779. default:
  780. return -EINVAL;
  781. }
  782. default:
  783. return -EINVAL;
  784. }
  785. }
  786. static int adxl372_read_event_config(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  787. enum iio_event_type type, enum iio_event_direction dir)
  788. {
  789. struct adxl372_state *st = iio_priv(indio_dev);
  790. switch (dir) {
  791. case IIO_EV_DIR_RISING:
  792. return FIELD_GET(ADXL372_INT1_MAP_ACT_MSK, st->int1_bitmask);
  793. case IIO_EV_DIR_FALLING:
  794. return FIELD_GET(ADXL372_INT1_MAP_INACT_MSK, st->int1_bitmask);
  795. default:
  796. return -EINVAL;
  797. }
  798. }
  799. static int adxl372_write_event_config(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  800. enum iio_event_type type, enum iio_event_direction dir,
  801. bool state)
  802. {
  803. struct adxl372_state *st = iio_priv(indio_dev);
  804. switch (dir) {
  805. case IIO_EV_DIR_RISING:
  806. set_mask_bits(&st->int1_bitmask, ADXL372_INT1_MAP_ACT_MSK,
  807. ADXL372_INT1_MAP_ACT_MODE(state));
  808. break;
  809. case IIO_EV_DIR_FALLING:
  810. set_mask_bits(&st->int1_bitmask, ADXL372_INT1_MAP_INACT_MSK,
  811. ADXL372_INT1_MAP_INACT_MODE(state));
  812. break;
  813. default:
  814. return -EINVAL;
  815. }
  816. return adxl372_set_interrupts(st, st->int1_bitmask, 0);
  817. }
  818. static ssize_t adxl372_show_filter_freq_avail(struct device *dev,
  819. struct device_attribute *attr,
  820. char *buf)
  821. {
  822. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  823. struct adxl372_state *st = iio_priv(indio_dev);
  824. int i;
  825. size_t len = 0;
  826. for (i = 0; i <= st->odr; i++)
  827. len += scnprintf(buf + len, PAGE_SIZE - len,
  828. "%d ", adxl372_bw_freq_tbl[i]);
  829. buf[len - 1] = '\n';
  830. return len;
  831. }
  832. static ssize_t adxl372_get_fifo_enabled(struct device *dev,
  833. struct device_attribute *attr,
  834. char *buf)
  835. {
  836. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  837. struct adxl372_state *st = iio_priv(indio_dev);
  838. return sprintf(buf, "%d\n", st->fifo_mode);
  839. }
  840. static ssize_t adxl372_get_fifo_watermark(struct device *dev,
  841. struct device_attribute *attr,
  842. char *buf)
  843. {
  844. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  845. struct adxl372_state *st = iio_priv(indio_dev);
  846. return sprintf(buf, "%d\n", st->watermark);
  847. }
  848. IIO_STATIC_CONST_DEVICE_ATTR(hwfifo_watermark_min, "1");
  849. IIO_STATIC_CONST_DEVICE_ATTR(hwfifo_watermark_max,
  850. __stringify(ADXL372_FIFO_SIZE));
  851. static IIO_DEVICE_ATTR(hwfifo_watermark, 0444,
  852. adxl372_get_fifo_watermark, NULL, 0);
  853. static IIO_DEVICE_ATTR(hwfifo_enabled, 0444,
  854. adxl372_get_fifo_enabled, NULL, 0);
  855. static const struct iio_dev_attr *adxl372_fifo_attributes[] = {
  856. &iio_dev_attr_hwfifo_watermark_min,
  857. &iio_dev_attr_hwfifo_watermark_max,
  858. &iio_dev_attr_hwfifo_watermark,
  859. &iio_dev_attr_hwfifo_enabled,
  860. NULL,
  861. };
  862. static int adxl372_set_watermark(struct iio_dev *indio_dev, unsigned int val)
  863. {
  864. struct adxl372_state *st = iio_priv(indio_dev);
  865. if (val > ADXL372_FIFO_SIZE)
  866. val = ADXL372_FIFO_SIZE;
  867. st->watermark = val;
  868. return 0;
  869. }
  870. static int adxl372_buffer_postenable(struct iio_dev *indio_dev)
  871. {
  872. struct adxl372_state *st = iio_priv(indio_dev);
  873. unsigned int mask;
  874. int i, ret;
  875. st->int1_bitmask |= ADXL372_INT1_MAP_FIFO_FULL_MSK;
  876. ret = adxl372_set_interrupts(st, st->int1_bitmask, 0);
  877. if (ret < 0)
  878. return ret;
  879. mask = *indio_dev->active_scan_mask;
  880. for (i = 0; i < ARRAY_SIZE(adxl372_axis_lookup_table); i++) {
  881. if (mask == adxl372_axis_lookup_table[i].bits)
  882. break;
  883. }
  884. if (i == ARRAY_SIZE(adxl372_axis_lookup_table))
  885. return -EINVAL;
  886. st->fifo_format = adxl372_axis_lookup_table[i].fifo_format;
  887. st->fifo_axis_mask = adxl372_axis_lookup_table[i].bits;
  888. st->fifo_set_size = bitmap_weight(indio_dev->active_scan_mask,
  889. iio_get_masklength(indio_dev));
  890. /* Configure the FIFO to store sets of impact event peak. */
  891. if (st->peak_fifo_mode_en) {
  892. st->fifo_set_size = 3;
  893. st->fifo_format = ADXL372_XYZ_PEAK_FIFO;
  894. }
  895. /*
  896. * The 512 FIFO samples can be allotted in several ways, such as:
  897. * 170 sample sets of concurrent 3-axis data
  898. * 256 sample sets of concurrent 2-axis data (user selectable)
  899. * 512 sample sets of single-axis data
  900. * 170 sets of impact event peak (x, y, z)
  901. */
  902. if ((st->watermark * st->fifo_set_size) > ADXL372_FIFO_SIZE)
  903. st->watermark = (ADXL372_FIFO_SIZE / st->fifo_set_size);
  904. st->fifo_mode = ADXL372_FIFO_STREAMED;
  905. ret = adxl372_configure_fifo(st);
  906. if (ret < 0) {
  907. st->fifo_mode = ADXL372_FIFO_BYPASSED;
  908. st->int1_bitmask &= ~ADXL372_INT1_MAP_FIFO_FULL_MSK;
  909. adxl372_set_interrupts(st, st->int1_bitmask, 0);
  910. return ret;
  911. }
  912. return 0;
  913. }
  914. static int adxl372_buffer_predisable(struct iio_dev *indio_dev)
  915. {
  916. struct adxl372_state *st = iio_priv(indio_dev);
  917. st->int1_bitmask &= ~ADXL372_INT1_MAP_FIFO_FULL_MSK;
  918. adxl372_set_interrupts(st, st->int1_bitmask, 0);
  919. st->fifo_mode = ADXL372_FIFO_BYPASSED;
  920. adxl372_configure_fifo(st);
  921. return 0;
  922. }
  923. static const struct iio_buffer_setup_ops adxl372_buffer_ops = {
  924. .postenable = adxl372_buffer_postenable,
  925. .predisable = adxl372_buffer_predisable,
  926. };
  927. static int adxl372_dready_trig_set_state(struct iio_trigger *trig,
  928. bool state)
  929. {
  930. struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig);
  931. struct adxl372_state *st = iio_priv(indio_dev);
  932. if (state)
  933. st->int1_bitmask |= ADXL372_INT1_MAP_FIFO_FULL_MSK;
  934. return adxl372_set_interrupts(st, st->int1_bitmask, 0);
  935. }
  936. static int adxl372_validate_trigger(struct iio_dev *indio_dev,
  937. struct iio_trigger *trig)
  938. {
  939. struct adxl372_state *st = iio_priv(indio_dev);
  940. if (st->dready_trig != trig && st->peak_datardy_trig != trig)
  941. return -EINVAL;
  942. return 0;
  943. }
  944. static const struct iio_trigger_ops adxl372_trigger_ops = {
  945. .validate_device = &iio_trigger_validate_own_device,
  946. .set_trigger_state = adxl372_dready_trig_set_state,
  947. };
  948. static int adxl372_peak_dready_trig_set_state(struct iio_trigger *trig,
  949. bool state)
  950. {
  951. struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig);
  952. struct adxl372_state *st = iio_priv(indio_dev);
  953. if (state)
  954. st->int1_bitmask |= ADXL372_INT1_MAP_FIFO_FULL_MSK;
  955. st->peak_fifo_mode_en = state;
  956. return adxl372_set_interrupts(st, st->int1_bitmask, 0);
  957. }
  958. static const struct iio_trigger_ops adxl372_peak_data_trigger_ops = {
  959. .validate_device = &iio_trigger_validate_own_device,
  960. .set_trigger_state = adxl372_peak_dready_trig_set_state,
  961. };
  962. static IIO_CONST_ATTR_SAMP_FREQ_AVAIL("400 800 1600 3200 6400");
  963. static IIO_DEVICE_ATTR(in_accel_filter_low_pass_3db_frequency_available,
  964. 0444, adxl372_show_filter_freq_avail, NULL, 0);
  965. static struct attribute *adxl372_attributes[] = {
  966. &iio_const_attr_sampling_frequency_available.dev_attr.attr,
  967. &iio_dev_attr_in_accel_filter_low_pass_3db_frequency_available.dev_attr.attr,
  968. NULL,
  969. };
  970. static const struct attribute_group adxl372_attrs_group = {
  971. .attrs = adxl372_attributes,
  972. };
  973. static const struct iio_info adxl372_info = {
  974. .validate_trigger = &adxl372_validate_trigger,
  975. .attrs = &adxl372_attrs_group,
  976. .read_raw = adxl372_read_raw,
  977. .write_raw = adxl372_write_raw,
  978. .read_event_config = adxl372_read_event_config,
  979. .write_event_config = adxl372_write_event_config,
  980. .read_event_value = adxl372_read_event_value,
  981. .write_event_value = adxl372_write_event_value,
  982. .debugfs_reg_access = &adxl372_reg_access,
  983. .hwfifo_set_watermark = adxl372_set_watermark,
  984. };
  985. bool adxl372_readable_noinc_reg(struct device *dev, unsigned int reg)
  986. {
  987. return (reg == ADXL372_FIFO_DATA);
  988. }
  989. EXPORT_SYMBOL_NS_GPL(adxl372_readable_noinc_reg, "IIO_ADXL372");
  990. int adxl372_probe(struct device *dev, struct regmap *regmap,
  991. int irq, const char *name)
  992. {
  993. struct iio_dev *indio_dev;
  994. struct adxl372_state *st;
  995. int ret;
  996. indio_dev = devm_iio_device_alloc(dev, sizeof(*st));
  997. if (!indio_dev)
  998. return -ENOMEM;
  999. st = iio_priv(indio_dev);
  1000. dev_set_drvdata(dev, indio_dev);
  1001. st->dev = dev;
  1002. st->regmap = regmap;
  1003. st->irq = irq;
  1004. mutex_init(&st->threshold_m);
  1005. indio_dev->channels = adxl372_channels;
  1006. indio_dev->num_channels = ARRAY_SIZE(adxl372_channels);
  1007. indio_dev->available_scan_masks = adxl372_channel_masks;
  1008. indio_dev->name = name;
  1009. indio_dev->info = &adxl372_info;
  1010. indio_dev->modes = INDIO_DIRECT_MODE | INDIO_BUFFER_SOFTWARE;
  1011. ret = adxl372_setup(st);
  1012. if (ret < 0) {
  1013. dev_err(dev, "ADXL372 setup failed\n");
  1014. return ret;
  1015. }
  1016. ret = devm_iio_triggered_buffer_setup_ext(dev,
  1017. indio_dev, NULL,
  1018. adxl372_trigger_handler,
  1019. IIO_BUFFER_DIRECTION_IN,
  1020. &adxl372_buffer_ops,
  1021. adxl372_fifo_attributes);
  1022. if (ret < 0)
  1023. return ret;
  1024. if (st->irq) {
  1025. st->dready_trig = devm_iio_trigger_alloc(dev,
  1026. "%s-dev%d",
  1027. indio_dev->name,
  1028. iio_device_id(indio_dev));
  1029. if (st->dready_trig == NULL)
  1030. return -ENOMEM;
  1031. st->peak_datardy_trig = devm_iio_trigger_alloc(dev,
  1032. "%s-dev%d-peak",
  1033. indio_dev->name,
  1034. iio_device_id(indio_dev));
  1035. if (!st->peak_datardy_trig)
  1036. return -ENOMEM;
  1037. st->dready_trig->ops = &adxl372_trigger_ops;
  1038. st->peak_datardy_trig->ops = &adxl372_peak_data_trigger_ops;
  1039. iio_trigger_set_drvdata(st->dready_trig, indio_dev);
  1040. iio_trigger_set_drvdata(st->peak_datardy_trig, indio_dev);
  1041. ret = devm_iio_trigger_register(dev, st->dready_trig);
  1042. if (ret < 0)
  1043. return ret;
  1044. ret = devm_iio_trigger_register(dev, st->peak_datardy_trig);
  1045. if (ret < 0)
  1046. return ret;
  1047. indio_dev->trig = iio_trigger_get(st->dready_trig);
  1048. ret = devm_request_irq(dev, st->irq,
  1049. iio_trigger_generic_data_rdy_poll,
  1050. IRQF_TRIGGER_RISING | IRQF_NO_THREAD,
  1051. indio_dev->name, st->dready_trig);
  1052. if (ret < 0)
  1053. return ret;
  1054. }
  1055. return devm_iio_device_register(dev, indio_dev);
  1056. }
  1057. EXPORT_SYMBOL_NS_GPL(adxl372_probe, "IIO_ADXL372");
  1058. MODULE_AUTHOR("Stefan Popa <stefan.popa@analog.com>");
  1059. MODULE_DESCRIPTION("Analog Devices ADXL372 3-axis accelerometer driver");
  1060. MODULE_LICENSE("GPL");