summaryrefslogtreecommitdiff
path: root/libsensors_iio/src/SWMagnetometerUncalibrated.cpp
blob: ab4baaf23bec8ad5add706f76018ae48c469d3c6 (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
/*
 * STMicroelectronics Magnetometer Uncalibrated 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 "SWMagnetometerUncalibrated.h"

SWMagnetometerUncalibrated::SWMagnetometerUncalibrated(const char *name, int handle, int pipe_data_fd) :
		SWSensorBaseWithPollrate(name, handle, SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED,
			pipe_data_fd, true, true, true, true)
{
	sensor_t_data.stringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
	sensor_t_data.flags = SENSOR_FLAG_CONTINUOUS_MODE;

	type_dependencies[SENSOR_BASE_DEPENDENCY_0] = SENSOR_TYPE_MAGNETIC_FIELD;
	type_sensor_need_trigger = SENSOR_TYPE_MAGNETIC_FIELD;
}

SWMagnetometerUncalibrated::~SWMagnetometerUncalibrated()
{

}

void SWMagnetometerUncalibrated::TriggerEventReceived()
{
	int data_remaining;
	SensorBaseData magn_data;

	do {
		data_remaining = GetLatestValidDataFromDependency(SENSOR_BASE_DEPENDENCY_0, &magn_data);
		if (data_remaining < 0)
			return;

		memcpy(sensor_event.uncalibrated_magnetic.uncalib, magn_data.raw, num_data_axis * sizeof(float));
		memcpy(sensor_event.uncalibrated_magnetic.bias, magn_data.offset, num_data_axis * sizeof(float));
		sensor_event.timestamp = magn_data.timestamp;

		SWSensorBaseWithPollrate::WriteDataToPipe();
		SWSensorBaseWithPollrate::ProcessData(&magn_data);
	} while (data_remaining > 0);
}