adxl345.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * ADXL345 3-Axis Digital Accelerometer
  4. *
  5. * Copyright (c) 2017 Eva Rachel Retuya <eraretuya@gmail.com>
  6. */
  7. #ifndef _ADXL345_H_
  8. #define _ADXL345_H_
  9. #define ADXL345_REG_DEVID 0x00
  10. #define ADXL345_REG_OFSX 0x1E
  11. #define ADXL345_REG_OFSY 0x1F
  12. #define ADXL345_REG_OFSZ 0x20
  13. #define ADXL345_REG_OFS_AXIS(index) (ADXL345_REG_OFSX + (index))
  14. #define ADXL345_REG_BW_RATE 0x2C
  15. #define ADXL345_REG_POWER_CTL 0x2D
  16. #define ADXL345_REG_DATA_FORMAT 0x31
  17. #define ADXL345_REG_DATAX0 0x32
  18. #define ADXL345_REG_DATAY0 0x34
  19. #define ADXL345_REG_DATAZ0 0x36
  20. #define ADXL345_REG_DATA_AXIS(index) \
  21. (ADXL345_REG_DATAX0 + (index) * sizeof(__le16))
  22. #define ADXL345_BW_RATE GENMASK(3, 0)
  23. #define ADXL345_BASE_RATE_NANO_HZ 97656250LL
  24. #define ADXL345_POWER_CTL_MEASURE BIT(3)
  25. #define ADXL345_POWER_CTL_STANDBY 0x00
  26. #define ADXL345_DATA_FORMAT_RANGE GENMASK(1, 0) /* Set the g range */
  27. #define ADXL345_DATA_FORMAT_JUSTIFY BIT(2) /* Left-justified (MSB) mode */
  28. #define ADXL345_DATA_FORMAT_FULL_RES BIT(3) /* Up to 13-bits resolution */
  29. #define ADXL345_DATA_FORMAT_SPI_3WIRE BIT(6) /* 3-wire SPI mode */
  30. #define ADXL345_DATA_FORMAT_SELF_TEST BIT(7) /* Enable a self test */
  31. #define ADXL345_DATA_FORMAT_2G 0
  32. #define ADXL345_DATA_FORMAT_4G 1
  33. #define ADXL345_DATA_FORMAT_8G 2
  34. #define ADXL345_DATA_FORMAT_16G 3
  35. #define ADXL345_DEVID 0xE5
  36. /*
  37. * In full-resolution mode, scale factor is maintained at ~4 mg/LSB
  38. * in all g ranges.
  39. *
  40. * At +/- 16g with 13-bit resolution, scale is computed as:
  41. * (16 + 16) * 9.81 / (2^13 - 1) = 0.0383
  42. */
  43. #define ADXL345_USCALE 38300
  44. /*
  45. * The Datasheet lists a resolution of Resolution is ~49 mg per LSB. That's
  46. * ~480mm/s**2 per LSB.
  47. */
  48. #define ADXL375_USCALE 480000
  49. struct adxl345_chip_info {
  50. const char *name;
  51. int uscale;
  52. };
  53. int adxl345_core_probe(struct device *dev, struct regmap *regmap,
  54. int (*setup)(struct device*, struct regmap*));
  55. #endif /* _ADXL345_H_ */