adxl372.c 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280
  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. unsigned long int2_bitmask;
  268. u16 watermark;
  269. __be16 fifo_buf[ADXL372_FIFO_SIZE];
  270. bool peak_fifo_mode_en;
  271. struct mutex threshold_m; /* lock for threshold */
  272. };
  273. static const unsigned long adxl372_channel_masks[] = {
  274. BIT(0), BIT(1), BIT(2),
  275. BIT(0) | BIT(1),
  276. BIT(0) | BIT(2),
  277. BIT(1) | BIT(2),
  278. BIT(0) | BIT(1) | BIT(2),
  279. 0
  280. };
  281. static ssize_t adxl372_read_threshold_value(struct iio_dev *indio_dev, unsigned int addr,
  282. u16 *threshold)
  283. {
  284. struct adxl372_state *st = iio_priv(indio_dev);
  285. __be16 raw_regval;
  286. u16 regval;
  287. int ret;
  288. ret = regmap_bulk_read(st->regmap, addr, &raw_regval, sizeof(raw_regval));
  289. if (ret < 0)
  290. return ret;
  291. regval = be16_to_cpu(raw_regval);
  292. regval >>= 5;
  293. *threshold = regval;
  294. return 0;
  295. }
  296. static ssize_t adxl372_write_threshold_value(struct iio_dev *indio_dev, unsigned int addr,
  297. u16 threshold)
  298. {
  299. struct adxl372_state *st = iio_priv(indio_dev);
  300. int ret;
  301. mutex_lock(&st->threshold_m);
  302. ret = regmap_write(st->regmap, addr, ADXL372_THRESH_VAL_H_SEL(threshold));
  303. if (ret < 0)
  304. goto unlock;
  305. ret = regmap_update_bits(st->regmap, addr + 1, GENMASK(7, 5),
  306. ADXL372_THRESH_VAL_L_SEL(threshold) << 5);
  307. unlock:
  308. mutex_unlock(&st->threshold_m);
  309. return ret;
  310. }
  311. static int adxl372_read_axis(struct adxl372_state *st, u8 addr)
  312. {
  313. __be16 regval;
  314. int ret;
  315. ret = regmap_bulk_read(st->regmap, addr, &regval, sizeof(regval));
  316. if (ret < 0)
  317. return ret;
  318. return be16_to_cpu(regval);
  319. }
  320. static int adxl372_set_op_mode(struct adxl372_state *st,
  321. enum adxl372_op_mode op_mode)
  322. {
  323. int ret;
  324. ret = regmap_update_bits(st->regmap, ADXL372_POWER_CTL,
  325. ADXL372_POWER_CTL_MODE_MSK,
  326. ADXL372_POWER_CTL_MODE(op_mode));
  327. if (ret < 0)
  328. return ret;
  329. st->op_mode = op_mode;
  330. return ret;
  331. }
  332. static int adxl372_set_odr(struct adxl372_state *st,
  333. enum adxl372_odr odr)
  334. {
  335. int ret;
  336. ret = regmap_update_bits(st->regmap, ADXL372_TIMING,
  337. ADXL372_TIMING_ODR_MSK,
  338. ADXL372_TIMING_ODR_MODE(odr));
  339. if (ret < 0)
  340. return ret;
  341. st->odr = odr;
  342. return ret;
  343. }
  344. static int adxl372_find_closest_match(const int *array,
  345. unsigned int size, int val)
  346. {
  347. int i;
  348. for (i = 0; i < size; i++) {
  349. if (val <= array[i])
  350. return i;
  351. }
  352. return size - 1;
  353. }
  354. static int adxl372_set_bandwidth(struct adxl372_state *st,
  355. enum adxl372_bandwidth bw)
  356. {
  357. int ret;
  358. ret = regmap_update_bits(st->regmap, ADXL372_MEASURE,
  359. ADXL372_MEASURE_BANDWIDTH_MSK,
  360. ADXL372_MEASURE_BANDWIDTH_MODE(bw));
  361. if (ret < 0)
  362. return ret;
  363. st->bw = bw;
  364. return ret;
  365. }
  366. static int adxl372_set_act_proc_mode(struct adxl372_state *st,
  367. enum adxl372_act_proc_mode mode)
  368. {
  369. int ret;
  370. ret = regmap_update_bits(st->regmap,
  371. ADXL372_MEASURE,
  372. ADXL372_MEASURE_LINKLOOP_MSK,
  373. ADXL372_MEASURE_LINKLOOP_MODE(mode));
  374. if (ret < 0)
  375. return ret;
  376. st->act_proc_mode = mode;
  377. return ret;
  378. }
  379. static int adxl372_set_activity_threshold(struct adxl372_state *st,
  380. enum adxl372_th_activity act,
  381. bool ref_en, bool enable,
  382. unsigned int threshold)
  383. {
  384. unsigned char buf[6];
  385. unsigned char th_reg_high_val, th_reg_low_val, th_reg_high_addr;
  386. /* scale factor is 100 mg/code */
  387. th_reg_high_val = (threshold / 100) >> 3;
  388. th_reg_low_val = ((threshold / 100) << 5) | (ref_en << 1) | enable;
  389. th_reg_high_addr = adxl372_th_reg_high_addr[act];
  390. buf[0] = th_reg_high_val;
  391. buf[1] = th_reg_low_val;
  392. buf[2] = th_reg_high_val;
  393. buf[3] = th_reg_low_val;
  394. buf[4] = th_reg_high_val;
  395. buf[5] = th_reg_low_val;
  396. return regmap_bulk_write(st->regmap, th_reg_high_addr,
  397. buf, ARRAY_SIZE(buf));
  398. }
  399. static int adxl372_set_activity_time_ms(struct adxl372_state *st,
  400. unsigned int act_time_ms)
  401. {
  402. unsigned int reg_val, scale_factor;
  403. int ret;
  404. /*
  405. * 3.3 ms per code is the scale factor of the TIME_ACT register for
  406. * ODR = 6400 Hz. It is 6.6 ms per code for ODR = 3200 Hz and below.
  407. */
  408. if (st->odr == ADXL372_ODR_6400HZ)
  409. scale_factor = 3300;
  410. else
  411. scale_factor = 6600;
  412. reg_val = DIV_ROUND_CLOSEST(act_time_ms * 1000, scale_factor);
  413. /* TIME_ACT register is 8 bits wide */
  414. if (reg_val > 0xFF)
  415. reg_val = 0xFF;
  416. ret = regmap_write(st->regmap, ADXL372_TIME_ACT, reg_val);
  417. if (ret < 0)
  418. return ret;
  419. st->act_time_ms = act_time_ms;
  420. return ret;
  421. }
  422. static int adxl372_set_inactivity_time_ms(struct adxl372_state *st,
  423. unsigned int inact_time_ms)
  424. {
  425. unsigned int reg_val_h, reg_val_l, res, scale_factor;
  426. int ret;
  427. /*
  428. * 13 ms per code is the scale factor of the TIME_INACT register for
  429. * ODR = 6400 Hz. It is 26 ms per code for ODR = 3200 Hz and below.
  430. */
  431. if (st->odr == ADXL372_ODR_6400HZ)
  432. scale_factor = 13;
  433. else
  434. scale_factor = 26;
  435. res = DIV_ROUND_CLOSEST(inact_time_ms, scale_factor);
  436. reg_val_h = (res >> 8) & 0xFF;
  437. reg_val_l = res & 0xFF;
  438. ret = regmap_write(st->regmap, ADXL372_TIME_INACT_H, reg_val_h);
  439. if (ret < 0)
  440. return ret;
  441. ret = regmap_write(st->regmap, ADXL372_TIME_INACT_L, reg_val_l);
  442. if (ret < 0)
  443. return ret;
  444. st->inact_time_ms = inact_time_ms;
  445. return ret;
  446. }
  447. static int adxl372_set_interrupts(struct adxl372_state *st,
  448. unsigned long int1_bitmask,
  449. unsigned long int2_bitmask)
  450. {
  451. int ret;
  452. ret = regmap_write(st->regmap, ADXL372_INT1_MAP, int1_bitmask);
  453. if (ret < 0)
  454. return ret;
  455. return regmap_write(st->regmap, ADXL372_INT2_MAP, int2_bitmask);
  456. }
  457. static int adxl372_configure_fifo(struct adxl372_state *st)
  458. {
  459. unsigned int fifo_samples, fifo_ctl;
  460. int ret;
  461. /* FIFO must be configured while in standby mode */
  462. ret = adxl372_set_op_mode(st, ADXL372_STANDBY);
  463. if (ret < 0)
  464. return ret;
  465. /*
  466. * watermark stores the number of sets; we need to write the FIFO
  467. * registers with the number of samples
  468. */
  469. fifo_samples = (st->watermark * st->fifo_set_size);
  470. fifo_ctl = ADXL372_FIFO_CTL_FORMAT_MODE(st->fifo_format) |
  471. ADXL372_FIFO_CTL_MODE_MODE(st->fifo_mode) |
  472. ADXL372_FIFO_CTL_SAMPLES_MODE(fifo_samples);
  473. ret = regmap_write(st->regmap,
  474. ADXL372_FIFO_SAMPLES, fifo_samples & 0xFF);
  475. if (ret < 0)
  476. return ret;
  477. ret = regmap_write(st->regmap, ADXL372_FIFO_CTL, fifo_ctl);
  478. if (ret < 0)
  479. return ret;
  480. return adxl372_set_op_mode(st, ADXL372_FULL_BW_MEASUREMENT);
  481. }
  482. static int adxl372_get_status(struct adxl372_state *st,
  483. u8 *status1, u8 *status2,
  484. u16 *fifo_entries)
  485. {
  486. __be32 buf;
  487. u32 val;
  488. int ret;
  489. /* STATUS1, STATUS2, FIFO_ENTRIES2 and FIFO_ENTRIES are adjacent regs */
  490. ret = regmap_bulk_read(st->regmap, ADXL372_STATUS_1,
  491. &buf, sizeof(buf));
  492. if (ret < 0)
  493. return ret;
  494. val = be32_to_cpu(buf);
  495. *status1 = (val >> 24) & 0x0F;
  496. *status2 = (val >> 16) & 0x0F;
  497. /*
  498. * FIFO_ENTRIES contains the least significant byte, and FIFO_ENTRIES2
  499. * contains the two most significant bits
  500. */
  501. *fifo_entries = val & 0x3FF;
  502. return ret;
  503. }
  504. static void adxl372_arrange_axis_data(struct adxl372_state *st, __be16 *sample)
  505. {
  506. __be16 axis_sample[3];
  507. int i = 0;
  508. memset(axis_sample, 0, 3 * sizeof(__be16));
  509. if (ADXL372_X_AXIS_EN(st->fifo_axis_mask))
  510. axis_sample[i++] = sample[0];
  511. if (ADXL372_Y_AXIS_EN(st->fifo_axis_mask))
  512. axis_sample[i++] = sample[1];
  513. if (ADXL372_Z_AXIS_EN(st->fifo_axis_mask))
  514. axis_sample[i++] = sample[2];
  515. memcpy(sample, axis_sample, 3 * sizeof(__be16));
  516. }
  517. static void adxl372_push_event(struct iio_dev *indio_dev, s64 timestamp, u8 status2)
  518. {
  519. unsigned int ev_dir = IIO_EV_DIR_NONE;
  520. if (ADXL372_STATUS_2_ACT(status2))
  521. ev_dir = IIO_EV_DIR_RISING;
  522. if (ADXL372_STATUS_2_INACT(status2))
  523. ev_dir = IIO_EV_DIR_FALLING;
  524. if (ev_dir != IIO_EV_DIR_NONE)
  525. iio_push_event(indio_dev,
  526. IIO_MOD_EVENT_CODE(IIO_ACCEL, 0, IIO_MOD_X_OR_Y_OR_Z,
  527. IIO_EV_TYPE_THRESH, ev_dir),
  528. timestamp);
  529. }
  530. static irqreturn_t adxl372_trigger_handler(int irq, void *p)
  531. {
  532. struct iio_poll_func *pf = p;
  533. struct iio_dev *indio_dev = pf->indio_dev;
  534. struct adxl372_state *st = iio_priv(indio_dev);
  535. u8 status1, status2;
  536. u16 fifo_entries;
  537. int i, ret;
  538. ret = adxl372_get_status(st, &status1, &status2, &fifo_entries);
  539. if (ret < 0)
  540. goto err;
  541. adxl372_push_event(indio_dev, iio_get_time_ns(indio_dev), status2);
  542. if (st->fifo_mode != ADXL372_FIFO_BYPASSED &&
  543. ADXL372_STATUS_1_FIFO_FULL(status1)) {
  544. /*
  545. * When reading data from multiple axes from the FIFO,
  546. * to ensure that data is not overwritten and stored out
  547. * of order at least one sample set must be left in the
  548. * FIFO after every read.
  549. */
  550. fifo_entries -= st->fifo_set_size;
  551. /* Read data from the FIFO */
  552. ret = regmap_noinc_read(st->regmap, ADXL372_FIFO_DATA,
  553. st->fifo_buf,
  554. fifo_entries * sizeof(u16));
  555. if (ret < 0)
  556. goto err;
  557. /* Each sample is 2 bytes */
  558. for (i = 0; i < fifo_entries; i += st->fifo_set_size) {
  559. /* filter peak detection data */
  560. if (st->peak_fifo_mode_en)
  561. adxl372_arrange_axis_data(st, &st->fifo_buf[i]);
  562. iio_push_to_buffers(indio_dev, &st->fifo_buf[i]);
  563. }
  564. }
  565. err:
  566. iio_trigger_notify_done(indio_dev->trig);
  567. return IRQ_HANDLED;
  568. }
  569. static int adxl372_setup(struct adxl372_state *st)
  570. {
  571. unsigned int regval;
  572. int ret;
  573. ret = regmap_read(st->regmap, ADXL372_DEVID, &regval);
  574. if (ret < 0)
  575. return ret;
  576. if (regval != ADXL372_DEVID_VAL) {
  577. dev_err(st->dev, "Invalid chip id %x\n", regval);
  578. return -ENODEV;
  579. }
  580. /*
  581. * Perform a software reset to make sure the device is in a consistent
  582. * state after start up.
  583. */
  584. ret = regmap_write(st->regmap, ADXL372_RESET, ADXL372_RESET_CODE);
  585. if (ret < 0)
  586. return ret;
  587. ret = adxl372_set_op_mode(st, ADXL372_STANDBY);
  588. if (ret < 0)
  589. return ret;
  590. /* Set threshold for activity detection to 1g */
  591. ret = adxl372_set_activity_threshold(st, ADXL372_ACTIVITY,
  592. true, true, 1000);
  593. if (ret < 0)
  594. return ret;
  595. /* Set threshold for inactivity detection to 100mg */
  596. ret = adxl372_set_activity_threshold(st, ADXL372_INACTIVITY,
  597. true, true, 100);
  598. if (ret < 0)
  599. return ret;
  600. /* Set activity processing in Looped mode */
  601. ret = adxl372_set_act_proc_mode(st, ADXL372_LOOPED);
  602. if (ret < 0)
  603. return ret;
  604. ret = adxl372_set_odr(st, ADXL372_ODR_6400HZ);
  605. if (ret < 0)
  606. return ret;
  607. ret = adxl372_set_bandwidth(st, ADXL372_BW_3200HZ);
  608. if (ret < 0)
  609. return ret;
  610. /* Set activity timer to 1ms */
  611. ret = adxl372_set_activity_time_ms(st, 1);
  612. if (ret < 0)
  613. return ret;
  614. /* Set inactivity timer to 10s */
  615. ret = adxl372_set_inactivity_time_ms(st, 10000);
  616. if (ret < 0)
  617. return ret;
  618. /* Set the mode of operation to full bandwidth measurement mode */
  619. return adxl372_set_op_mode(st, ADXL372_FULL_BW_MEASUREMENT);
  620. }
  621. static int adxl372_reg_access(struct iio_dev *indio_dev,
  622. unsigned int reg,
  623. unsigned int writeval,
  624. unsigned int *readval)
  625. {
  626. struct adxl372_state *st = iio_priv(indio_dev);
  627. if (readval)
  628. return regmap_read(st->regmap, reg, readval);
  629. else
  630. return regmap_write(st->regmap, reg, writeval);
  631. }
  632. static int adxl372_read_raw(struct iio_dev *indio_dev,
  633. struct iio_chan_spec const *chan,
  634. int *val, int *val2, long info)
  635. {
  636. struct adxl372_state *st = iio_priv(indio_dev);
  637. int ret;
  638. switch (info) {
  639. case IIO_CHAN_INFO_RAW:
  640. ret = iio_device_claim_direct_mode(indio_dev);
  641. if (ret)
  642. return ret;
  643. ret = adxl372_read_axis(st, chan->address);
  644. iio_device_release_direct_mode(indio_dev);
  645. if (ret < 0)
  646. return ret;
  647. *val = sign_extend32(ret >> chan->scan_type.shift,
  648. chan->scan_type.realbits - 1);
  649. return IIO_VAL_INT;
  650. case IIO_CHAN_INFO_SCALE:
  651. *val = 0;
  652. *val2 = ADXL372_USCALE;
  653. return IIO_VAL_INT_PLUS_MICRO;
  654. case IIO_CHAN_INFO_SAMP_FREQ:
  655. *val = adxl372_samp_freq_tbl[st->odr];
  656. return IIO_VAL_INT;
  657. case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
  658. *val = adxl372_bw_freq_tbl[st->bw];
  659. return IIO_VAL_INT;
  660. }
  661. return -EINVAL;
  662. }
  663. static int adxl372_write_raw(struct iio_dev *indio_dev,
  664. struct iio_chan_spec const *chan,
  665. int val, int val2, long info)
  666. {
  667. struct adxl372_state *st = iio_priv(indio_dev);
  668. int odr_index, bw_index, ret;
  669. switch (info) {
  670. case IIO_CHAN_INFO_SAMP_FREQ:
  671. odr_index = adxl372_find_closest_match(adxl372_samp_freq_tbl,
  672. ARRAY_SIZE(adxl372_samp_freq_tbl),
  673. val);
  674. ret = adxl372_set_odr(st, odr_index);
  675. if (ret < 0)
  676. return ret;
  677. /*
  678. * The timer period depends on the ODR selected.
  679. * At 3200 Hz and below, it is 6.6 ms; at 6400 Hz, it is 3.3 ms
  680. */
  681. ret = adxl372_set_activity_time_ms(st, st->act_time_ms);
  682. if (ret < 0)
  683. return ret;
  684. /*
  685. * The timer period depends on the ODR selected.
  686. * At 3200 Hz and below, it is 26 ms; at 6400 Hz, it is 13 ms
  687. */
  688. ret = adxl372_set_inactivity_time_ms(st, st->inact_time_ms);
  689. if (ret < 0)
  690. return ret;
  691. /*
  692. * The maximum bandwidth is constrained to at most half of
  693. * the ODR to ensure that the Nyquist criteria is not violated
  694. */
  695. if (st->bw > odr_index)
  696. ret = adxl372_set_bandwidth(st, odr_index);
  697. return ret;
  698. case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
  699. bw_index = adxl372_find_closest_match(adxl372_bw_freq_tbl,
  700. ARRAY_SIZE(adxl372_bw_freq_tbl),
  701. val);
  702. return adxl372_set_bandwidth(st, bw_index);
  703. default:
  704. return -EINVAL;
  705. }
  706. }
  707. static int adxl372_read_event_value(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  708. enum iio_event_type type, enum iio_event_direction dir,
  709. enum iio_event_info info, int *val, int *val2)
  710. {
  711. struct adxl372_state *st = iio_priv(indio_dev);
  712. unsigned int addr;
  713. u16 raw_value;
  714. int ret;
  715. switch (info) {
  716. case IIO_EV_INFO_VALUE:
  717. switch (dir) {
  718. case IIO_EV_DIR_RISING:
  719. addr = ADXL372_X_THRESH_ACT_H + 2 * chan->scan_index;
  720. ret = adxl372_read_threshold_value(indio_dev, addr, &raw_value);
  721. if (ret < 0)
  722. return ret;
  723. *val = raw_value * ADXL372_USCALE;
  724. *val2 = 1000000;
  725. return IIO_VAL_FRACTIONAL;
  726. case IIO_EV_DIR_FALLING:
  727. addr = ADXL372_X_THRESH_INACT_H + 2 * chan->scan_index;
  728. ret = adxl372_read_threshold_value(indio_dev, addr, &raw_value);
  729. if (ret < 0)
  730. return ret;
  731. *val = raw_value * ADXL372_USCALE;
  732. *val2 = 1000000;
  733. return IIO_VAL_FRACTIONAL;
  734. default:
  735. return -EINVAL;
  736. }
  737. case IIO_EV_INFO_PERIOD:
  738. switch (dir) {
  739. case IIO_EV_DIR_RISING:
  740. *val = st->act_time_ms;
  741. *val2 = 1000;
  742. return IIO_VAL_FRACTIONAL;
  743. case IIO_EV_DIR_FALLING:
  744. *val = st->inact_time_ms;
  745. *val2 = 1000;
  746. return IIO_VAL_FRACTIONAL;
  747. default:
  748. return -EINVAL;
  749. }
  750. default:
  751. return -EINVAL;
  752. }
  753. }
  754. static int adxl372_write_event_value(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  755. enum iio_event_type type, enum iio_event_direction dir,
  756. enum iio_event_info info, int val, int val2)
  757. {
  758. struct adxl372_state *st = iio_priv(indio_dev);
  759. unsigned int val_ms;
  760. unsigned int addr;
  761. u16 raw_val;
  762. switch (info) {
  763. case IIO_EV_INFO_VALUE:
  764. raw_val = DIV_ROUND_UP(val * 1000000, ADXL372_USCALE);
  765. switch (dir) {
  766. case IIO_EV_DIR_RISING:
  767. addr = ADXL372_X_THRESH_ACT_H + 2 * chan->scan_index;
  768. return adxl372_write_threshold_value(indio_dev, addr, raw_val);
  769. case IIO_EV_DIR_FALLING:
  770. addr = ADXL372_X_THRESH_INACT_H + 2 * chan->scan_index;
  771. return adxl372_write_threshold_value(indio_dev, addr, raw_val);
  772. default:
  773. return -EINVAL;
  774. }
  775. case IIO_EV_INFO_PERIOD:
  776. val_ms = val * 1000 + DIV_ROUND_UP(val2, 1000);
  777. switch (dir) {
  778. case IIO_EV_DIR_RISING:
  779. return adxl372_set_activity_time_ms(st, val_ms);
  780. case IIO_EV_DIR_FALLING:
  781. return adxl372_set_inactivity_time_ms(st, val_ms);
  782. default:
  783. return -EINVAL;
  784. }
  785. default:
  786. return -EINVAL;
  787. }
  788. }
  789. static int adxl372_read_event_config(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  790. enum iio_event_type type, enum iio_event_direction dir)
  791. {
  792. struct adxl372_state *st = iio_priv(indio_dev);
  793. switch (dir) {
  794. case IIO_EV_DIR_RISING:
  795. return FIELD_GET(ADXL372_INT1_MAP_ACT_MSK, st->int1_bitmask);
  796. case IIO_EV_DIR_FALLING:
  797. return FIELD_GET(ADXL372_INT1_MAP_INACT_MSK, st->int1_bitmask);
  798. default:
  799. return -EINVAL;
  800. }
  801. }
  802. static int adxl372_write_event_config(struct iio_dev *indio_dev, const struct iio_chan_spec *chan,
  803. enum iio_event_type type, enum iio_event_direction dir,
  804. int state)
  805. {
  806. struct adxl372_state *st = iio_priv(indio_dev);
  807. switch (dir) {
  808. case IIO_EV_DIR_RISING:
  809. set_mask_bits(&st->int1_bitmask, ADXL372_INT1_MAP_ACT_MSK,
  810. ADXL372_INT1_MAP_ACT_MODE(state));
  811. break;
  812. case IIO_EV_DIR_FALLING:
  813. set_mask_bits(&st->int1_bitmask, ADXL372_INT1_MAP_INACT_MSK,
  814. ADXL372_INT1_MAP_INACT_MODE(state));
  815. break;
  816. default:
  817. return -EINVAL;
  818. }
  819. return adxl372_set_interrupts(st, st->int1_bitmask, 0);
  820. }
  821. static ssize_t adxl372_show_filter_freq_avail(struct device *dev,
  822. struct device_attribute *attr,
  823. char *buf)
  824. {
  825. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  826. struct adxl372_state *st = iio_priv(indio_dev);
  827. int i;
  828. size_t len = 0;
  829. for (i = 0; i <= st->odr; i++)
  830. len += scnprintf(buf + len, PAGE_SIZE - len,
  831. "%d ", adxl372_bw_freq_tbl[i]);
  832. buf[len - 1] = '\n';
  833. return len;
  834. }
  835. static ssize_t adxl372_get_fifo_enabled(struct device *dev,
  836. struct device_attribute *attr,
  837. char *buf)
  838. {
  839. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  840. struct adxl372_state *st = iio_priv(indio_dev);
  841. return sprintf(buf, "%d\n", st->fifo_mode);
  842. }
  843. static ssize_t adxl372_get_fifo_watermark(struct device *dev,
  844. struct device_attribute *attr,
  845. char *buf)
  846. {
  847. struct iio_dev *indio_dev = dev_to_iio_dev(dev);
  848. struct adxl372_state *st = iio_priv(indio_dev);
  849. return sprintf(buf, "%d\n", st->watermark);
  850. }
  851. static ssize_t hwfifo_watermark_min_show(struct device *dev,
  852. struct device_attribute *attr,
  853. char *buf)
  854. {
  855. return sysfs_emit(buf, "%s\n", "1");
  856. }
  857. static ssize_t hwfifo_watermark_max_show(struct device *dev,
  858. struct device_attribute *attr,
  859. char *buf)
  860. {
  861. return sysfs_emit(buf, "%s\n", __stringify(ADXL372_FIFO_SIZE));
  862. }
  863. static IIO_DEVICE_ATTR_RO(hwfifo_watermark_min, 0);
  864. static IIO_DEVICE_ATTR_RO(hwfifo_watermark_max, 0);
  865. static IIO_DEVICE_ATTR(hwfifo_watermark, 0444,
  866. adxl372_get_fifo_watermark, NULL, 0);
  867. static IIO_DEVICE_ATTR(hwfifo_enabled, 0444,
  868. adxl372_get_fifo_enabled, NULL, 0);
  869. static const struct attribute *adxl372_fifo_attributes[] = {
  870. &iio_dev_attr_hwfifo_watermark_min.dev_attr.attr,
  871. &iio_dev_attr_hwfifo_watermark_max.dev_attr.attr,
  872. &iio_dev_attr_hwfifo_watermark.dev_attr.attr,
  873. &iio_dev_attr_hwfifo_enabled.dev_attr.attr,
  874. NULL,
  875. };
  876. static int adxl372_set_watermark(struct iio_dev *indio_dev, unsigned int val)
  877. {
  878. struct adxl372_state *st = iio_priv(indio_dev);
  879. if (val > ADXL372_FIFO_SIZE)
  880. val = ADXL372_FIFO_SIZE;
  881. st->watermark = val;
  882. return 0;
  883. }
  884. static int adxl372_buffer_postenable(struct iio_dev *indio_dev)
  885. {
  886. struct adxl372_state *st = iio_priv(indio_dev);
  887. unsigned int mask;
  888. int i, ret;
  889. st->int1_bitmask |= ADXL372_INT1_MAP_FIFO_FULL_MSK;
  890. ret = adxl372_set_interrupts(st, st->int1_bitmask, 0);
  891. if (ret < 0)
  892. return ret;
  893. mask = *indio_dev->active_scan_mask;
  894. for (i = 0; i < ARRAY_SIZE(adxl372_axis_lookup_table); i++) {
  895. if (mask == adxl372_axis_lookup_table[i].bits)
  896. break;
  897. }
  898. if (i == ARRAY_SIZE(adxl372_axis_lookup_table))
  899. return -EINVAL;
  900. st->fifo_format = adxl372_axis_lookup_table[i].fifo_format;
  901. st->fifo_axis_mask = adxl372_axis_lookup_table[i].bits;
  902. st->fifo_set_size = bitmap_weight(indio_dev->active_scan_mask,
  903. indio_dev->masklength);
  904. /* Configure the FIFO to store sets of impact event peak. */
  905. if (st->peak_fifo_mode_en) {
  906. st->fifo_set_size = 3;
  907. st->fifo_format = ADXL372_XYZ_PEAK_FIFO;
  908. }
  909. /*
  910. * The 512 FIFO samples can be allotted in several ways, such as:
  911. * 170 sample sets of concurrent 3-axis data
  912. * 256 sample sets of concurrent 2-axis data (user selectable)
  913. * 512 sample sets of single-axis data
  914. * 170 sets of impact event peak (x, y, z)
  915. */
  916. if ((st->watermark * st->fifo_set_size) > ADXL372_FIFO_SIZE)
  917. st->watermark = (ADXL372_FIFO_SIZE / st->fifo_set_size);
  918. st->fifo_mode = ADXL372_FIFO_STREAMED;
  919. ret = adxl372_configure_fifo(st);
  920. if (ret < 0) {
  921. st->fifo_mode = ADXL372_FIFO_BYPASSED;
  922. st->int1_bitmask &= ~ADXL372_INT1_MAP_FIFO_FULL_MSK;
  923. adxl372_set_interrupts(st, st->int1_bitmask, 0);
  924. return ret;
  925. }
  926. return 0;
  927. }
  928. static int adxl372_buffer_predisable(struct iio_dev *indio_dev)
  929. {
  930. struct adxl372_state *st = iio_priv(indio_dev);
  931. st->int1_bitmask &= ~ADXL372_INT1_MAP_FIFO_FULL_MSK;
  932. adxl372_set_interrupts(st, st->int1_bitmask, 0);
  933. st->fifo_mode = ADXL372_FIFO_BYPASSED;
  934. adxl372_configure_fifo(st);
  935. return 0;
  936. }
  937. static const struct iio_buffer_setup_ops adxl372_buffer_ops = {
  938. .postenable = adxl372_buffer_postenable,
  939. .predisable = adxl372_buffer_predisable,
  940. };
  941. static int adxl372_dready_trig_set_state(struct iio_trigger *trig,
  942. bool state)
  943. {
  944. struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig);
  945. struct adxl372_state *st = iio_priv(indio_dev);
  946. if (state)
  947. st->int1_bitmask |= ADXL372_INT1_MAP_FIFO_FULL_MSK;
  948. return adxl372_set_interrupts(st, st->int1_bitmask, 0);
  949. }
  950. static int adxl372_validate_trigger(struct iio_dev *indio_dev,
  951. struct iio_trigger *trig)
  952. {
  953. struct adxl372_state *st = iio_priv(indio_dev);
  954. if (st->dready_trig != trig && st->peak_datardy_trig != trig)
  955. return -EINVAL;
  956. return 0;
  957. }
  958. static const struct iio_trigger_ops adxl372_trigger_ops = {
  959. .validate_device = &iio_trigger_validate_own_device,
  960. .set_trigger_state = adxl372_dready_trig_set_state,
  961. };
  962. static int adxl372_peak_dready_trig_set_state(struct iio_trigger *trig,
  963. bool state)
  964. {
  965. struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig);
  966. struct adxl372_state *st = iio_priv(indio_dev);
  967. if (state)
  968. st->int1_bitmask |= ADXL372_INT1_MAP_FIFO_FULL_MSK;
  969. st->peak_fifo_mode_en = state;
  970. return adxl372_set_interrupts(st, st->int1_bitmask, 0);
  971. }
  972. static const struct iio_trigger_ops adxl372_peak_data_trigger_ops = {
  973. .validate_device = &iio_trigger_validate_own_device,
  974. .set_trigger_state = adxl372_peak_dready_trig_set_state,
  975. };
  976. static IIO_CONST_ATTR_SAMP_FREQ_AVAIL("400 800 1600 3200 6400");
  977. static IIO_DEVICE_ATTR(in_accel_filter_low_pass_3db_frequency_available,
  978. 0444, adxl372_show_filter_freq_avail, NULL, 0);
  979. static struct attribute *adxl372_attributes[] = {
  980. &iio_const_attr_sampling_frequency_available.dev_attr.attr,
  981. &iio_dev_attr_in_accel_filter_low_pass_3db_frequency_available.dev_attr.attr,
  982. NULL,
  983. };
  984. static const struct attribute_group adxl372_attrs_group = {
  985. .attrs = adxl372_attributes,
  986. };
  987. static const struct iio_info adxl372_info = {
  988. .validate_trigger = &adxl372_validate_trigger,
  989. .attrs = &adxl372_attrs_group,
  990. .read_raw = adxl372_read_raw,
  991. .write_raw = adxl372_write_raw,
  992. .read_event_config = adxl372_read_event_config,
  993. .write_event_config = adxl372_write_event_config,
  994. .read_event_value = adxl372_read_event_value,
  995. .write_event_value = adxl372_write_event_value,
  996. .debugfs_reg_access = &adxl372_reg_access,
  997. .hwfifo_set_watermark = adxl372_set_watermark,
  998. };
  999. bool adxl372_readable_noinc_reg(struct device *dev, unsigned int reg)
  1000. {
  1001. return (reg == ADXL372_FIFO_DATA);
  1002. }
  1003. EXPORT_SYMBOL_NS_GPL(adxl372_readable_noinc_reg, IIO_ADXL372);
  1004. int adxl372_probe(struct device *dev, struct regmap *regmap,
  1005. int irq, const char *name)
  1006. {
  1007. struct iio_dev *indio_dev;
  1008. struct adxl372_state *st;
  1009. int ret;
  1010. indio_dev = devm_iio_device_alloc(dev, sizeof(*st));
  1011. if (!indio_dev)
  1012. return -ENOMEM;
  1013. st = iio_priv(indio_dev);
  1014. dev_set_drvdata(dev, indio_dev);
  1015. st->dev = dev;
  1016. st->regmap = regmap;
  1017. st->irq = irq;
  1018. mutex_init(&st->threshold_m);
  1019. indio_dev->channels = adxl372_channels;
  1020. indio_dev->num_channels = ARRAY_SIZE(adxl372_channels);
  1021. indio_dev->available_scan_masks = adxl372_channel_masks;
  1022. indio_dev->name = name;
  1023. indio_dev->info = &adxl372_info;
  1024. indio_dev->modes = INDIO_DIRECT_MODE | INDIO_BUFFER_SOFTWARE;
  1025. ret = adxl372_setup(st);
  1026. if (ret < 0) {
  1027. dev_err(dev, "ADXL372 setup failed\n");
  1028. return ret;
  1029. }
  1030. ret = devm_iio_triggered_buffer_setup_ext(dev,
  1031. indio_dev, NULL,
  1032. adxl372_trigger_handler,
  1033. IIO_BUFFER_DIRECTION_IN,
  1034. &adxl372_buffer_ops,
  1035. adxl372_fifo_attributes);
  1036. if (ret < 0)
  1037. return ret;
  1038. if (st->irq) {
  1039. st->dready_trig = devm_iio_trigger_alloc(dev,
  1040. "%s-dev%d",
  1041. indio_dev->name,
  1042. iio_device_id(indio_dev));
  1043. if (st->dready_trig == NULL)
  1044. return -ENOMEM;
  1045. st->peak_datardy_trig = devm_iio_trigger_alloc(dev,
  1046. "%s-dev%d-peak",
  1047. indio_dev->name,
  1048. iio_device_id(indio_dev));
  1049. if (!st->peak_datardy_trig)
  1050. return -ENOMEM;
  1051. st->dready_trig->ops = &adxl372_trigger_ops;
  1052. st->peak_datardy_trig->ops = &adxl372_peak_data_trigger_ops;
  1053. iio_trigger_set_drvdata(st->dready_trig, indio_dev);
  1054. iio_trigger_set_drvdata(st->peak_datardy_trig, indio_dev);
  1055. ret = devm_iio_trigger_register(dev, st->dready_trig);
  1056. if (ret < 0)
  1057. return ret;
  1058. ret = devm_iio_trigger_register(dev, st->peak_datardy_trig);
  1059. if (ret < 0)
  1060. return ret;
  1061. indio_dev->trig = iio_trigger_get(st->dready_trig);
  1062. ret = devm_request_threaded_irq(dev, st->irq,
  1063. iio_trigger_generic_data_rdy_poll,
  1064. NULL,
  1065. IRQF_TRIGGER_RISING | IRQF_ONESHOT,
  1066. indio_dev->name, st->dready_trig);
  1067. if (ret < 0)
  1068. return ret;
  1069. }
  1070. return devm_iio_device_register(dev, indio_dev);
  1071. }
  1072. EXPORT_SYMBOL_NS_GPL(adxl372_probe, IIO_ADXL372);
  1073. MODULE_AUTHOR("Stefan Popa <[email protected]>");
  1074. MODULE_DESCRIPTION("Analog Devices ADXL372 3-axis accelerometer driver");
  1075. MODULE_LICENSE("GPL");