diff options
author | Baixing Tan <baixingx.tan@intel.com> | 2015-03-25 11:16:57 +0800 |
---|---|---|
committer | Zhengyin Qian <qianzy@google.com> | 2015-07-28 12:19:18 -0700 |
commit | 049ab1da89d389f05870f7e30d585ecfc14524dd (patch) | |
tree | 37bd50571b00976df97cc10e64e6be66c1e5c422 /libsensors_iio/src/Accelerometer.cpp | |
parent | 0d5f99879a2ed5026cee26374d18d0e878ed0e13 (diff) | |
download | sensors-049ab1da89d389f05870f7e30d585ecfc14524dd.tar.gz |
Original code get from ST for lsm6ds3 sensor base on iio subsystem
Add original SensorHAL_IIO_v3.1.0 for lsm6ds3 sensor
Change-Id: Iebd049a36696f9b1f09049cc8672ed260c12cdf7
Tracked-On: https://jira01.devtools.intel.com/browse/MARVIN-175
Signed-off-by: Baixing Tan <baixingx.tan@intel.com>
Reviewed-on: https://android.intel.com:443/346267
Diffstat (limited to 'libsensors_iio/src/Accelerometer.cpp')
-rw-r--r-- | libsensors_iio/src/Accelerometer.cpp | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/libsensors_iio/src/Accelerometer.cpp b/libsensors_iio/src/Accelerometer.cpp new file mode 100644 index 0000000..98ed7c6 --- /dev/null +++ b/libsensors_iio/src/Accelerometer.cpp @@ -0,0 +1,55 @@ +/* + * STMicroelectronics Accelerometer Sensor Class + * + * Copyright 2013-2015 STMicroelectronics Inc. + * Author: Denis Ciocca - <denis.ciocca@st.com> + * + * Licensed under the Apache License, Version 2.0 (the "License"). + */ + +#include <fcntl.h> +#include <assert.h> +#include <signal.h> + +#include "Accelerometer.h" + +Accelerometer::Accelerometer(HWSensorBaseCommonData *data, const char *name, + struct iio_sampling_frequency_available *sfa, int handle, + unsigned int hw_fifo_len, int pipe_data_fd, float power_consumption, bool wakeup) : + HWSensorBaseWithPollrate(data, name, sfa, handle, + SENSOR_TYPE_ACCELEROMETER, hw_fifo_len, pipe_data_fd, power_consumption) +{ + sensor_t_data.stringType = SENSOR_STRING_TYPE_ACCELEROMETER; + sensor_t_data.flags = SENSOR_FLAG_CONTINUOUS_MODE; + + if (wakeup) + sensor_t_data.flags |= SENSOR_FLAG_WAKE_UP; + + sensor_t_data.resolution = data->channels[0].scale; + sensor_t_data.maxRange = sensor_t_data.resolution * (pow(2, data->channels[0].bits_used - 1) - 1); +} + +Accelerometer::~Accelerometer() +{ + +} + +void Accelerometer::ProcessData(SensorBaseData *data) +{ + float tmp_raw_data[num_data_axis]; + + memcpy(tmp_raw_data, data->raw, num_data_axis * sizeof(float)); + + data->raw[0] = SENSOR_X_DATA(tmp_raw_data[0], tmp_raw_data[1], tmp_raw_data[2], CONFIG_ST_HAL_ACCEL_ROT_MATRIX); + data->raw[1] = SENSOR_Y_DATA(tmp_raw_data[0], tmp_raw_data[1], tmp_raw_data[2], CONFIG_ST_HAL_ACCEL_ROT_MATRIX); + data->raw[2] = SENSOR_Z_DATA(tmp_raw_data[0], tmp_raw_data[1], tmp_raw_data[2], CONFIG_ST_HAL_ACCEL_ROT_MATRIX); + + sensor_event.acceleration.x = data->raw[0]; + sensor_event.acceleration.y = data->raw[1]; + sensor_event.acceleration.z = data->raw[2]; + sensor_event.acceleration.status = SENSOR_STATUS_UNRELIABLE; + sensor_event.timestamp = data->timestamp; + + HWSensorBaseWithPollrate::WriteDataToPipe(); + HWSensorBaseWithPollrate::ProcessData(data); +} |