Driver library for the Freescale FXOS8700Q sensor

Dependencies:   MotionSensor

Dependents:   el14dg_Project frdm_serial_peopleAndComputing simple-client-app-shield pelion-example-frdm ... more

Fork of FXOS8700Q by Freescale

Committer:
sam_grove
Date:
Thu Jun 18 22:53:07 2015 +0000
Revision:
10:834488c11340
Parent:
9:5553a64d0762
Child:
11:aee7dea904e2
Update driver based on changes to MotionSensor

Who changed what in which revision?

UserRevisionLine numberNew contents of line
sam_grove 10:834488c11340 1 /* FXOS8700Q sensor driver
sam_grove 10:834488c11340 2 * Copyright (c) 2014-2015 ARM Limited
sam_grove 10:834488c11340 3 *
sam_grove 10:834488c11340 4 * Licensed under the Apache License, Version 2.0 (the "License");
sam_grove 10:834488c11340 5 * you may not use this file except in compliance with the License.
sam_grove 10:834488c11340 6 * You may obtain a copy of the License at
sam_grove 10:834488c11340 7 *
sam_grove 10:834488c11340 8 * http://www.apache.org/licenses/LICENSE-2.0
sam_grove 10:834488c11340 9 *
sam_grove 10:834488c11340 10 * Unless required by applicable law or agreed to in writing, software
sam_grove 10:834488c11340 11 * distributed under the License is distributed on an "AS IS" BASIS,
sam_grove 10:834488c11340 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
sam_grove 10:834488c11340 13 * See the License for the specific language governing permissions and
sam_grove 10:834488c11340 14 * limitations under the License.
sam_grove 10:834488c11340 15 */
JimCarver 3:eb1271ef90bc 16
JimCarver 0:2562215f5bc0 17 #include "FXOS8700Q.h"
sam_grove 10:834488c11340 18
sam_grove 10:834488c11340 19 const uint16_t uint14_max = 0x3FFF;
sam_grove 10:834488c11340 20 void static inline normalize_14bits(int16_t &x)
sam_grove 10:834488c11340 21 {
sam_grove 10:834488c11340 22 x = ((x) > (uint14_max/2)) ? (x - uint14_max) : (x);
sam_grove 10:834488c11340 23 }
JimCarver 1:8b53edef272f 24
sam_grove 10:834488c11340 25 static int16_t dummy_int16_t = 0;
sam_grove 10:834488c11340 26 static float dummy_float = 0.0f;
JimCarver 1:8b53edef272f 27
sam_grove 10:834488c11340 28 FXOS8700Q::FXOS8700Q(I2C &i2c, uint8_t addr)
sam_grove 10:834488c11340 29 {
sam_grove 10:834488c11340 30 _i2c = &i2c;
sam_grove 10:834488c11340 31 _addr = addr;
JimCarver 1:8b53edef272f 32 // activate the peripheral
JimCarver 1:8b53edef272f 33 uint8_t data[2] = {FXOS8700Q_CTRL_REG1, 0x00};
sam_grove 10:834488c11340 34 _i2c->frequency(400000);
JimCarver 1:8b53edef272f 35 writeRegs(data, 2);
JimCarver 1:8b53edef272f 36 data[0] = FXOS8700Q_M_CTRL_REG1;
JimCarver 1:8b53edef272f 37 data[1] = 0x1F;
JimCarver 1:8b53edef272f 38 writeRegs(data, 2);
JimCarver 1:8b53edef272f 39 data[0] = FXOS8700Q_M_CTRL_REG2;
JimCarver 1:8b53edef272f 40 data[1] = 0x20;
JimCarver 1:8b53edef272f 41 writeRegs(data, 2);
JimCarver 1:8b53edef272f 42 data[0] = FXOS8700Q_XYZ_DATA_CFG;
JimCarver 1:8b53edef272f 43 data[1] = 0x00;
JimCarver 1:8b53edef272f 44 writeRegs(data, 2);
JimCarver 1:8b53edef272f 45 data[0] = FXOS8700Q_CTRL_REG1;
JimCarver 8:52116f8fb3da 46 data[1] = 0x1C;
JimCarver 6:cdc362f08339 47 writeRegs(data, 2);
sam_grove 10:834488c11340 48 }
sam_grove 10:834488c11340 49
sam_grove 10:834488c11340 50 FXOS8700Q::~FXOS8700Q()
sam_grove 10:834488c11340 51 {
sam_grove 10:834488c11340 52 _i2c = 0;
sam_grove 10:834488c11340 53 _addr = 0;
sam_grove 10:834488c11340 54 }
sam_grove 10:834488c11340 55
sam_grove 10:834488c11340 56 void FXOS8700Q::readRegs(int addr, uint8_t *data, uint32_t len) const
sam_grove 10:834488c11340 57 {
sam_grove 10:834488c11340 58 char t[1] = {addr};
sam_grove 10:834488c11340 59 _i2c->write(_addr, t, sizeof(t), true);
sam_grove 10:834488c11340 60 _i2c->read(_addr, (char *)data, len);
sam_grove 10:834488c11340 61 }
sam_grove 10:834488c11340 62
sam_grove 10:834488c11340 63 uint8_t FXOS8700Q::whoAmI() const
sam_grove 10:834488c11340 64 {
sam_grove 10:834488c11340 65 uint8_t who_am_i = 0;
sam_grove 10:834488c11340 66 readRegs(FXOS8700Q_WHOAMI, &who_am_i, sizeof(who_am_i));
sam_grove 10:834488c11340 67 return who_am_i;
JimCarver 6:cdc362f08339 68 }
JimCarver 6:cdc362f08339 69
sam_grove 10:834488c11340 70 void FXOS8700Q::writeRegs(uint8_t * data, uint32_t len) const
sam_grove 10:834488c11340 71 {
sam_grove 10:834488c11340 72 _i2c->write(_addr, (char *)data, len);
sam_grove 10:834488c11340 73 }
JimCarver 6:cdc362f08339 74
sam_grove 10:834488c11340 75 int16_t FXOS8700Q::getSensorAxis(uint8_t addr) const
sam_grove 10:834488c11340 76 {
sam_grove 10:834488c11340 77 uint8_t res[2];
sam_grove 10:834488c11340 78 readRegs(addr, res, sizeof(res));
sam_grove 10:834488c11340 79 return static_cast<int16_t>((res[0] << 8) | res[1]);
sam_grove 10:834488c11340 80 }
sam_grove 10:834488c11340 81
sam_grove 10:834488c11340 82 void FXOS8700Q::enable(void) const
sam_grove 10:834488c11340 83 {
JimCarver 6:cdc362f08339 84 uint8_t data[2];
sam_grove 10:834488c11340 85 readRegs(FXOS8700Q_CTRL_REG1, &data[1], 1);
JimCarver 6:cdc362f08339 86 data[1] |= 0x01;
JimCarver 6:cdc362f08339 87 data[0] = FXOS8700Q_CTRL_REG1;
sam_grove 10:834488c11340 88 writeRegs(data, sizeof(data));
JimCarver 6:cdc362f08339 89 }
JimCarver 6:cdc362f08339 90
sam_grove 10:834488c11340 91 void FXOS8700Q::disable(void) const
sam_grove 10:834488c11340 92 {
JimCarver 6:cdc362f08339 93 uint8_t data[2];
sam_grove 10:834488c11340 94 readRegs(FXOS8700Q_CTRL_REG1, &data[1], 1);
JimCarver 6:cdc362f08339 95 data[1] &= 0xFE;
JimCarver 6:cdc362f08339 96 data[0] = FXOS8700Q_CTRL_REG1;
sam_grove 10:834488c11340 97 writeRegs(data, sizeof(data));
JimCarver 1:8b53edef272f 98 }
JimCarver 0:2562215f5bc0 99
sam_grove 10:834488c11340 100 uint32_t FXOS8700Q::dataReady(void) const
sam_grove 10:834488c11340 101 {
sam_grove 10:834488c11340 102 uint8_t stat = 0;
sam_grove 10:834488c11340 103 readRegs(FXOS8700Q_STATUS, &stat, 1);
sam_grove 10:834488c11340 104 return (uint32_t)stat;
JimCarver 6:cdc362f08339 105 }
JimCarver 6:cdc362f08339 106
sam_grove 10:834488c11340 107 uint32_t FXOS8700Q::sampleRate(uint32_t frequency) const
sam_grove 10:834488c11340 108 {
JimCarver 6:cdc362f08339 109 return(50); // for now sample rate is fixed at 50Hz
JimCarver 1:8b53edef272f 110 }
JimCarver 1:8b53edef272f 111
sam_grove 10:834488c11340 112 int16_t FXOS8700QAccelerometer::getX(int16_t &x = dummy_int16_t) const
sam_grove 10:834488c11340 113 {
sam_grove 10:834488c11340 114 x = getSensorAxis(FXOS8700Q_OUT_X_MSB) >> 2;
sam_grove 10:834488c11340 115 normalize_14bits(x);
sam_grove 10:834488c11340 116 return x;
JimCarver 6:cdc362f08339 117 }
JimCarver 6:cdc362f08339 118
sam_grove 10:834488c11340 119 int16_t FXOS8700QAccelerometer::getY(int16_t &y = dummy_int16_t) const
sam_grove 10:834488c11340 120 {
sam_grove 10:834488c11340 121 y = getSensorAxis(FXOS8700Q_OUT_Y_MSB) >> 2;
sam_grove 10:834488c11340 122 normalize_14bits(y);
sam_grove 10:834488c11340 123 return y;
JimCarver 1:8b53edef272f 124 }
JimCarver 1:8b53edef272f 125
sam_grove 10:834488c11340 126 int16_t FXOS8700QAccelerometer::getZ(int16_t &z = dummy_int16_t) const
sam_grove 10:834488c11340 127 {
sam_grove 10:834488c11340 128 z = getSensorAxis(FXOS8700Q_OUT_Z_MSB) >> 2;
sam_grove 10:834488c11340 129 normalize_14bits(z);
sam_grove 10:834488c11340 130 return z;
JimCarver 0:2562215f5bc0 131 }
JimCarver 0:2562215f5bc0 132
sam_grove 10:834488c11340 133 float FXOS8700QAccelerometer::getX(float &x = dummy_float) const
sam_grove 10:834488c11340 134 {
sam_grove 10:834488c11340 135 int16_t val = getSensorAxis(FXOS8700Q_OUT_X_MSB) >> 2;
sam_grove 10:834488c11340 136 normalize_14bits(val);
sam_grove 10:834488c11340 137 x = val / 4096.0f;
sam_grove 10:834488c11340 138 return x;
JimCarver 0:2562215f5bc0 139 }
JimCarver 0:2562215f5bc0 140
sam_grove 10:834488c11340 141 float FXOS8700QAccelerometer::getY(float &y = dummy_float) const
sam_grove 10:834488c11340 142 {
sam_grove 10:834488c11340 143 int16_t val = getSensorAxis(FXOS8700Q_OUT_Y_MSB) >> 2;
sam_grove 10:834488c11340 144 normalize_14bits(val);
sam_grove 10:834488c11340 145 y = val / 4096.0f;
sam_grove 10:834488c11340 146 return y;
JimCarver 6:cdc362f08339 147 }
JimCarver 6:cdc362f08339 148
sam_grove 10:834488c11340 149 float FXOS8700QAccelerometer::getZ(float &z = dummy_float) const
sam_grove 10:834488c11340 150 {
sam_grove 10:834488c11340 151 int16_t val = getSensorAxis(FXOS8700Q_OUT_Z_MSB) >> 2;
sam_grove 10:834488c11340 152 normalize_14bits(val);
sam_grove 10:834488c11340 153 z = val / 4096.0f;
sam_grove 10:834488c11340 154 return z;
JimCarver 1:8b53edef272f 155 }
JimCarver 0:2562215f5bc0 156
sam_grove 10:834488c11340 157 void FXOS8700QAccelerometer::getAxis(motion_data_counts_t &xyz) const
sam_grove 10:834488c11340 158 {
sam_grove 10:834488c11340 159 uint8_t res[6];
sam_grove 10:834488c11340 160 readRegs(FXOS8700Q_OUT_X_MSB, res, sizeof(res));
sam_grove 10:834488c11340 161 xyz.x = static_cast<int16_t>((res[0] << 8) | res[1]) >> 2;
sam_grove 10:834488c11340 162 xyz.y = static_cast<int16_t>((res[2] << 8) | res[3]) >> 2;
sam_grove 10:834488c11340 163 xyz.z = static_cast<int16_t>((res[4] << 8) | res[5]) >> 2;
sam_grove 10:834488c11340 164 normalize_14bits(xyz.x);
sam_grove 10:834488c11340 165 normalize_14bits(xyz.y);
sam_grove 10:834488c11340 166 normalize_14bits(xyz.z);
JimCarver 6:cdc362f08339 167 }
JimCarver 6:cdc362f08339 168
sam_grove 10:834488c11340 169 void FXOS8700QAccelerometer::getAxis(motion_data_units_t &xyz) const
sam_grove 10:834488c11340 170 {
sam_grove 10:834488c11340 171 motion_data_counts_t _xyz;
sam_grove 10:834488c11340 172 FXOS8700QAccelerometer::getAxis(_xyz);
sam_grove 10:834488c11340 173 xyz.x = _xyz.x / 4096.0f;
sam_grove 10:834488c11340 174 xyz.y = _xyz.y / 4096.0f;
sam_grove 10:834488c11340 175 xyz.z = _xyz.z / 4096.0f;
JimCarver 6:cdc362f08339 176 }
JimCarver 6:cdc362f08339 177
sam_grove 10:834488c11340 178 int16_t FXOS8700QMagnetometer::getX(int16_t &x = dummy_int16_t) const
sam_grove 10:834488c11340 179 {
sam_grove 10:834488c11340 180 x = getSensorAxis(FXOS8700Q_M_OUT_X_MSB);
sam_grove 10:834488c11340 181 return x;
JimCarver 6:cdc362f08339 182 }
JimCarver 6:cdc362f08339 183
sam_grove 10:834488c11340 184 int16_t FXOS8700QMagnetometer::getY(int16_t &y = dummy_int16_t) const
sam_grove 10:834488c11340 185 {
sam_grove 10:834488c11340 186 y = getSensorAxis(FXOS8700Q_M_OUT_Y_MSB);
sam_grove 10:834488c11340 187 return y;
JimCarver 6:cdc362f08339 188 }
JimCarver 6:cdc362f08339 189
sam_grove 10:834488c11340 190 int16_t FXOS8700QMagnetometer::getZ(int16_t &z = dummy_int16_t) const
sam_grove 10:834488c11340 191 {
sam_grove 10:834488c11340 192 z = getSensorAxis(FXOS8700Q_M_OUT_Z_MSB);
sam_grove 10:834488c11340 193 return z;
JimCarver 6:cdc362f08339 194 }
JimCarver 6:cdc362f08339 195
sam_grove 10:834488c11340 196 float FXOS8700QMagnetometer::getX(float &x = dummy_float) const
sam_grove 10:834488c11340 197 {
sam_grove 10:834488c11340 198 x = static_cast<float>(getSensorAxis(FXOS8700Q_M_OUT_X_MSB)) * 0.1f;
sam_grove 10:834488c11340 199 return x;
JimCarver 6:cdc362f08339 200 }
JimCarver 6:cdc362f08339 201
sam_grove 10:834488c11340 202 float FXOS8700QMagnetometer::getY(float &y = dummy_float) const
sam_grove 10:834488c11340 203 {
sam_grove 10:834488c11340 204 y = static_cast<float>(getSensorAxis(FXOS8700Q_M_OUT_Y_MSB)) * 0.1f;
sam_grove 10:834488c11340 205 return y;
sam_grove 10:834488c11340 206 }
JimCarver 6:cdc362f08339 207
sam_grove 10:834488c11340 208 float FXOS8700QMagnetometer::getZ(float &z = dummy_float) const
sam_grove 10:834488c11340 209 {
sam_grove 10:834488c11340 210 z = static_cast<float>(getSensorAxis(FXOS8700Q_M_OUT_Z_MSB)) * 0.1f;
sam_grove 10:834488c11340 211 return z;
JimCarver 6:cdc362f08339 212 }
JimCarver 6:cdc362f08339 213
sam_grove 10:834488c11340 214 void FXOS8700QMagnetometer::getAxis(motion_data_counts_t &xyz) const
sam_grove 10:834488c11340 215 {
JimCarver 6:cdc362f08339 216 uint8_t res[6];
sam_grove 10:834488c11340 217 readRegs(FXOS8700Q_M_OUT_X_MSB, res, sizeof(res));
sam_grove 10:834488c11340 218 xyz.x = (res[0] << 8) | res[1];
sam_grove 10:834488c11340 219 xyz.y = (res[2] << 8) | res[3];
sam_grove 10:834488c11340 220 xyz.z = (res[4] << 8) | res[5];
JimCarver 6:cdc362f08339 221 }
JimCarver 6:cdc362f08339 222
sam_grove 10:834488c11340 223 void FXOS8700QMagnetometer::getAxis(motion_data_units_t &xyz) const
sam_grove 10:834488c11340 224 {
sam_grove 10:834488c11340 225 motion_data_counts_t _xyz;
sam_grove 10:834488c11340 226 FXOS8700QMagnetometer::getAxis(_xyz);
sam_grove 10:834488c11340 227 xyz.x = static_cast<float>(_xyz.x * 0.1f);
sam_grove 10:834488c11340 228 xyz.y = static_cast<float>(_xyz.y * 0.1f);
sam_grove 10:834488c11340 229 xyz.z = static_cast<float>(_xyz.z * 0.1f);
JimCarver 1:8b53edef272f 230 }