Device driver for the Freescale MMA845x family of accelerometers.
Fork of MMA845x by
MMA845x.h@1:37ddb4739f02, 2017-01-05 (annotated)
- Committer:
- 1994timmeh
- Date:
- Thu Jan 05 06:41:39 2017 +0000
- Revision:
- 1:37ddb4739f02
- Parent:
- 0:9d1e3a344e4f
- Child:
- 2:555f8ba0c959
asdfasdfadsf
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
sam_grove | 0:9d1e3a344e4f | 1 | /** |
sam_grove | 0:9d1e3a344e4f | 2 | * @file MMA845x.h |
sam_grove | 0:9d1e3a344e4f | 3 | * @brief Device driver - MMA845x 3-axis accelerometer IC |
sam_grove | 0:9d1e3a344e4f | 4 | * @author sam grove |
sam_grove | 0:9d1e3a344e4f | 5 | * @version 1.0 |
sam_grove | 0:9d1e3a344e4f | 6 | * @see http://cache.freescale.com/files/sensors/doc/data_sheet/MMA8451Q.pdf |
sam_grove | 0:9d1e3a344e4f | 7 | * @see http://cache.freescale.com/files/sensors/doc/data_sheet/MMA8452Q.pdf |
sam_grove | 0:9d1e3a344e4f | 8 | * @see http://cache.freescale.com/files/sensors/doc/data_sheet/MMA8453Q.pdf |
sam_grove | 0:9d1e3a344e4f | 9 | * |
sam_grove | 0:9d1e3a344e4f | 10 | * Copyright (c) 2013 |
sam_grove | 0:9d1e3a344e4f | 11 | * |
sam_grove | 0:9d1e3a344e4f | 12 | * Licensed under the Apache License, Version 2.0 (the "License"); |
sam_grove | 0:9d1e3a344e4f | 13 | * you may not use this file except in compliance with the License. |
sam_grove | 0:9d1e3a344e4f | 14 | * You may obtain a copy of the License at |
sam_grove | 0:9d1e3a344e4f | 15 | * |
sam_grove | 0:9d1e3a344e4f | 16 | * http://www.apache.org/licenses/LICENSE-2.0 |
sam_grove | 0:9d1e3a344e4f | 17 | * |
sam_grove | 0:9d1e3a344e4f | 18 | * Unless required by applicable law or agreed to in writing, software |
sam_grove | 0:9d1e3a344e4f | 19 | * distributed under the License is distributed on an "AS IS" BASIS, |
sam_grove | 0:9d1e3a344e4f | 20 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
sam_grove | 0:9d1e3a344e4f | 21 | * See the License for the specific language governing permissions and |
sam_grove | 0:9d1e3a344e4f | 22 | * limitations under the License. |
sam_grove | 0:9d1e3a344e4f | 23 | */ |
sam_grove | 0:9d1e3a344e4f | 24 | |
sam_grove | 0:9d1e3a344e4f | 25 | #ifndef MMA845X_H |
sam_grove | 0:9d1e3a344e4f | 26 | #define MMA845X_H |
sam_grove | 0:9d1e3a344e4f | 27 | |
sam_grove | 0:9d1e3a344e4f | 28 | #include "mbed.h" |
sam_grove | 0:9d1e3a344e4f | 29 | |
sam_grove | 0:9d1e3a344e4f | 30 | /** Using the Sparkfun SEN-10955 |
sam_grove | 0:9d1e3a344e4f | 31 | * |
sam_grove | 0:9d1e3a344e4f | 32 | * Example: |
sam_grove | 0:9d1e3a344e4f | 33 | * @code |
sam_grove | 0:9d1e3a344e4f | 34 | * #include "mbed.h" |
sam_grove | 0:9d1e3a344e4f | 35 | * #include "MMA845x.h" |
sam_grove | 0:9d1e3a344e4f | 36 | * |
sam_grove | 0:9d1e3a344e4f | 37 | |
sam_grove | 0:9d1e3a344e4f | 38 | * |
sam_grove | 0:9d1e3a344e4f | 39 | * int main() |
sam_grove | 0:9d1e3a344e4f | 40 | * { |
sam_grove | 0:9d1e3a344e4f | 41 | |
sam_grove | 0:9d1e3a344e4f | 42 | * } |
sam_grove | 0:9d1e3a344e4f | 43 | * @endcode |
sam_grove | 0:9d1e3a344e4f | 44 | */ |
sam_grove | 0:9d1e3a344e4f | 45 | |
sam_grove | 0:9d1e3a344e4f | 46 | |
sam_grove | 0:9d1e3a344e4f | 47 | /** |
sam_grove | 0:9d1e3a344e4f | 48 | * @class MMA845x_DATA |
sam_grove | 0:9d1e3a344e4f | 49 | * @brief API abstraction for the MMA845x 3-axis accelerometer IC data |
sam_grove | 0:9d1e3a344e4f | 50 | */ |
sam_grove | 0:9d1e3a344e4f | 51 | class MMA845x_DATA |
sam_grove | 0:9d1e3a344e4f | 52 | { |
sam_grove | 0:9d1e3a344e4f | 53 | public: |
sam_grove | 0:9d1e3a344e4f | 54 | |
sam_grove | 0:9d1e3a344e4f | 55 | volatile uint16_t _x; /*!< volatile data variable */ |
sam_grove | 0:9d1e3a344e4f | 56 | volatile uint16_t _y; /*!< volatile data variable */ |
sam_grove | 0:9d1e3a344e4f | 57 | volatile uint16_t _z; /*!< volatile data variable */ |
sam_grove | 0:9d1e3a344e4f | 58 | |
sam_grove | 0:9d1e3a344e4f | 59 | /** Create the MMA845x_DATA object initialized to the parameter (or 0 if none) |
sam_grove | 0:9d1e3a344e4f | 60 | * @param x - the init value of _x |
sam_grove | 0:9d1e3a344e4f | 61 | * @param y - the init value of _y |
sam_grove | 0:9d1e3a344e4f | 62 | * @param x - the init value of _z |
sam_grove | 0:9d1e3a344e4f | 63 | */ |
sam_grove | 0:9d1e3a344e4f | 64 | MMA845x_DATA(uint16_t x = 0, uint16_t y = 0, uint16_t z = 0) : _x(x), _y(y), _z(z) {} |
sam_grove | 0:9d1e3a344e4f | 65 | |
sam_grove | 0:9d1e3a344e4f | 66 | /** Overloaded '=' operator to allow shorthand coding, assigning objects to one another |
sam_grove | 0:9d1e3a344e4f | 67 | * @param rhs - an object of the same type to assign ourself the same values of |
sam_grove | 0:9d1e3a344e4f | 68 | * @return this |
sam_grove | 0:9d1e3a344e4f | 69 | */ |
sam_grove | 0:9d1e3a344e4f | 70 | MMA845x_DATA &operator= (MMA845x_DATA const &rhs) |
sam_grove | 0:9d1e3a344e4f | 71 | { |
sam_grove | 0:9d1e3a344e4f | 72 | _x = rhs._x; |
sam_grove | 0:9d1e3a344e4f | 73 | _y = rhs._y; |
sam_grove | 0:9d1e3a344e4f | 74 | _z = rhs._z; |
sam_grove | 0:9d1e3a344e4f | 75 | |
sam_grove | 0:9d1e3a344e4f | 76 | return *this; |
sam_grove | 0:9d1e3a344e4f | 77 | } |
sam_grove | 0:9d1e3a344e4f | 78 | |
sam_grove | 0:9d1e3a344e4f | 79 | /** Overloaded '=' operator to allow shorthand coding, assigning objects to one another |
sam_grove | 0:9d1e3a344e4f | 80 | * @param val - Assign each data member (_x, _y, _z) this value |
sam_grove | 0:9d1e3a344e4f | 81 | * @return this |
sam_grove | 0:9d1e3a344e4f | 82 | */ |
sam_grove | 0:9d1e3a344e4f | 83 | MMA845x_DATA &operator= (uint16_t const val) |
sam_grove | 0:9d1e3a344e4f | 84 | { |
sam_grove | 0:9d1e3a344e4f | 85 | _x = _y = _z = val; |
sam_grove | 0:9d1e3a344e4f | 86 | |
sam_grove | 0:9d1e3a344e4f | 87 | return *this; |
sam_grove | 0:9d1e3a344e4f | 88 | } |
sam_grove | 0:9d1e3a344e4f | 89 | |
sam_grove | 0:9d1e3a344e4f | 90 | /** Overloaded '==' operator to allow shorthand coding, test objects to one another |
sam_grove | 0:9d1e3a344e4f | 91 | * @param rhs - the object to compare against |
sam_grove | 0:9d1e3a344e4f | 92 | * @return 1 if the data members are the same and 0 otherwise |
sam_grove | 0:9d1e3a344e4f | 93 | */ |
sam_grove | 0:9d1e3a344e4f | 94 | bool operator== (MMA845x_DATA const &rhs) const |
sam_grove | 0:9d1e3a344e4f | 95 | { |
sam_grove | 0:9d1e3a344e4f | 96 | return ((_x == rhs._x)&&(_y == rhs._y)&&(_z == rhs._z)) ? 1 : 0; |
sam_grove | 0:9d1e3a344e4f | 97 | } |
sam_grove | 0:9d1e3a344e4f | 98 | |
sam_grove | 0:9d1e3a344e4f | 99 | }; |
sam_grove | 0:9d1e3a344e4f | 100 | |
sam_grove | 0:9d1e3a344e4f | 101 | /** |
sam_grove | 0:9d1e3a344e4f | 102 | * @class MMA845x |
sam_grove | 0:9d1e3a344e4f | 103 | * @brief API abstraction for the MMA845x 3-axis accelerometer IC |
sam_grove | 0:9d1e3a344e4f | 104 | */ |
sam_grove | 0:9d1e3a344e4f | 105 | class MMA845x |
sam_grove | 0:9d1e3a344e4f | 106 | { |
sam_grove | 0:9d1e3a344e4f | 107 | public: |
sam_grove | 0:9d1e3a344e4f | 108 | |
sam_grove | 0:9d1e3a344e4f | 109 | /** |
sam_grove | 0:9d1e3a344e4f | 110 | * @enum MMA845x_SA0 |
sam_grove | 0:9d1e3a344e4f | 111 | * @brief Possible terminations for the ADDR pin |
sam_grove | 0:9d1e3a344e4f | 112 | */ |
1994timmeh | 1:37ddb4739f02 | 113 | enum MMA845x_SA0 { |
sam_grove | 0:9d1e3a344e4f | 114 | SA0_VSS = 0, /*!< SA0 connected to VSS */ |
sam_grove | 0:9d1e3a344e4f | 115 | SA0_VDD /*!< SA0 connected to VDD */ |
sam_grove | 0:9d1e3a344e4f | 116 | }; |
sam_grove | 0:9d1e3a344e4f | 117 | |
sam_grove | 0:9d1e3a344e4f | 118 | /** |
sam_grove | 0:9d1e3a344e4f | 119 | * @enum MMA845x_WHO_AM_I |
sam_grove | 0:9d1e3a344e4f | 120 | * @brief Device ID's that this class is compatible with |
sam_grove | 0:9d1e3a344e4f | 121 | */ |
1994timmeh | 1:37ddb4739f02 | 122 | enum MMA845x_WHO_AM_I { |
sam_grove | 0:9d1e3a344e4f | 123 | MMA8451 = 0x1a, /*!< MMA8451 WHO_AM_I register content */ |
sam_grove | 0:9d1e3a344e4f | 124 | MMA8452 = 0x2a, /*!< MMA8452 WHO_AM_I register content */ |
sam_grove | 0:9d1e3a344e4f | 125 | MMA8453 = 0x3a, /*!< MMA8453 WHO_AM_I register content */ |
sam_grove | 0:9d1e3a344e4f | 126 | }; |
sam_grove | 0:9d1e3a344e4f | 127 | |
sam_grove | 0:9d1e3a344e4f | 128 | /** |
sam_grove | 0:9d1e3a344e4f | 129 | * @enum MMA845x_REGISTER |
sam_grove | 0:9d1e3a344e4f | 130 | * @brief The device register map |
sam_grove | 0:9d1e3a344e4f | 131 | */ |
1994timmeh | 1:37ddb4739f02 | 132 | enum MMA845x_REGISTER { |
sam_grove | 0:9d1e3a344e4f | 133 | STATUS = 0x0, |
sam_grove | 0:9d1e3a344e4f | 134 | OUT_X_MSB, OUT_X_LSB, OUT_Y_MSB, OUT_Y_LSB, OUT_Z_MSB, OUT_Z_LSB, |
sam_grove | 0:9d1e3a344e4f | 135 | |
sam_grove | 0:9d1e3a344e4f | 136 | F_SETUP = 0x9, TRIG_CFG, // only available on the MMA8451 variant |
sam_grove | 0:9d1e3a344e4f | 137 | |
sam_grove | 0:9d1e3a344e4f | 138 | SYSMOD = 0xb, |
sam_grove | 0:9d1e3a344e4f | 139 | INT_SOURCE, WHO_AM_I, XYZ_DATA_CFG, HP_FILTER_CUTOFF, PL_STATUS, |
sam_grove | 0:9d1e3a344e4f | 140 | PL_CFG, PL_COUNT, PL_BF_ZCOMP, P_L_THS_REG, FF_MT_CFG, FF_MT_SRC, |
sam_grove | 0:9d1e3a344e4f | 141 | FF_MT_THS, FF_MT_COUNT, |
sam_grove | 0:9d1e3a344e4f | 142 | |
sam_grove | 0:9d1e3a344e4f | 143 | TRANSIENT_CFG = 0x1d, |
sam_grove | 0:9d1e3a344e4f | 144 | TRANSIENT_SRC, TRANSIENT_THS, TRANSIENT_COUNT, PULSE_CFG, PULSE_SRC, |
sam_grove | 0:9d1e3a344e4f | 145 | PULSE_THSX, PULSE_THSY, PULSE_THSZ, PULSE_TMLT, PULSE_LTCY, PULSE_WIND, |
sam_grove | 0:9d1e3a344e4f | 146 | ASLP_COUNT, CTRL_REG1, CTRL_REG2, CTRL_REG3, CTRL_REG4, CTRL_REG5, |
sam_grove | 0:9d1e3a344e4f | 147 | OFF_X, OFF_Y, OFF_Z |
sam_grove | 0:9d1e3a344e4f | 148 | }; |
sam_grove | 0:9d1e3a344e4f | 149 | |
sam_grove | 0:9d1e3a344e4f | 150 | /** Create the MMA845x object |
sam_grove | 0:9d1e3a344e4f | 151 | * @param i2c - A defined I2C object |
sam_grove | 0:9d1e3a344e4f | 152 | * @param int1 - A defined InterruptIn object |
sam_grove | 0:9d1e3a344e4f | 153 | * @param int2 - A defined InterruptIn object |
sam_grove | 0:9d1e3a344e4f | 154 | * @param i2c_addr - Connection of the address line |
sam_grove | 0:9d1e3a344e4f | 155 | */ |
1994timmeh | 1:37ddb4739f02 | 156 | MMA845x(I2C &i2c, InterruptIn &int1, InterruptIn &int2); |
sam_grove | 0:9d1e3a344e4f | 157 | |
sam_grove | 0:9d1e3a344e4f | 158 | /** Get the X data |
sam_grove | 0:9d1e3a344e4f | 159 | * @return The last valid reading from the accelerometer |
sam_grove | 0:9d1e3a344e4f | 160 | */ |
sam_grove | 0:9d1e3a344e4f | 161 | uint16_t getX(void) const; |
sam_grove | 0:9d1e3a344e4f | 162 | |
sam_grove | 0:9d1e3a344e4f | 163 | /** Get the Y data |
sam_grove | 0:9d1e3a344e4f | 164 | * @return The last valid reading from the accelerometer |
sam_grove | 0:9d1e3a344e4f | 165 | */ |
sam_grove | 0:9d1e3a344e4f | 166 | uint16_t getY(void) const; |
sam_grove | 0:9d1e3a344e4f | 167 | |
sam_grove | 0:9d1e3a344e4f | 168 | /** Get the Z data |
sam_grove | 0:9d1e3a344e4f | 169 | * @return The last valid reading from the accelerometer |
sam_grove | 0:9d1e3a344e4f | 170 | */ |
sam_grove | 0:9d1e3a344e4f | 171 | uint16_t getZ(void) const; |
sam_grove | 0:9d1e3a344e4f | 172 | |
sam_grove | 0:9d1e3a344e4f | 173 | /** Get the XYZ data structure |
sam_grove | 0:9d1e3a344e4f | 174 | * @return The last valid reading from the accelerometer |
sam_grove | 0:9d1e3a344e4f | 175 | */ |
sam_grove | 0:9d1e3a344e4f | 176 | MMA845x_DATA getXYZ(void) const; |
sam_grove | 0:9d1e3a344e4f | 177 | |
sam_grove | 0:9d1e3a344e4f | 178 | void enableDataReadyMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 179 | void enableMotionMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 180 | void enablePulseMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 181 | void enableOrientationMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 182 | void enableTransitMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 183 | void enableAutoSleepMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 184 | void enableFIFOMode(void) const; |
sam_grove | 0:9d1e3a344e4f | 185 | |
sam_grove | 0:9d1e3a344e4f | 186 | /** Put the MMA845x in the lowest possible power mode and suspend operation |
sam_grove | 0:9d1e3a344e4f | 187 | */ |
sam_grove | 0:9d1e3a344e4f | 188 | void disable(void); |
sam_grove | 0:9d1e3a344e4f | 189 | |
sam_grove | 0:9d1e3a344e4f | 190 | /** Write to a register (exposed for debugging reasons) |
sam_grove | 0:9d1e3a344e4f | 191 | * Note: most writes are only valid in stop mode |
sam_grove | 0:9d1e3a344e4f | 192 | * @param reg - The register to be written |
sam_grove | 0:9d1e3a344e4f | 193 | * @param data - The data to be written |
sam_grove | 0:9d1e3a344e4f | 194 | */ |
sam_grove | 0:9d1e3a344e4f | 195 | void writeRegister(uint8_t const reg, uint8_t const data) const; |
sam_grove | 0:9d1e3a344e4f | 196 | |
sam_grove | 0:9d1e3a344e4f | 197 | /** Read from a register (exposed for debugging reasons) |
sam_grove | 0:9d1e3a344e4f | 198 | * @param reg - The register to read from |
sam_grove | 0:9d1e3a344e4f | 199 | * @return The register contents |
sam_grove | 0:9d1e3a344e4f | 200 | */ |
sam_grove | 0:9d1e3a344e4f | 201 | uint8_t readRegister(uint8_t const reg) const; |
sam_grove | 0:9d1e3a344e4f | 202 | |
sam_grove | 0:9d1e3a344e4f | 203 | /** print the register map and values to the console |
sam_grove | 0:9d1e3a344e4f | 204 | */ |
sam_grove | 0:9d1e3a344e4f | 205 | void registerDump(void) const; |
sam_grove | 0:9d1e3a344e4f | 206 | |
sam_grove | 0:9d1e3a344e4f | 207 | private: |
sam_grove | 0:9d1e3a344e4f | 208 | |
sam_grove | 0:9d1e3a344e4f | 209 | I2C *_i2c; |
sam_grove | 0:9d1e3a344e4f | 210 | InterruptIn *_int1; |
sam_grove | 0:9d1e3a344e4f | 211 | InterruptIn *_int2; |
sam_grove | 0:9d1e3a344e4f | 212 | uint8_t _i2c_addr; |
sam_grove | 0:9d1e3a344e4f | 213 | MMA845x_DATA _data; |
sam_grove | 0:9d1e3a344e4f | 214 | |
sam_grove | 0:9d1e3a344e4f | 215 | void init(void) const; |
sam_grove | 0:9d1e3a344e4f | 216 | }; |
sam_grove | 0:9d1e3a344e4f | 217 | |
sam_grove | 0:9d1e3a344e4f | 218 | #endif |