27 #include <mraa/common.hpp>
28 #include <mraa/i2c.hpp>
29 #include <mraa/gpio.hpp>
31 #define BMA220_I2C_BUS 0
32 #define BMA220_DEFAULT_ADDR 0x0a
83 REG_REVISIONID = 0x02,
90 REG_H_HYST_DUR = 0x0a,
92 REG_L_HYST_DUR = 0x0e,
94 REG_TAP_CONFIG = 0x10,
96 REG_SLOPE_CONFIG = 0x12,
97 REG_TAP_CONFIG2 = 0x14,
99 REG_INT_STATUS1 = 0x16,
100 REG_INT_STATUS2 = 0x18,
102 REG_ENABLE_CONFIG = 0x1a,
103 REG_ENABLE_CONFIG2 = 0x1c,
104 REG_ENABLE_CONFIG3 = 0x1e,
106 REG_FILTER_CONFIG = 0x20,
108 REG_SBIST_FSL_CONFIG = 0x22,
112 REG_I2C_WATCHDOG = 0x2e,
123 H_HYST_DUR_HIGH_DUR0 = 0x01,
124 H_HYST_DUR_HIGH_DUR1 = 0x02,
125 H_HYST_DUR_HIGH_DUR2 = 0x04,
126 H_HYST_DUR_HIGH_DUR3 = 0x08,
127 H_HYST_DUR_HIGH_DUR4 = 0x10,
128 H_HYST_DUR_HIGH_DUR5 = 0x20,
129 _H_HYST_DUR_HIGH_DUR_MASK = 63,
130 _H_HYST_DUR_HIGH_DUR_SHIFT = 0,
132 H_HYST_DUR_HIGH_HY1 = 0x40,
133 H_HYST_DUR_HIGH_HY2 = 0x80,
134 _H_HYST_DUR_HIGH_HY_MASK = 3,
135 _H_HYST_DUR_HIGH_HY_SHIFT = 6
142 THRESHOLD_HIGH0 = 0x01,
143 THRESHOLD_HIGH1 = 0x02,
144 THRESHOLD_HIGH2 = 0x04,
145 THRESHOLD_HIGH3 = 0x08,
146 _THRESHOLD_HIGH_MASK = 15,
147 _THRESHOLD_HIGH_SHIFT = 0,
149 THRESHOLD_LOW0 = 0x10,
150 THRESHOLD_LOW1 = 0x20,
151 THRESHOLD_LOW2 = 0x40,
152 THRESHOLD_LOW3 = 0x80,
153 _THRESHOLD_LOW_MASK = 15,
154 _THRESHOLD_LOW_SHIFT = 4
161 L_HYST_DUR_LOW_DUR0 = 0x01,
162 L_HYST_DUR_LOW_DUR1 = 0x02,
163 L_HYST_DUR_LOW_DUR2 = 0x04,
164 L_HYST_DUR_LOW_DUR3 = 0x08,
165 L_HYST_DUR_LOW_DUR4 = 0x10,
166 L_HYST_DUR_LOW_DUR5 = 0x20,
167 _L_HYST_DUR_LOW_DUR_MASK = 63,
168 _L_HYST_DUR_LOW_DUR_SHIFT = 0,
170 L_HYST_DUR_LOW_HY1 = 0x40,
171 L_HYST_DUR_LOW_HY2 = 0x80,
172 _L_HYST_DUR_LOW_HY_MASK = 3,
173 _L_HYST_DUR_LOW_HY_SHIFT = 6
180 TAP_CONFIG_DUR0 = 0x01,
181 TAP_CONFIG_DUR1 = 0x02,
182 TAP_CONFIG_DUR2 = 0x04,
183 _TAP_CONFIG_DUR_MASK = 7,
184 _TAP_CONFIG_DUR_SHIFT = 0,
186 TAP_CONFIG_THRESH0 = 0x08,
187 TAP_CONFIG_THRESH1 = 0x10,
188 TAP_CONFIG_THRESH2 = 0x20,
189 TAP_CONFIG_THRESH3 = 0x40,
190 _TAP_CONFIG_THRESH_MASK = 15,
191 _TAP_CONFIG_THRESH_SHIFT = 3,
193 TAP_CONFIG_FILTER = 0x80
200 SLOPE_CONFIG_DUR0 = 0x01,
201 SLOPE_CONFIG_DUR1 = 0x02,
202 _SLOPE_CONFIG_DUR_MASK = 3,
203 _SLOPE_CONFIG_DUR_SHIFT = 0,
205 SLOPE_CONFIG_THRESH0 = 0x04,
206 SLOPE_CONFIG_THRESH1 = 0x08,
207 SLOPE_CONFIG_THRESH2 = 0x10,
208 SLOPE_CONFIG_THRESH3 = 0x20,
209 _SLOPE_CONFIG_THRESH_MASK = 15,
210 _SLOPE_CONFIG_THRESH_SHIFT = 2,
212 SLOPE_CONFIG_FILTER = 0x40,
213 SLOPE_CONFIG_ORIENT_EX = 0x80
220 TAP_CONFIG2_SAMP0 = 0x01,
221 TAP_CONFIG2_SAMP1 = 0x02,
222 _TAP_CONFIG2_SAMP_MASK = 3,
223 _TAP_CONFIG2_SAMP_SHIFT = 0,
225 TAP_CONFIG2_ORIENT_BLOCK0 = 0x04,
226 TAP_CONFIG2_ORIENT_BLOCK1 = 0x08,
227 _TAP_CONFIG2_ORIENT_BLOCK_MASK = 3,
228 _TAP_CONFIG2_ORIENT_BLOCK_SHIFT = 2,
230 TAP_CONFIG2_TIP_EN = 0x10
250 TAP_ORIENT_BLOCK_0 = 0,
251 TAP_ORIENT_BLOCK_2 = 1,
252 TAP_ORIENT_BLOCK_3 = 2,
253 TAP_ORIENT_BLOCK_4 = 3,
260 INT_STATUS1_SIGN = 0x01,
261 INT_STATUS1_FIRST_Z = 0x02,
262 INT_STATUS1_FIRST_Y = 0x04,
263 INT_STATUS1_FIRST_X = 0x08,
265 INT_STATUS1_ORIENT0 = 0x10,
266 INT_STATUS1_ORIENT1 = 0x20,
267 INT_STATUS1_ORIENT2 = 0x40,
268 _INT_STATUS1_ORIENT_MASK = 7,
269 _INT_STATUS1_ORIENT_SHIFT = 4,
271 INT_STATUS1_ORIENT_INT = 0x80
281 CONFIG_ORI_UP_PORT_UPRIGHT = 0,
282 CONFIG_ORI_UP_PORT_UPSIDE_DOWN = 1,
283 CONFIG_ORI_UP_LAND_LEFT = 2,
284 CONFIG_ORI_UP_LAND_RIGHT = 3,
285 CONFIG_ORI_DN_PORT_UPRIGHT = 4,
286 CONFIG_ORI_DN_PORT_UPSIDE_DOWN = 5,
287 CONFIG_ORI_DN_LAND_LEFT = 6,
288 CONFIG_ORI_DN_LAND_RIGHT = 7
295 INT_STATUS2_SLOPE = 0x01,
296 INT_STATUS2_DATA = 0x02,
297 INT_STATUS2_HIGH = 0x04,
298 INT_STATUS2_LOW = 0x08,
299 INT_STATUS2_TAP = 0x10
308 ENABLE_CONFIG_TT_Z = 0x01,
309 ENABLE_CONFIG_TT_Y = 0x02,
310 ENABLE_CONFIG_TT_X = 0x04,
311 ENABLE_CONFIG_SLOPE_Z = 0x08,
312 ENABLE_CONFIG_SLOPE_Y = 0x10,
313 ENABLE_CONFIG_SLOPE_X = 0x20,
314 ENABLE_CONFIG_ORIENT = 0x40,
315 ENABLE_CONFIG_DATA = 0x80
322 ENABLE_CONFIG2_HIGH_Z = 0x01,
323 ENABLE_CONFIG2_HIGH_Y = 0x02,
324 ENABLE_CONFIG2_HIGH_X = 0x04,
326 ENABLE_CONFIG2_LOW = 0x08,
328 ENABLE_CONFIG2_LAT_INT0 = 0x10,
329 ENABLE_CONFIG2_LAT_INT1 = 0x20,
330 ENABLE_CONFIG2_LAT_INT2 = 0x40,
331 _ENABLE_CONFIG2_LAT_INT_MASK = 7,
332 _ENABLE_CONFIG2_LAT_INT_SHIFT = 4,
334 ENABLE_CONFIG2_RESET_INT = 0x80
343 CONFIG2_LAT_UNLATCH = 0,
344 CONFIG2_LAT_0_25 = 1,
357 ENABLE_CONFIG3_Z_CHAN = 0x01,
358 ENABLE_CONFIG3_Y_CHAN = 0x02,
359 ENABLE_CONFIG3_X_CHAN = 0x04,
361 ENABLE_CONFIG3_SLEEP_DUR0 = 0x08,
362 ENABLE_CONFIG3_SLEEP_DUR1 = 0x10,
363 ENABLE_CONFIG3_SLEEP_DUR2 = 0x20,
364 _ENABLE_CONFIG3_SLEEP_DUR_MASK = 7,
365 _ENABLE_CONFIG3_SLEEP_DUR_SHIFT = 3,
367 ENABLE_CONFIG3_SLEEP_EN = 0x40
393 FILTER_CONFIG_FILTER0 = 0x01,
394 FILTER_CONFIG_FILTER1 = 0x02,
395 FILTER_CONFIG_FILTER2 = 0x04,
396 FILTER_CONFIG_FILTER3 = 0x08,
397 _FILTER_CONFIG_FILTER_MASK = 15,
398 _FILTER_CONFIG_FILTER_SHIFT = 0,
402 FILTER_CONFIG_SERIAL_HIGH_BW = 0x80
411 FILTER_CONFIG_1KHZ = 0,
412 FILTER_CONFIG_500HZ = 1,
413 FILTER_CONFIG_250HZ = 2,
414 FILTER_CONFIG_125HZ = 3,
415 FILTER_CONFIG_64HZ = 4,
416 FILTER_CONFIG_32HZ = 5
423 REG_SBIST_FSL_RANGE0 = 0x01,
424 REG_SBIST_FSL_RANGE1 = 0x02,
425 _REG_SBIST_FSL_RANGE_MASK = 3,
426 _REG_SBIST_FSL_RANGE_SHIFT = 0,
428 REG_SBIST_FSL_SBIST0 = 0x04,
429 REG_SBIST_FSL_SBIST1 = 0x08,
430 _REG_SBIST_FSL_SBIST_MASK = 3,
431 _REG_SBIST_FSL_SBIST_SHIFT = 2,
433 REG_SBIST_FSL_SBIST_SIGN = 0x10
466 I2C_WATCHDOG_SPI3 = 0x01,
468 I2C_WATCHDOG_TO_SEL = 0x02,
469 I2C_WATCHDOG_TO_EN = 0x04
481 BMA220(
int bus=BMA220_I2C_BUS, uint8_t addr=BMA220_DEFAULT_ADDR);
510 bool writeReg(uint8_t reg, uint8_t val);
543 #if defined(SWIGJAVA) || defined(JAVACALLBACK)
578 bool enableAxes(
bool xEn,
bool yEn,
bool zEn);
604 bool sleep(
bool enable);
780 #if defined(SWIGJAVA) || defined(JAVACALLBACK)
781 void installISR(
int gpio, mraa::Edge level, jobject runnable);
794 void (*isr)(
void *),
void *arg);
805 mraa::Gpio *m_gpioIntr;
820 void updateAccelerometer();
822 #if defined(SWIGJAVA) || defined(JAVACALLBACK)
824 void (*isr)(
void *),
void *arg);
uint8_t readReg(uint8_t reg)
Definition: bma220.cxx:97
uint8_t softReset()
Definition: bma220.cxx:239
SBIST_FSL_CONFIG_BITS_T
Definition: bma220.h:422
bool enableTapFilter(bool filt)
Definition: bma220.cxx:371
FILTER_CONFIG_BITS_T
Definition: bma220.h:392
uint8_t getInterruptEnables1()
Definition: bma220.cxx:447
bool setTapDuration(uint8_t dur)
Definition: bma220.cxx:345
uint8_t getInterruptStatus2()
Definition: bma220.cxx:437
bool resetInterrupts()
Definition: bma220.cxx:481
TAP_SAMP_T
Definition: bma220.h:238
THRESHOLD_BITS_T
Definition: bma220.h:141
void getAccelerometer(float *x, float *y, float *z)
Definition: bma220.cxx:158
uint8_t getInterruptEnables2()
Definition: bma220.cxx:465
bool setAccelerometerScale(FSL_RANGE_T scale)
Definition: bma220.cxx:115
L_HYST_DUR_LOW_BITS_T
Definition: bma220.h:160
bool setSleepDuration(SLEEP_DUR_T dur)
Definition: bma220.cxx:256
bool setInterruptEnables1(uint8_t bits)
Definition: bma220.cxx:442
bool setInterruptEnables2(uint8_t bits)
Definition: bma220.cxx:452
bool setSlopeThreshold(uint8_t thresh)
Definition: bma220.cxx:396
bool setLowGThreshold(uint8_t thresh)
Definition: bma220.cxx:267
ENABLE_CONFIG3_BITS_T
Definition: bma220.h:356
SLOPE_CONFIG_BITS_T
Definition: bma220.h:199
void uninstallISR()
Definition: bma220.cxx:521
I2C_WATCHDOG_BITS_T
Definition: bma220.h:465
TAP_CONFIG2_BITS_T
Definition: bma220.h:219
uint8_t getInterruptStatus1()
Definition: bma220.cxx:421
uint8_t getChipRevision()
Definition: bma220.cxx:184
FSL_RANGE_T
Definition: bma220.h:443
bool setHighGThreshold(uint8_t thresh)
Definition: bma220.cxx:280
void update()
Definition: bma220.cxx:73
REG_T
Definition: bma220.h:81
bool enableSlopeFilter(bool filt)
Definition: bma220.cxx:409
uint8_t suspend()
Definition: bma220.cxx:234
CONFIG_ORIENT_T getOrient()
Definition: bma220.cxx:426
TAP_CONFIG_BITS_T
Definition: bma220.h:179
bool setFilterConfig(FILTER_CONFIG_T filter)
Definition: bma220.cxx:189
void installISR(int gpio, mraa::Edge level, void(*isr)(void *), void *arg)
Definition: bma220.cxx:507
SBIST_T
Definition: bma220.h:455
bool enableAxes(bool xEn, bool yEn, bool zEn)
Definition: bma220.cxx:212
ENABLE_CONFIG_BITS_T
Definition: bma220.h:307
INT_STATUS1_BITS_T
Definition: bma220.h:259
CONFIG2_LAT_T
Definition: bma220.h:342
FILTER_CONFIG_T
Definition: bma220.h:410
bool setInterruptLatch(CONFIG2_LAT_T lat)
Definition: bma220.cxx:470
bool writeReg(uint8_t reg, uint8_t val)
Definition: bma220.cxx:102
ENABLE_CONFIG2_BITS_T
Definition: bma220.h:321
bool setHighGDuration(uint8_t dur)
Definition: bma220.cxx:332
bool sleep(bool enable)
Definition: bma220.cxx:244
API for the BMA220 3-axis Accelerometer.
Definition: bma220.h:69
CONFIG_ORIENT_T
Definition: bma220.h:280
H_HYST_DUR_HIGH_BITS_T
Definition: bma220.h:122
bool setSlopeDuration(uint8_t dur)
Definition: bma220.cxx:383
TAP_ORIENT_BLOCK_T
Definition: bma220.h:249
uint8_t getChipID()
Definition: bma220.cxx:179
INT_STATUS2_BITS_T
Definition: bma220.h:294
bool setHighGHysteresis(uint8_t hyst)
Definition: bma220.cxx:319
bool setLowGDuration(uint8_t dur)
Definition: bma220.cxx:306
bool setTapThreshold(uint8_t thresh)
Definition: bma220.cxx:358
SLEEP_DUR_T
Definition: bma220.h:378
BMA220(int bus=BMA220_I2C_BUS, uint8_t addr=BMA220_DEFAULT_ADDR)
Definition: bma220.cxx:37
bool setLowGHysteresis(uint8_t hyst)
Definition: bma220.cxx:293
bool setSerialHighBW(bool high)
Definition: bma220.cxx:200
~BMA220()
Definition: bma220.cxx:68