2015-11-18 16:17:20 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup driver_lsm303dlhc
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief LSM303DLHC adaption to the RIOT actuator/sensor interface
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "saul.h"
|
|
|
|
#include "lsm303dlhc.h"
|
|
|
|
|
2017-06-26 16:00:34 +02:00
|
|
|
static int read_acc(const void *dev, phydat_t *res)
|
2015-11-18 16:17:20 +01:00
|
|
|
{
|
2017-06-26 16:00:34 +02:00
|
|
|
const lsm303dlhc_t *d = (const lsm303dlhc_t *)dev;
|
2015-11-18 16:17:20 +01:00
|
|
|
lsm303dlhc_read_acc(d, (lsm303dlhc_3d_data_t *)res);
|
2016-02-04 11:50:54 +01:00
|
|
|
|
|
|
|
/* normalize result */
|
|
|
|
int fac = (1 << (d->acc_scale >> 4));
|
|
|
|
for (int i = 0; i < 3; i++) {
|
|
|
|
res->val[i] *= fac;
|
|
|
|
}
|
|
|
|
|
2015-11-18 16:17:20 +01:00
|
|
|
res->unit = UNIT_G;
|
2016-02-04 11:50:54 +01:00
|
|
|
res->scale = -3;
|
2015-11-18 16:17:20 +01:00
|
|
|
return 3;
|
|
|
|
}
|
|
|
|
|
2017-06-26 16:00:34 +02:00
|
|
|
static int read_mag(const void *dev, phydat_t *res)
|
2015-11-18 16:17:20 +01:00
|
|
|
{
|
2017-06-26 16:00:34 +02:00
|
|
|
const lsm303dlhc_t *d = (const lsm303dlhc_t *)dev;
|
|
|
|
|
2015-11-18 16:17:20 +01:00
|
|
|
lsm303dlhc_read_mag(d, (lsm303dlhc_3d_data_t *)res);
|
2016-02-04 11:50:54 +01:00
|
|
|
|
|
|
|
/* normalize results */
|
|
|
|
int gain;
|
|
|
|
switch (d->mag_gain) {
|
|
|
|
case LSM303DLHC_MAG_GAIN_1100_980_GAUSS: gain = 1100; break;
|
|
|
|
case LSM303DLHC_MAG_GAIN_855_760_GAUSS: gain = 855; break;
|
|
|
|
case LSM303DLHC_MAG_GAIN_670_600_GAUSS: gain = 670; break;
|
|
|
|
case LSM303DLHC_MAG_GAIN_450_400_GAUSS: gain = 450; break;
|
|
|
|
case LSM303DLHC_MAG_GAIN_400_355_GAUSS: gain = 400; break;
|
|
|
|
case LSM303DLHC_MAG_GAIN_330_295_GAUSS: gain = 330; break;
|
|
|
|
case LSM303DLHC_MAG_GAIN_230_205_GAUSS: gain = 230; break;
|
|
|
|
default: gain = 1000; break;
|
|
|
|
}
|
|
|
|
for (int i = 0; i < 3; i++) {
|
|
|
|
int32_t tmp = res->val[i] * 1000;
|
|
|
|
tmp /= gain;
|
|
|
|
res->val[i] = (int16_t)tmp;
|
|
|
|
}
|
|
|
|
|
2015-11-18 16:17:20 +01:00
|
|
|
res->unit = UNIT_GS;
|
2016-02-04 11:50:54 +01:00
|
|
|
res->scale = -3;
|
2015-11-18 16:17:20 +01:00
|
|
|
return 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
const saul_driver_t lsm303dlhc_saul_acc_driver = {
|
|
|
|
.read = read_acc,
|
2017-05-08 13:56:35 +02:00
|
|
|
.write = saul_notsup,
|
2015-11-18 16:17:20 +01:00
|
|
|
.type = SAUL_SENSE_ACCEL,
|
|
|
|
};
|
|
|
|
|
|
|
|
const saul_driver_t lsm303dlhc_saul_mag_driver = {
|
|
|
|
.read = read_mag,
|
2017-05-08 13:56:35 +02:00
|
|
|
.write = saul_notsup,
|
2015-11-18 16:17:20 +01:00
|
|
|
.type = SAUL_SENSE_MAG,
|
|
|
|
};
|