summaryrefslogtreecommitdiff
path: root/peripheral/sensors/mraa/sensors/LSM9DS0Accelerometer.cpp
blob: 2c7985025cfe0e8c5b3c2d2f2e4f63995fab3863 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*
 * Copyright (C) 2015 Intel Corporation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or impliedt data output.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include <cutils/log.h>
#include "LSM9DS0Accelerometer.hpp"
#include "SensorsHAL.hpp"
#include "SensorUtils.hpp"

struct sensor_t LSM9DS0Accelerometer::sensorDescription = {
  .name = "LSM9DS0 Accelerometer",
  .vendor = "Unknown",
  .version = 1,
  .handle = -1,
  .type = SENSOR_TYPE_ACCELEROMETER,
  .maxRange = 16.0f,
  .resolution = 0.061,
  .power = 0.000350,
  .minDelay = 0,
  .fifoReservedEventCount = 0,
  .fifoMaxEventCount = 0,
  .stringType = SENSOR_STRING_TYPE_ACCELEROMETER,
  .requiredPermission = "",
  .maxDelay = 1000,
  .flags = SENSOR_FLAG_CONTINUOUS_MODE,
  .reserved = {},
};

Sensor * LSM9DS0Accelerometer::createSensor(int pollFd) {
  return new LSM9DS0Accelerometer(pollFd,
      SensorUtils::getI2cBusNumber(),
      LSM9DS0_DEFAULT_GYRO_ADDR, LSM9DS0_DEFAULT_XM_ADDR);

}

void LSM9DS0Accelerometer::initModule() {
  SensorContext::addSensorModule(&sensorDescription, createSensor);
}

LSM9DS0Accelerometer::LSM9DS0Accelerometer(int pollFd,
    int bus, uint8_t gAddress, uint8_t xmAddress)
    : LSM9DS0 (bus, gAddress, xmAddress), pollFd(pollFd) {
  handle = sensorDescription.handle;
  type = SENSOR_TYPE_ACCELEROMETER;
}

LSM9DS0Accelerometer::~LSM9DS0Accelerometer() {}

int LSM9DS0Accelerometer::pollEvents(sensors_event_t* data, int count) {
  updateAccelerometer();
  getAccelerometer(&data->acceleration.x, &data->acceleration.y, &data->acceleration.z);
  data->acceleration.x *= Sensor::kGravitationalAcceleration;
  data->acceleration.y *= Sensor::kGravitationalAcceleration;
  data->acceleration.z *= Sensor::kGravitationalAcceleration;
  return 1;
}

// LSM9DS0 accelerometer sensor implementation
int LSM9DS0Accelerometer::activate(int handle, int enabled) {
  init();

  /* start or stop the acquisition thread */
  return activateAcquisitionThread(pollFd, handle, enabled);
}