My version of the library for this accelerometer. It works on 800Hz data rate.

Fork of MMA8451Q by Antonio Quevedo

Committer:
DWeng
Date:
Tue Jul 18 18:34:24 2017 +0000
Revision:
1:9c229882cd2b
Parent:
0:7c9ab58f6af3
initial commit.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
quevedo 0:7c9ab58f6af3 1 /* Copyright (c) 2010-2011 mbed.org, MIT License
quevedo 0:7c9ab58f6af3 2 * Copyright (c) 2014 Antonio Quevedo, UNICAMP
quevedo 0:7c9ab58f6af3 3 *
quevedo 0:7c9ab58f6af3 4 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
quevedo 0:7c9ab58f6af3 5 * and associated documentation files (the "Software"), to deal in the Software without
quevedo 0:7c9ab58f6af3 6 * restriction, including without limitation the rights to use, copy, modify, merge, publish,
quevedo 0:7c9ab58f6af3 7 * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
quevedo 0:7c9ab58f6af3 8 * Software is furnished to do so, subject to the following conditions:
quevedo 0:7c9ab58f6af3 9 *
quevedo 0:7c9ab58f6af3 10 * The above copyright notice and this permission notice shall be included in all copies or
quevedo 0:7c9ab58f6af3 11 * substantial portions of the Software.
quevedo 0:7c9ab58f6af3 12 *
quevedo 0:7c9ab58f6af3 13 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
quevedo 0:7c9ab58f6af3 14 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
quevedo 0:7c9ab58f6af3 15 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
quevedo 0:7c9ab58f6af3 16 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
quevedo 0:7c9ab58f6af3 17 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
quevedo 0:7c9ab58f6af3 18 */
quevedo 0:7c9ab58f6af3 19
quevedo 0:7c9ab58f6af3 20 #include "MMA8451Q.h"
quevedo 0:7c9ab58f6af3 21
quevedo 0:7c9ab58f6af3 22 #define ACCEL_I2C_ADDRESS 0x1D<<1
quevedo 0:7c9ab58f6af3 23 #define REG_STATUS 0x00
quevedo 0:7c9ab58f6af3 24 #define REG_XYZ_DATA_CFG 0x0E
quevedo 0:7c9ab58f6af3 25 #define REG_WHO_AM_I 0x0D
quevedo 0:7c9ab58f6af3 26 #define REG_CTRL_REG1 0x2A
quevedo 0:7c9ab58f6af3 27 #define REG_CTRL_REG2 0x2B
quevedo 0:7c9ab58f6af3 28 #define REG_CTRL_REG3 0x2C
quevedo 0:7c9ab58f6af3 29 #define REG_CTRL_REG4 0x2D
quevedo 0:7c9ab58f6af3 30 #define REG_CTRL_REG5 0x2E
quevedo 0:7c9ab58f6af3 31 #define REG_OUT_X_MSB 0x01
quevedo 0:7c9ab58f6af3 32 #define REG_OUT_Y_MSB 0x03
quevedo 0:7c9ab58f6af3 33 #define REG_OUT_Z_MSB 0x05
quevedo 0:7c9ab58f6af3 34
quevedo 0:7c9ab58f6af3 35 MMA8451Q::MMA8451Q(PinName sda, PinName scl) : m_i2c(sda, scl) {
quevedo 0:7c9ab58f6af3 36 uint8_t data[2] = {REG_CTRL_REG1, 0x00}; // Puts acc in standby for configuring
quevedo 0:7c9ab58f6af3 37 writeRegs(data, 2);
quevedo 0:7c9ab58f6af3 38 data[0] = REG_XYZ_DATA_CFG; // Writing 00 turns off high-pass filter and sets full scale range to 2g
DWeng 1:9c229882cd2b 39 // data[1] = 0x01; for 4g
DWeng 1:9c229882cd2b 40 // data[1] = 0x02; for 8g
DWeng 1:9c229882cd2b 41 data[1] = 0x00;
DWeng 1:9c229882cd2b 42 writeRegs(data, 2);
quevedo 0:7c9ab58f6af3 43 data[0] = REG_CTRL_REG2;
quevedo 0:7c9ab58f6af3 44 data[1] = 0x00; // Disable self-test, software reset and auto-sleep; operates in normal mode
quevedo 0:7c9ab58f6af3 45 writeRegs(data, 2);
quevedo 0:7c9ab58f6af3 46 data[0] = REG_CTRL_REG3; // Interrupt polarity low, push-pull output
quevedo 0:7c9ab58f6af3 47 writeRegs(data, 2);
quevedo 0:7c9ab58f6af3 48 data[0] = REG_CTRL_REG4;
quevedo 0:7c9ab58f6af3 49 data[1] = 0x01; // Enables interrupt for data Ready
quevedo 0:7c9ab58f6af3 50 writeRegs(data, 2);
quevedo 0:7c9ab58f6af3 51 data[0] = REG_CTRL_REG5;
quevedo 0:7c9ab58f6af3 52 writeRegs(data, 2); // Routes Data Ready interrupt to INT1
quevedo 0:7c9ab58f6af3 53 data[0] = REG_CTRL_REG1;
DWeng 1:9c229882cd2b 54 data[1] = 0x09; // Data rate is 400Hz
quevedo 0:7c9ab58f6af3 55 writeRegs(data, 2);
quevedo 0:7c9ab58f6af3 56 }
quevedo 0:7c9ab58f6af3 57
quevedo 0:7c9ab58f6af3 58 MMA8451Q::~MMA8451Q() { }
quevedo 0:7c9ab58f6af3 59
quevedo 0:7c9ab58f6af3 60 void MMA8451Q::getAccAllAxis(int16_t * res) {
quevedo 0:7c9ab58f6af3 61 uint8_t temp[6];
quevedo 0:7c9ab58f6af3 62 readRegs(REG_OUT_X_MSB, temp, 6);
DWeng 1:9c229882cd2b 63 res[0] = ((temp[0] << 8) + temp[1]);
DWeng 1:9c229882cd2b 64 res[1] = ((temp[2] << 8) + temp[3]);
DWeng 1:9c229882cd2b 65 res[2] = ((temp[4] << 8) + temp[5]);
quevedo 0:7c9ab58f6af3 66 }
quevedo 0:7c9ab58f6af3 67
quevedo 0:7c9ab58f6af3 68 void MMA8451Q::readRegs(int addr, uint8_t * data, int len) {
quevedo 0:7c9ab58f6af3 69 char t[1] = {addr};
quevedo 0:7c9ab58f6af3 70 m_i2c.write(ACCEL_I2C_ADDRESS, t, 1, true);
quevedo 0:7c9ab58f6af3 71 m_i2c.read(ACCEL_I2C_ADDRESS, (char *)data, len);
quevedo 0:7c9ab58f6af3 72 }
quevedo 0:7c9ab58f6af3 73
quevedo 0:7c9ab58f6af3 74 void MMA8451Q::writeRegs(uint8_t * data, int len) {
quevedo 0:7c9ab58f6af3 75 m_i2c.write(ACCEL_I2C_ADDRESS, (char *)data, len);
quevedo 0:7c9ab58f6af3 76 }