bma253_defs.h 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943
  1. /**
  2. * @brief : this
  3. * @file : bma253_defs.h
  4. * @version : v0.0.1
  5. * Date Version Author Note
  6. */
  7. #ifndef __BMA253_DEFS_H__
  8. #define __BMA253_DEFS_H__
  9. #include "main.h"
  10. #define BMA253_DEFAULT_ADDR 0x18
  11. #define BMA253_CHIP_ID 0xFA
  12. #define BMA253_RESET_BYTE 0xB6
  13. #define BMA253_I2C_TIMEOUT 1000
  14. // NOTE: Reserved registers must not be written into. Reading
  15. // from them may return indeterminate values. Registers
  16. // containing reserved bitfields must be written as 0. Reading
  17. // reserved bitfields may return indeterminate values.
  18. /**
  19. * BMA253 registers
  20. */
  21. typedef enum
  22. {
  23. BMA253_REG_BGW_CHIPID = 0x00, // R
  24. // 0x01 reserved
  25. BMA253_REG_ACCD_X_LSB = 0x02, // R acc_x_lsb<3:0>:new_data_x
  26. BMA253_REG_ACCD_X_MSB = 0x03, // R acc_x_msb<11:4>
  27. BMA253_REG_ACCD_Y_LSB = 0x04, // R acc_y_lsb<3:0>:new_data_y
  28. BMA253_REG_ACCD_Y_MSB = 0x05, // R acc_y_msb<11:4>
  29. BMA253_REG_ACCD_Z_LSB = 0x06, // R acc_z_lsb<3:0>:new_data_z
  30. BMA253_REG_ACCD_Z_MSB = 0x07, // R acc_z_msb<11:4>
  31. BMA253_REG_ACCD_TEMP = 0x08, // R temp<7:0>
  32. BMA253_REG_INT_STATUS_0 = 0x09, // R falt:orient:s_tap:d_tap:slo_no_mot:slope:high:low
  33. BMA253_REG_INT_STATUS_1 = 0x0A, // R data:fifo_wm:fifo_full
  34. BMA253_REG_INT_STATUS_2 = 0x0B, // R tap_sign:tap_first_<z:y:x>:slope_sign:slope_first_<z:y:x>
  35. BMA253_REG_INT_STATUS_3 = 0x0C, // R flat:orient<2:0>:high_sign:high_first_<z:y:x>
  36. // 0x0d reserved
  37. BMA253_REG_FIFO_STATUS = 0x0E, // R fifo_overrun:fifo_frame_counter<6:0>
  38. BMA253_REG_PMU_RANGE = 0x0F, // R/W range<3:0>
  39. BMA253_REG_PMU_BW = 0x10, // R/W bw<3:0>
  40. BMA253_REG_PMU_LPW = 0x11, // R/W suspend:lowpower_en:deep_suspend:sleep_dur<3:0>
  41. BMA253_REG_PMU_LOW_POWER = 0x12, // R/W lowpower_mode:sleeptimer_mode
  42. BMA253_REG_ACCD_HBW = 0x13, // R/W data_high_bw:shadow_dis
  43. BMA253_REG_BGW_SOFTRESET = 0x14, // W softreset
  44. // 0x15 reserved
  45. BMA253_REG_INT_EN_0 = 0x16, // R/W falt:orient:s_tap:d_tap:slope_en_<z:y:x>
  46. BMA253_REG_INT_EN_1 = 0x17, // R/W int_fwm:int_ffull:data:low:high_en_<z:y:x>
  47. BMA253_REG_INT_EN_2 = 0x18, // R/W slo_no_mot:slo_no_mot_en_<z:y:x>
  48. BMA253_REG_INT_MAP_0 = 0x19, // R/W int1_flat:int1_orient:int1_s_tap:int1_d_tap:int1_slo_no_mot:int1_slope:int1_high:int1_low
  49. BMA253_REG_INT_MAP_1 = 0x1A, // R/W int2_data:int2_fwm:int2_ffull:int1_ffull:int1_fwm:int1_data
  50. BMA253_REG_INT_MAP_2 = 0x1B, // R/W int2_flat:int2_orient:int2_s_tap:int2_d_tap:int2_slo_no_mot:int2_slope:int2_high:int2_low
  51. // 0x1c-0x1d reserved
  52. BMA253_REG_INT_SRC = 0x1E, // R/W int_src_data:int_src_tap:int_src_slo_no_mot:int_src_slope:int_src_high:int_src_low
  53. // 0x1f reserved
  54. BMA253_REG_INT_OUT_CTRL = 0x20, // R/W int2_od:int2_lvl:int1_od:int1_lvl
  55. BMA253_REG_INT_RST_LATCH = 0x21, // R/W reset_int:latch_int<3:0>
  56. BMA253_REG_INT_0 = 0x22, // R/W low_dur<7:0>
  57. BMA253_REG_INT_1 = 0x23, // R/W low_th<7:0>
  58. BMA253_REG_INT_2 = 0x24, // R/W high_hy<1:0>:low_mode:low_hy<1:0>
  59. BMA253_REG_INT_3 = 0X25, // R/W high_dur<7:0>
  60. BMA253_REG_INT_4 = 0X26, // R/W high_th<7:0>
  61. BMA253_REG_INT_5 = 0X27, // R/W slot_no_mot_dur<5:0>
  62. BMA253_REG_INT_6 = 0X28, // R/W slope_th<7:0>
  63. BMA253_REG_INT_7 = 0X29, // R/W slo_no_mot_th<5:0>
  64. BMA253_REG_INT_8 = 0X2A, // R/W tap_quiet:tap_shock:tap_dur<2:0>
  65. BMA253_REG_INT_9 = 0X2B, // R/W tap_samp<1:0>:tap_th<4:0>
  66. BMA253_REG_INT_A = 0X2C, // R/W orient_hyst<2:0>:orient_blocking<1:0>:orient_mode<1:0>
  67. BMA253_REG_INT_B = 0X2D, // R/W orient_ud_en:orient_theta<5:0>
  68. BMA253_REG_INT_C = 0X2E, // R/W flat_theta<5:0>
  69. BMA253_REG_INT_D = 0X2F, // R/W flat_hold_time<1:0>:flat_hy<2:0>
  70. BMA253_REG_FIFO_CONFIG_0 = 0X30, // R/W fifo_water_mark_level_trigger_retain<5:0>
  71. // 0x31 reserved
  72. BMA253_REG_PMU_SELF_TEST = 0X32, // R/W self_test_amp:self_test_sign:self_test_axis<1:0>
  73. BMA253_REG_TRIM_NVM_CTRL = 0X33, // R/W nvm_remain<3:0>:nvm_load:nvm_rdy:nvm_prog_trig:nvm_prog_mode
  74. BMA253_REG_BGW_SPI3_WDT = 0X34, // R/W i2c_wdt_en:i2c_wdt_sel:spi3
  75. // 0x35 reserved
  76. BMA253_REG_OFC_CTRL = 0x36, // R/W offset_rest:cal_trigger<1:0>:cal_rdy:hp_<z:y:x>_en
  77. BMA253_REG_OFC_SETTING = 0x37, // R/W offset_target_<z:y:x><1:0>:cut_off
  78. BMA253_REG_OFC_OFFSET_X = 0x38, // R/W offset_x<7:0>
  79. BMA253_REG_OFC_OFFSET_Y = 0x39, // R/W offset_y<7:0>
  80. BMA253_REG_OFC_OFFSET_Z = 0x3A, // R/W offset_z<7:0>
  81. BMA253_REG_TRIM_GP0 = 0x3B, // R/W GP0<7:0>
  82. BMA253_REG_TRIM_GP1 = 0x3C, // R/W GP1<7:0>
  83. // 0x3d reserved
  84. BMA253_REG_FIFO_CONFIG_1 = 0x3E, // R/W fifo_mode<1:0>:fifo_data_select<1:0>
  85. BMA253_REG_FIFO_DATA = 0x3F, // R/W fifo_data_output_register<7:0>
  86. } BMA253_REGS_T;
  87. /**
  88. * REG_ACCD_*_LSB bits - handle X, Y, and Z LSB regs, for 10 bit
  89. * resolution
  90. */
  91. typedef enum
  92. {
  93. BMA253_ACCD10_LSB_NEW_DATA = 0x01, // data
  94. // updated
  95. // since last
  96. // read
  97. // 0x02-0x20 reserved
  98. BMA253_ACCD10_LSB0 = 0x40, // lower 2
  99. // bits of
  100. // LSB data
  101. BMA253_ACCD10_LSB1 = 0x80,
  102. _BMA253_ACCD10_LSB_MASK = 3,
  103. _BMA253_ACCD10_LSB_SHIFT = 6
  104. } BMA253_ACCD10_LSB_BITS_T;
  105. /**
  106. * REG_ACCD_*_LSB bits - handle X, Y, and Z LSB regs, for 12 bit
  107. * resolution
  108. */
  109. typedef enum
  110. {
  111. BMA253_ACCD12_LSB_NEW_DATA = 0x01, // data
  112. // updated
  113. // since last
  114. // read
  115. // 0x02-0x08 reserved
  116. BMA253_ACCD12_LSB0 = 0x10, // lower 4
  117. // bits of
  118. // LSB data
  119. BMA253_ACCD12_LSB1 = 0x20,
  120. BMA253_ACCD12_LSB2 = 0x40,
  121. BMA253_ACCD12_LSB3 = 0x80,
  122. _BMA253_ACCD12_LSB_MASK = 15,
  123. _BMA253_ACCD12_LSB_SHIFT = 4
  124. } BMA253_ACCD12_LSB_BITS_T;
  125. /**
  126. * REG_INT_STATUS_0 bits
  127. */
  128. typedef enum
  129. {
  130. BMA253_INT_STATUS_0_LOW = 0x01,
  131. BMA253_INT_STATUS_0_HIGH = 0x02,
  132. BMA253_INT_STATUS_0_SLOPE = 0x04,
  133. BMA253_INT_STATUS_0_SLO_NOT_MOT = 0x08,
  134. BMA253_INT_STATUS_0_D_TAP = 0x10,
  135. BMA253_INT_STATUS_0_S_TAP = 0x20,
  136. BMA253_INT_STATUS_0_ORIENT = 0x40,
  137. BMA253_INT_STATUS_0_FLAT = 0x80
  138. } BMA253_INT_STATUS_0_BITS_T;
  139. /**
  140. * REG_INT_STATUS_1 bits
  141. */
  142. typedef enum
  143. {
  144. _BMA253_INT_STATUS_1_RESERVED_BITS = 0x0f | 0x10,
  145. // 0x01-0x10 reserved
  146. BMA253_INT_STATUS_1_FIFO_FULL = 0x20,
  147. BMA253_INT_STATUS_1_FIFO_WM = 0x40,
  148. BMA253_INT_STATUS_1_DATA = 0x80 // data ready int
  149. } BMA253_INT_STATUS_1_BITS_T;
  150. /**
  151. * REG_INT_STATUS_2 bits
  152. */
  153. typedef enum
  154. {
  155. BMA253_INT_STATUS_2_SLOPE_FIRST_X = 0x01,
  156. BMA253_INT_STATUS_2_SLOPE_FIRST_Y = 0x02,
  157. BMA253_INT_STATUS_2_SLOPE_FIRST_Z = 0x04,
  158. BMA253_INT_STATUS_2_SLOPE_SIGN = 0x08,
  159. BMA253_INT_STATUS_2_TAP_FIRST_X = 0x10,
  160. BMA253_INT_STATUS_2_TAP_FIRST_Y = 0x20,
  161. BMA253_INT_STATUS_2_TAP_FIRST_Z = 0x40,
  162. BMA253_INT_STATUS_2_TAP_SIGN = 0x80
  163. } BMA253_INT_STATUS_2_BITS_T;
  164. /**
  165. * REG_INT_STATUS_3 bits
  166. */
  167. typedef enum
  168. {
  169. BMA253_INT_STATUS_3_HIGH_FIRST_X = 0x01,
  170. BMA253_INT_STATUS_3_HIGH_FIRST_Y = 0x02,
  171. BMA253_INT_STATUS_3_HIGH_FIRST_Z = 0x04,
  172. BMA253_INT_STATUS_3_HIGH_SIGN = 0x08,
  173. BMA253_INT_STATUS_3_ORIENT0 = 0x10,
  174. BMA253_INT_STATUS_3_ORIENT1 = 0x20,
  175. BMA253_INT_STATUS_3_ORIENT2 = 0x40,
  176. _BMA253_INT_STATUS_3_ORIENT_MASK = 7,
  177. _BMA253_INT_STATUS_3_ORIENT_SHIFT = 4,
  178. BMA253_INT_STATUS_3_FLAT = 0x80
  179. } INT_STATUS_3_BITS_T;
  180. /**
  181. * INT_STATUS_3_ORIENT values
  182. */
  183. typedef enum
  184. {
  185. BMA253_ORIENT_POTRAIT_UPRIGHT = 0,
  186. BMA253_ORIENT_POTRAIT_UPSIDE_DOWN = 1,
  187. BMA253_ORIENT_LANDSCAPE_LEFT = 2,
  188. BMA253_ORIENT_LANDSCAPE_RIGHT = 3,
  189. } BMA253_ORIENT_T;
  190. /**
  191. * REG_FIFO_STATUS bits
  192. */
  193. typedef enum
  194. {
  195. BMA253_FIFO_STATUS_FRAME_COUNTER0 = 0x01,
  196. BMA253_FIFO_STATUS_FRAME_COUNTER1 = 0x02,
  197. BMA253_FIFO_STATUS_FRAME_COUNTER2 = 0x04,
  198. BMA253_FIFO_STATUS_FRAME_COUNTER3 = 0x08,
  199. BMA253_FIFO_STATUS_FRAME_COUNTER4 = 0x10,
  200. BMA253_FIFO_STATUS_FRAME_COUNTER5 = 0x20,
  201. BMA253_FIFO_STATUS_FRAME_COUNTER6 = 0x40,
  202. _BMA253_FIFO_STATUS_FRAME_COUNTER_MASK = 127,
  203. _BMA253_FIFO_STATUS_FRAME_COUNTER_SHIFT = 0,
  204. BMA253_FIFO_STATUS_FIFO_OVERRUN = 0x80
  205. } BMA253_FIFO_STATUS_BITS_T;
  206. /**
  207. * REG_PMU_RANGE bits
  208. */
  209. typedef enum
  210. {
  211. BMA253_PMU_RANGE0 = 0x01,
  212. BMA253_PMU_RANGE1 = 0x02,
  213. BMA253_PMU_RANGE2 = 0x04,
  214. BMA253_PMU_RANGE3 = 0x08,
  215. _BMA253_PMU_RANGE_MASK = 15,
  216. _BMA253_PMU_RANGE_SHIFT = 0
  217. // 0x10-0x80 reserved
  218. } BMA253_PMU_RANGE_BITS_T;
  219. /**
  220. * PMU_RANGE (accelerometer g-range) values
  221. */
  222. typedef enum
  223. {
  224. BMA253_RANGE_2G = 3,
  225. BMA253_RANGE_4G = 5,
  226. BMA253_RANGE_8G = 8,
  227. BMA253_RANGE_16G = 12
  228. } BMA253_RANGE_T;
  229. #define RANGE_2G_MG_LSB (0.98)
  230. #define RANGE_4G_MG_LSB (1.95)
  231. #define RANGE_8G_MG_LSB (3.91)
  232. #define RANGE_16G_MG_LSB (7.81)
  233. /**
  234. * REG_PMU_BW bits
  235. */
  236. typedef enum
  237. {
  238. BMA253_PMU_BW0 = 0x01,
  239. BMA253_PMU_BW1 = 0x02,
  240. BMA253_PMU_BW2 = 0x04,
  241. BMA253_PMU_BW3 = 0x08,
  242. BMA253_PMU_BW4 = 0x10,
  243. _BMA253_PMU_BW_MASK = 31,
  244. _BMA253_PMU_BW_SHIFT = 0
  245. // 0x20-0x80 reserved
  246. } BMA253_PMU_BW_BITS_T;
  247. /**
  248. * PMU_BW (accelerometer filter bandwidth) values
  249. */
  250. typedef enum
  251. {
  252. BMA253_BW_7_81 = 8, // 7.81 Hz
  253. BMA253_BW_15_63 = 9,
  254. BMA253_BW_31_25 = 10,
  255. BMA253_BW_62_5 = 11,
  256. BMA253_BW_125 = 12,
  257. BMA253_BW_250 = 13,
  258. BMA253_BW_500 = 14,
  259. BMA253_BW_1000 = 15
  260. } BMA253_BW_T;
  261. /**
  262. * REG_PMU_LPW bits
  263. */
  264. typedef enum
  265. {
  266. // 0x01 reserved
  267. _BMA253_PMU_LPW_RESERVED_MASK = 0x01,
  268. BMA253_PMU_LPW_SLEEP_DUR0 = 0x02, // sleep dur
  269. // in low
  270. // power mode
  271. BMA253_PMU_LPW_SLEEP_DUR1 = 0x04,
  272. BMA253_PMU_LPW_SLEEP_DUR2 = 0x08,
  273. BMA253_PMU_LPW_SLEEP_DUR3 = 0x10,
  274. _BMA253_PMU_LPW_SLEEP_MASK = 15,
  275. _BMA253_PMU_LPW_SLEEP_SHIFT = 1,
  276. // These are separate bits, deep_suspend, lowpower_en and
  277. // suspend (and if all 0, normal). Since only specific
  278. // combinations are allowed, we will treat this as a 3 bit
  279. // bitfield called POWER_MODE.
  280. BMA253_PMU_LPW_POWER_MODE0 = 0x20, // deep_suspend
  281. BMA253_PMU_LPW_POWER_MODE1 = 0x40, // lowpower_en
  282. BMA253_PMU_LPW_POWER_MODE2 = 0x80, // suspend
  283. _BMA253_PMU_LPW_POWER_MODE_MASK = 7,
  284. _BMA253_PMU_LPW_POWER_MODE_SHIFT = 5
  285. } BMA253_PMU_LPW_BITS_T;
  286. /**
  287. * SLEEP_DUR values
  288. */
  289. typedef enum
  290. {
  291. BMA253_SLEEP_DUR_0_5 = 0, // 0.5ms
  292. BMA253_SLEEP_DUR_1 = 6,
  293. BMA253_SLEEP_DUR_2 = 7,
  294. BMA253_SLEEP_DUR_4 = 8,
  295. BMA253_SLEEP_DUR_6 = 9,
  296. BMA253_SLEEP_DUR_10 = 10,
  297. BMA253_SLEEP_DUR_25 = 11,
  298. BMA253_SLEEP_DUR_50 = 12,
  299. BMA253_SLEEP_DUR_100 = 13,
  300. BMA253_SLEEP_DUR_500 = 14,
  301. BMA253_SLEEP_DUR_1000 = 15
  302. } BMA253_SLEEP_DUR_T;
  303. /**
  304. * POWER_MODE values
  305. */
  306. typedef enum
  307. {
  308. BMA253_POWER_MODE_NORMAL = 0,
  309. BMA253_POWER_MODE_DEEP_SUSPEND = 1,
  310. BMA253_POWER_MODE_LOW_POWER = 2,
  311. BMA253_POWER_MODE_SUSPEND = 4
  312. } BMA253_POWER_MODE_T;
  313. /**
  314. * REG_PMU_LOW_POWER bits
  315. */
  316. typedef enum
  317. {
  318. _BMA253_LOW_POWER_RESERVED_BITS = 0x0f | 0x10 | 0x80,
  319. // 0x01-0x10 reserved
  320. BMA253_LOW_POWER_SLEEPTIMER_MODE = 0x20,
  321. BMA253_LOW_POWER_LOWPOWER_MODE = 0x40 // LPM1 or
  322. // LPM2
  323. // mode. see
  324. // DS.
  325. // 0x80 reserved
  326. } BMA253_LOW_POWER_BITS_T;
  327. /**
  328. * REG_ACC_HBW bits
  329. */
  330. typedef enum
  331. {
  332. _BMA253_ACC_HBW_RESERVED_BITS = 0x0f | 0x10 | 0x20,
  333. // 0x01-0x20 reserved
  334. BMA253_ACC_HBW_SHADOW_DIS = 0x40,
  335. BMA253_ACC_HBW_DATA_HIGH_BW = 0x80
  336. } BMA253_ACC_HBW_BITS_T;
  337. /**
  338. * REG_INT_EN_0 bits
  339. */
  340. typedef enum
  341. {
  342. _BMA253_INT_EN_0_RESERVED_BITS = 0x08,
  343. BMA253_INT_EN_0_SLOPE_EN_X = 0x01,
  344. BMA253_INT_EN_0_SLOPE_EN_Y = 0x02,
  345. BMA253_INT_EN_0_SLOPE_EN_Z = 0x04,
  346. // 0x08 reserved
  347. BMA253_INT_EN_0_D_TAP_EN = 0x10,
  348. BMA253_INT_EN_0_S_TAP_EN = 0x20,
  349. BMA253_INT_EN_0_ORIENT_EN = 0x40,
  350. BMA253_INT_EN_0_FLAT_EN = 0x80
  351. } BMA253_INT_EN_0_BITS_T;
  352. /**
  353. * REG_INT_EN_1 bits
  354. */
  355. typedef enum
  356. {
  357. _BMA253_INT_EN_1_RESERVED_BITS = 0x80,
  358. BMA253_INT_EN_1_HIGH_EN_X = 0x01,
  359. BMA253_INT_EN_1_HIGH_EN_Y = 0x02,
  360. BMA253_INT_EN_1_HIGH_EN_Z = 0x04,
  361. BMA253_INT_EN_1_LOW_EN = 0x08,
  362. BMA253_INT_EN_1_DATA_EN = 0x10,
  363. BMA253_INT_EN_1_INT_FFULL_EN = 0x20, // fifo full
  364. BMA253_INT_EN_1_INT_FWM_EN = 0x40 // fifo watermark
  365. // 0x80 reserved
  366. } BMA253_INT_EN_1_BITS_T;
  367. /**
  368. * REG_INT_EN_2 bits
  369. */
  370. typedef enum
  371. {
  372. _BMA253_INT_EN_2_RESERVED_BITS = 0xf0,
  373. BMA253_INT_EN_2_SLO_NO_MOT_EN_X = 0x01,
  374. BMA253_INT_EN_2_SLO_NO_MOT_EN_Y = 0x02,
  375. BMA253_INT_EN_2_SLO_NO_MOT_EN_Z = 0x04,
  376. BMA253_INT_EN_2_SLO_NO_MOT_SEL = 0x08
  377. // 0x10-0x80 reserved
  378. } BMA253_INT_EN_2_BITS_T;
  379. /**
  380. * REG_INT_MAP_0 bits
  381. */
  382. typedef enum
  383. {
  384. BMA253_INT_MAP_0_INT1_LOW = 0x01,
  385. BMA253_INT_MAP_0_INT1_HIGH = 0x02,
  386. BMA253_INT_MAP_0_INT1_SLOPE = 0x04,
  387. BMA253_INT_MAP_0_INT1_SLO_NO_MOT = 0x08,
  388. BMA253_INT_MAP_0_INT1_D_TAP = 0x10,
  389. BMA253_INT_MAP_0_INT1_S_TAP = 0x20,
  390. BMA253_INT_MAP_0_INT1_ORIENT = 0x40,
  391. BMA253_INT_MAP_0_INT1_FLAT = 0x80
  392. } BMA253_INT_MAP_0_BITS_T;
  393. /**
  394. * REG_INT_MAP_1 bits
  395. */
  396. typedef enum
  397. {
  398. _BMA253_INT_MAP_1_INT1_RESERVED_BITS = 0x08 | 0x10,
  399. BMA253_INT_MAP_1_INT1_DATA = 0x01,
  400. BMA253_INT_MAP_1_INT1_FWM = 0x02,
  401. BMA253_INT_MAP_1_INT1_FFULL = 0x04,
  402. // 0x08-0x10 reserved
  403. BMA253_INT_MAP_1_INT2_FFULL = 0x20,
  404. BMA253_INT_MAP_1_INT2_FWM = 0x40,
  405. BMA253_INT_MAP_1_INT2_DATA = 0x80
  406. } BMA253_INT_MAP_1_BITS_T;
  407. /**
  408. * REG_INT_MAP_2 bits
  409. */
  410. typedef enum
  411. {
  412. BMA253_INT_MAP_2_INT2_LOW = 0x01,
  413. BMA253_INT_MAP_2_INT2_HIGH = 0x02,
  414. BMA253_INT_MAP_2_INT2_SLOPE = 0x04,
  415. BMA253_INT_MAP_2_INT2_SLO_NO_MOT = 0x08,
  416. BMA253_INT_MAP_2_INT2_D_TAP = 0x10,
  417. BMA253_INT_MAP_2_INT2_S_TAP = 0x20,
  418. BMA253_INT_MAP_2_INT2_ORIENT = 0x40,
  419. BMA253_INT_MAP_2_INT2_FLAT = 0x80
  420. } BMA253_INT_MAP_2_BITS_T;
  421. /**
  422. * REG_INT_SRC bits
  423. */
  424. typedef enum
  425. {
  426. _BMA253_INT_SRC_RESERVED_BITS = 0x40 | 0x80,
  427. BMA253_INT_SRC_LOW = 0x01,
  428. BMA253_INT_SRC_HIGH = 0x02,
  429. BMA253_INT_SRC_SLO_NO_MOT = 0x04,
  430. BMA253_INT_SRC_SLOPE = 0x08,
  431. BMA253_INT_SRC_TAP = 0x10,
  432. BMA253_INT_SRC_DATA = 0x20
  433. // 0x40-0x80 reserved
  434. } BMA253_INT_SRC_BITS_T;
  435. /**
  436. * REG_INT_OUT_CTRL bits
  437. */
  438. typedef enum
  439. {
  440. _BMA253_INT_OUT_CTRL_INT1_RESERVED_BITS = 0xf0,
  441. BMA253_INT_OUT_CTRL_INT1_LVL = 0x01, // level or edge
  442. BMA253_INT_OUT_CTRL_INT1_OD = 0x02, // push-pull
  443. // or open
  444. // drain
  445. BMA253_INT_OUT_CTRL_INT2_LVL = 0x04,
  446. BMA253_INT_OUT_CTRL_INT2_OD = 0x08
  447. // 0x10-0x80 reserved
  448. } BMA253_INT_OUT_CTRL_BITS_T;
  449. /**
  450. * REG_INT_RST_LATCH bits
  451. */
  452. typedef enum
  453. {
  454. _BMA253_INT_RST_LATCH_RESERVED_BITS = 0x10 | 0x20 | 0x40,
  455. BMA253_INT_RST_LATCH0 = 0x01,
  456. BMA253_INT_RST_LATCH1 = 0x02,
  457. BMA253_INT_RST_LATCH2 = 0x04,
  458. BMA253_INT_RST_LATCH3 = 0x08,
  459. _BMA253_INT_RST_LATCH_MASK = 15,
  460. _BMA253_INT_RST_LATCH_SHIFT = 0,
  461. // 0x10-0x40 reserved
  462. BMA253_INT_RST_LATCH_RESET_INT = 0x80
  463. } BMA253_INT_RST_LATCH_BITS_T;
  464. /**
  465. * RST_LATCH values
  466. */
  467. typedef enum
  468. {
  469. BMA253_RST_LATCH_NON_LATCHED = 0,
  470. BMA253_RST_LATCH_TEMPORARY_250MS = 1,
  471. BMA253_RST_LATCH_TEMPORARY_500MS = 2,
  472. BMA253_RST_LATCH_TEMPORARY_1S = 3,
  473. BMA253_RST_LATCH_TEMPORARY_2S = 4,
  474. BMA253_RST_LATCH_TEMPORARY_4S = 5,
  475. BMA253_RST_LATCH_TEMPORARY_8S = 6,
  476. BMA253_RST_LATCH_LATCHED = 7,
  477. // 8 == non latched
  478. BMA253_RST_LATCH_TEMPORARY_250US = 9,
  479. BMA253_RST_LATCH_TEMPORARY_500US = 10,
  480. BMA253_RST_LATCH_TEMPORARY_1MS = 11,
  481. BMA253_RST_LATCH_TEMPORARY_12_5MS = 12,
  482. BMA253_RST_LATCH_TEMPORARY_25MS = 13,
  483. BMA253_RST_LATCH_TEMPORARY_50MS = 14
  484. // 15 == latched
  485. } BMA253_RST_LATCH_T;
  486. /**
  487. * REG_INT_2 bits
  488. */
  489. typedef enum
  490. {
  491. BMA253_INT_2_LOW_HY0 = 0x01,
  492. BMA253_INT_2_LOW_HY1 = 0x02,
  493. _BMA253_INT_2_LOW_HY_MASK = 3,
  494. _BMA253_INT_2_LOW_HY_SHIFT = 0,
  495. BMA253_INT_2_LOW_MODE = 0x04,
  496. // 0x08-0x20 reserved
  497. BMA253_INT_2_HIGH_HY0 = 0x40,
  498. BMA253_INT_2_HIGH_HY1 = 0x80,
  499. _BMA253_INT_2_HIGH_HY_MASK = 3,
  500. _BMA253_INT_2_HIGH_HY_SHIFT = 6
  501. } BMA253_INT_2_BITS_T;
  502. /**
  503. * REG_INT_5 bits
  504. */
  505. typedef enum
  506. {
  507. BMA253_INT_5_SLOPE_DUR0 = 0x01,
  508. BMA253_INT_5_SLOPE_DUR1 = 0x02,
  509. _BMA253_INT_5_SLOPE_DUR_MASK = 3,
  510. _BMA253_INT_5_SLOPE_DUR_SHIFT = 0,
  511. BMA253_INT_5_SLO_NO_MOT_DUR0 = 0x04,
  512. BMA253_INT_5_SLO_NO_MOT_DUR1 = 0x08,
  513. BMA253_INT_5_SLO_NO_MOT_DUR2 = 0x10,
  514. BMA253_INT_5_SLO_NO_MOT_DUR3 = 0x20,
  515. BMA253_INT_5_SLO_NO_MOT_DUR4 = 0x40,
  516. BMA253_INT_5_SLO_NO_MOT_DUR5 = 0x80,
  517. _BMA253_INT_5_SLO_NO_MOT_DUR_MASK = 63,
  518. _BMA253_INT_5_SLO_NO_MOT_DUR_SHIFT = 2
  519. } BMA253_INT_5_BITS_T;
  520. /**
  521. * REG_INT_8 bits
  522. */
  523. typedef enum
  524. {
  525. BMA253_INT_8_TAP_DUR0 = 0x01,
  526. BMA253_INT_8_TAP_DUR1 = 0x02,
  527. BMA253_INT_8_TAP_DUR2 = 0x04,
  528. _BMA253_INT_8_TAP_DUR_MASK = 7,
  529. _BMA253_INT_8_TAP_DUR_SHIFT = 0,
  530. // 0x08-0x20 reserved
  531. BMA253_INT_8_TAP_SHOCK = 0x40,
  532. BMA253_INT_8_TAP_QUIET = 0x80
  533. } BMA253_INT_8_BITS_T;
  534. /**
  535. * REG_INT_9 bits
  536. */
  537. typedef enum
  538. {
  539. BMA253_INT_9_TAP_TH0 = 0x01,
  540. BMA253_INT_9_TAP_TH1 = 0x02,
  541. BMA253_INT_9_TAP_TH2 = 0x04,
  542. BMA253_INT_9_TAP_TH3 = 0x08,
  543. BMA253_INT_9_TAP_TH4 = 0x10,
  544. _BMA253_INT_5_TAP_TH_MASK = 31,
  545. _BMA253_INT_5_TAP_TH_SHIFT = 0,
  546. // 0x20 reserved
  547. BMA253_INT_9_TAP_SAMP0 = 0x40,
  548. BMA253_INT_9_TAP_SAMP1 = 0x80,
  549. BMA253_INT_9_TAP_SAMP1_MASK = 3,
  550. BMA253_INT_9_TAP_SAMP1_SHIFT = 6
  551. } BMA253_INT_9_BITS_T;
  552. /**
  553. * REG_INT_A bits
  554. */
  555. typedef enum
  556. {
  557. BMA253_INT_A_ORIENT_MODE0 = 0x01,
  558. BMA253_INT_A_ORIENT_MODE1 = 0x02,
  559. _BMA253_INT_A_ORIENT_MODE_MASK = 3,
  560. _BMA253_INT_A_ORIENT_MODE_SHIFT = 0,
  561. BMA253_INT_A_ORIENT_BLOCKING0 = 0x04,
  562. BMA253_INT_A_ORIENT_BLOCKING1 = 0x08,
  563. _BMA253_INT_A_ORIENT_BLOCKING_MASK = 3,
  564. _BMA253_INT_A_ORIENT_BLOCKING_SHIFT = 2,
  565. BMA253_INT_A_ORIENT_HYST0 = 0x10,
  566. BMA253_INT_A_ORIENT_HYST1 = 0x20,
  567. BMA253_INT_A_ORIENT_HYST2 = 0x40,
  568. _BMA253_INT_A_ORIENT_HYST_MASK = 7,
  569. _BMA253_INT_A_ORIENT_HYST_SHIFT = 4
  570. // 0x80 reserved
  571. } BMA253_INT_A_BITS_T;
  572. /**
  573. * INT_A_ORIENT_MODE values
  574. */
  575. typedef enum
  576. {
  577. BMA253_ORIENT_MODE_SYMETRICAL = 0,
  578. BMA253_ORIENT_MODE_HIGH_ASYMETRICAL = 1,
  579. BMA253_ORIENT_MODE_LOW_ASYMETRICAL = 2
  580. } BMA253_ORIENT_MODE_T;
  581. /**
  582. * INT_A_ORIENT_BLOCKING values
  583. */
  584. typedef enum
  585. {
  586. BMA253_ORIENT_BLOCKING_NONE = 0,
  587. BMA253_ORIENT_BLOCKING_THETA_ACC_1_5G = 1,
  588. BMA253_ORIENT_BLOCKING_THETA_ACC_0_2G_1_5G = 2,
  589. BMA253_ORIENT_BLOCKING_THETA_ACC_0_4G_1_5G = 3
  590. } BMA253_ORIENT_BLOCKING_T;
  591. /**
  592. * REG_INT_B bits
  593. */
  594. typedef enum
  595. {
  596. BMA253_INT_B_ORIENT_THETA0 = 0x01,
  597. BMA253_INT_B_ORIENT_THETA1 = 0x02,
  598. BMA253_INT_B_ORIENT_THETA2 = 0x04,
  599. BMA253_INT_B_ORIENT_THETA3 = 0x08,
  600. BMA253_INT_B_ORIENT_THETA4 = 0x10,
  601. BMA253_INT_B_ORIENT_THETA5 = 0x20,
  602. _BMA253_INT_B_ORIENT_THETA_MASK = 63,
  603. _BMA253_INT_B_ORIENT_THETA_SHIFT = 0,
  604. BMA253_INT_B_ORIENT_UD_EN = 0x40
  605. // 0x80 reserved
  606. } BMA253_INT_B_BITS_T;
  607. /**
  608. * REG_INT_C bits
  609. */
  610. typedef enum
  611. {
  612. BMA253_INT_B_FLAT_THETA0 = 0x01,
  613. BMA253_INT_B_FLAT_THETA1 = 0x02,
  614. BMA253_INT_B_FLAT_THETA2 = 0x04,
  615. BMA253_INT_B_FLAT_THETA3 = 0x08,
  616. BMA253_INT_B_FLAT_THETA4 = 0x10,
  617. BMA253_INT_B_FLAT_THETA5 = 0x20,
  618. _BMA253_INT_B_FLAT_THETA_MASK = 63,
  619. _BMA253_INT_B_FLAT_THETA_SHIFT = 0,
  620. // 0x40-0x80 reserved
  621. } BMA253_INT_C_BITS_T;
  622. /**
  623. * REG_INT_D bits
  624. */
  625. typedef enum
  626. {
  627. BMA253_INT_D_FLAT_HY0 = 0x01,
  628. BMA253_INT_D_FLAT_HY1 = 0x02,
  629. BMA253_INT_D_FLAT_HY2 = 0x04,
  630. _BMA253_INT_B_FLAT_HY_MASK = 7,
  631. _BMA253_INT_B_FLAT_HY_SHIFT = 0,
  632. // 0x08 reserved
  633. BMA253_INT_D_FLAT_HOLD_TIME0 = 0x10,
  634. BMA253_INT_D_FLAT_HOLD_TIME1 = 0x20,
  635. _BMA253_INT_B_FLAT_HOLD_TIME_MASK = 3,
  636. _BMA253_INT_B_FLAT_HOLD_TIME_SHIFT = 4
  637. // 0x40-0x80 reserved
  638. } BMA253_INT_D_BITS_T;
  639. /**
  640. * REG_FIFO_CONFIG_0 bits
  641. */
  642. typedef enum
  643. {
  644. _BMA253_FIFO_CONFIG_0_RESERVED_BITS = 0x80 | 0x40,
  645. BMA253_FIFO_CONFIG_0_WATER_MARK0 = 0x01,
  646. BMA253_FIFO_CONFIG_0_WATER_MARK1 = 0x02,
  647. BMA253_FIFO_CONFIG_0_WATER_MARK2 = 0x04,
  648. BMA253_FIFO_CONFIG_0_WATER_MARK3 = 0x08,
  649. BMA253_FIFO_CONFIG_0_WATER_MARK4 = 0x10,
  650. BMA253_FIFO_CONFIG_0_WATER_MARK5 = 0x20,
  651. _BMA253_FIFO_CONFIG_0_WATER_MARK_MASK = 63,
  652. _BMA253_FIFO_CONFIG_0_WATER_MARK_SHIFT = 0
  653. } BMA253_FIFO_CONFIG_0_BITS_T;
  654. /**
  655. * REG_PMU_SELFTTEST bits
  656. */
  657. typedef enum
  658. {
  659. BMA253_PMU_SELFTTEST_AXIS0 = 0x01,
  660. BMA253_PMU_SELFTTEST_AXIS1 = 0x02,
  661. _BMA253_PMU_SELFTTEST_AXIS_MASK = 3,
  662. _BMA253_PMU_SELFTTEST_AXIS_SHIFT = 0,
  663. BMA253_PMU_SELFTTEST_SIGN = 0x04,
  664. // 0x08 reserved
  665. BMA253_PMU_SELFTTEST_AMP = 0x10,
  666. // 0x20-0x80 reserved
  667. } BMA253_PMU_SELFTTEST_BITS_T;
  668. /**
  669. * PMU_SELFTTEST_AXIS values
  670. */
  671. typedef enum
  672. {
  673. BMA253_SELFTTEST_AXIS_NONE = 0,
  674. BMA253_SELFTTEST_AXIS_X = 1,
  675. BMA253_SELFTTEST_AXIS_Y = 2,
  676. BMA253_SELFTTEST_AXIS_Z = 3,
  677. } BMA253_SELFTTEST_AXIS_T;
  678. /**
  679. * REG_TRIM_NVM_CTRL bits
  680. */
  681. typedef enum
  682. {
  683. BMA253_TRIM_NVM_CTRL_NVM_PROG_MODE = 0x01,
  684. BMA253_TRIM_NVM_CTRL_NVM_PROG_TRIG = 0x02,
  685. BMA253_TRIM_NVM_CTRL_NVM_PROG_RDY = 0x04,
  686. BMA253_TRIM_NVM_CTRL_NVM_PROG_LOAD = 0x08,
  687. BMA253_TRIM_NVM_CTRL_NVM_REMAIN0 = 0x10,
  688. BMA253_TRIM_NVM_CTRL_NVM_REMAIN1 = 0x20,
  689. BMA253_TRIM_NVM_CTRL_NVM_REMAIN2 = 0x40,
  690. BMA253_TRIM_NVM_CTRL_NVM_REMAIN3 = 0x80,
  691. _BMA253_TRIM_NVM_CTRL_NVM_REMAIN_MASK = 15,
  692. _BMA253_TRIM_NVM_CTRL_NVM_REMAIN_SHIFT = 4
  693. } BMA253_TRIM_NVM_CTRL_BITS_T;
  694. /**
  695. * REG_SPI3_WDT bits
  696. */
  697. typedef enum
  698. {
  699. _BMA253_SPI3_WDT_RESERVED_BITS = 0xf0 | 0x08,
  700. BMA253_SPI3_WDT_SPI3 = 0x01, // 3-wire SPI
  701. // - NOT
  702. // SUPPORTED
  703. BMA253_SPI3_WDT_I2C_WDT_SEL = 0x02,
  704. BMA253_SPI3_WDT_I2C_WDT_EN = 0x04
  705. // 0x08-0x80 reserved
  706. } BMA253_SPI3_WDT_BITS_T;
  707. /**
  708. * REG_OFC_CTRL bits
  709. */
  710. typedef enum
  711. {
  712. BMA253_OFC_CTRL_HP_X_EN = 0x01,
  713. BMA253_OFC_CTRL_HP_Y_EN = 0x02,
  714. BMA253_OFC_CTRL_HP_Z_EN = 0x04,
  715. // 0x08 reserved
  716. BMA253_OFC_CTRL_CAL_RDY = 0x10,
  717. BMA253_OFC_CTRL_CAL_TRIGGER0 = 0x20,
  718. BMA253_OFC_CTRL_CAL_TRIGGER1 = 0x40,
  719. _BMA253_OFC_CTRL_CAL_TRIGGER_MASK = 3,
  720. _BMA253_OFC_CTRL_CAL_TRIGGER_SHIFT = 5,
  721. BMA253_OFC_CTRL_OFFSET_RESET = 0x80
  722. } BMA253_OFC_CTRL_BITS_T;
  723. /**
  724. * OFC_CTRL_CAL_TRIGGER values
  725. */
  726. typedef enum
  727. {
  728. BMA253_CAL_TRIGGER_NONE = 0,
  729. BMA253_CAL_TRIGGER_X = 1,
  730. BMA253_CAL_TRIGGER_Y = 2,
  731. BMA253_CAL_TRIGGER_Z = 3
  732. } BMA253_CAL_TRIGGER_T;
  733. /**
  734. * REG_OFC_SETTING bits
  735. */
  736. typedef enum
  737. {
  738. BMA253_OFC_SETTING_CUT_OFF = 0x01,
  739. BMA253_OFC_SETTING_OFFSET_TARGET_X0 = 0x02,
  740. BMA253_OFC_SETTING_OFFSET_TARGET_X1 = 0x04,
  741. _BMA253_OFC_SETTING_OFFSET_TARGET_X_MASK = 3,
  742. _BMA253_OFC_SETTING_OFFSET_TARGET_X_SHIFT = 1,
  743. BMA253_OFC_SETTING_OFFSET_TARGET_Y0 = 0x08,
  744. BMA253_OFC_SETTING_OFFSET_TARGET_Y1 = 0x10,
  745. _BMA253_OFC_SETTING_OFFSET_TARGET_Y_MASK = 3,
  746. _BMA253_OFC_SETTING_OFFSET_TARGET_Y_SHIFT = 3,
  747. BMA253_OFC_SETTING_OFFSET_TARGET_Z0 = 0x20,
  748. BMA253_OFC_SETTING_OFFSET_TARGET_Z1 = 0x40,
  749. _BMA253_OFC_SETTING_OFFSET_TARGET_Z_MASK = 3,
  750. _BMA253_OFC_SETTING_OFFSET_TARGET_Z_SHIFT = 5
  751. // 0x80 reserved
  752. } BMA253_OFC_SETTING_BITS_T;
  753. /**
  754. * OFC_SETTING_OFFSET_TARGET (for X, Y and Z axis) values
  755. */
  756. typedef enum
  757. {
  758. BMA253_OFFSET_TARGET_0G = 0,
  759. BMA253_OFFSET_TARGET_PLUS_1G = 1,
  760. BMA253_OFFSET_TARGET_MINUS_1G = 2,
  761. // 3 == 0G
  762. } BMA253_OFFSET_TARGET_T;
  763. /**
  764. * REG_FIFO_CONFIG_1 bits
  765. */
  766. typedef enum
  767. {
  768. BMA253_FIFO_CONFIG_1_FIFO_DATA_SEL0 = 0x01,
  769. BMA253_FIFO_CONFIG_1_FIFO_DATA_SEL1 = 0x02,
  770. _BMA253_FIFO_CONFIG_1_FIFO_DATA_SEL = 3,
  771. _BMA253_FIFO_CONFIG_1_FIFO_DATA_SHIFT = 0,
  772. // 0x04-0x20 reserved
  773. BMA253_FIFO_CONFIG_1_FIFO_MODE0 = 0x40,
  774. BMA253_FIFO_CONFIG_1_FIFO_MODE1 = 0x80,
  775. _BMA253_FIFO_CONFIG_1_FIFO_MODE_MASK = 3,
  776. _BMA253_FIFO_CONFIG_1_FIFO_MODE_SHIFT = 6
  777. } BMA253_FIFO_CONFIG_1_BITS_T;
  778. /**
  779. * FIFO_DATA_SEL values
  780. */
  781. typedef enum
  782. {
  783. BMA253_FIFO_DATA_SEL_XYZ = 0,
  784. BMA253_FIFO_DATA_SEL_X = 1,
  785. BMA253_FIFO_DATA_SEL_Y = 2,
  786. BMA253_FIFO_DATA_SEL_Z = 3
  787. } BMA253_FIFO_DATA_SEL_T;
  788. /**
  789. * FIFO_MODE values
  790. */
  791. typedef enum
  792. {
  793. BMA253_FIFO_MODE_BYPASS = 0,
  794. BMA253_FIFO_MODE_FIFO = 1,
  795. BMA253_FIFO_MODE_STREAM = 2
  796. // 3 == reserved (execute self-destruct :)
  797. } BMA253_FIFO_MODE_T;
  798. // interrupt selection for installISR() and uninstallISR()
  799. typedef enum
  800. {
  801. BMA253_INTERRUPT_INT1,
  802. BMA253_INTERRUPT_INT2
  803. } BMA253_INTERRUPT_PINS_T;
  804. // Different variants of this chip support different resolutions.
  805. // The 0xf9 variant supports 10b, while the 0xfa variant (bmx055)
  806. // supports 12 bits.
  807. typedef enum
  808. {
  809. BMA253_RESOLUTION_10BITS,
  810. BMA253_RESOLUTION_12BITS
  811. } BMA253_RESOLUTION_T;
  812. #endif