diff options
author | Mario Tesi <mario.tesi@st.com> | 2016-11-18 09:48:42 +0100 |
---|---|---|
committer | chrome-bot <chrome-bot@chromium.org> | 2017-02-09 03:10:22 -0800 |
commit | 8db50ce410cd71a6b4429fb91a3be9e103312f8f (patch) | |
tree | def49c0684d3d0b1e10491ed475afb9ebbc1eb22 /driver/accel_lis2dh.h | |
parent | b6c5e8e7a2edee6f167fe1282db6e1263fa6988e (diff) | |
download | chrome-ec-8db50ce410cd71a6b4429fb91a3be9e103312f8f.tar.gz |
driver: accel: Add acc driver basics and FIFO for LIS2DH/LIS2DH12
Add driver for acc sensor ST lis2dh/lis2dh12
Support interrupt management for FIFO watermark
Starting to share common code with other devices
like lsm6dsm/lsm6dsl (acc/gyro) or new lis2mdl (mag)
TODO: Add all embedded functions support (click,
tap and so on)
BUG=none
BRANCH=master
TEST=Tested on discovery BOARD with sensor connected on
EC i2c master bus. Added motion sense task on discovery
board task list, added gpio info in board configuration
file and tested with motion sense console commands. Data
for acc seems ok: can successfully change ODR and
full scale range. Also FIFO and interrupt tested
Device tested is lis2dh (lis2dh12 simply differs for low
pin count but share the same registers)
Change-Id: I16abeac3f139a604094b38d8d8b857a62c93a242
Signed-off-by: Mario Tesi <mario.tesi@st.com>
Reviewed-on: https://chromium-review.googlesource.com/412700
Commit-Ready: mario tesi <mario.tesi@st.com>
Tested-by: mario tesi <mario.tesi@st.com>
Reviewed-by: Gwendal Grignou <gwendal@chromium.org>
Diffstat (limited to 'driver/accel_lis2dh.h')
-rw-r--r-- | driver/accel_lis2dh.h | 161 |
1 files changed, 161 insertions, 0 deletions
diff --git a/driver/accel_lis2dh.h b/driver/accel_lis2dh.h new file mode 100644 index 0000000000..eac16d5e20 --- /dev/null +++ b/driver/accel_lis2dh.h @@ -0,0 +1,161 @@ +/* Copyright (c) 2016 The Chromium OS Authors. All rights reserved. + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + +/* LIS2DH accelerometer module for Chrome EC */ + +#ifndef __CROS_EC_ACCEL_LIS2DH_H +#define __CROS_EC_ACCEL_LIS2DH_H + +#define LIS2DH_I2C_ADDR(__x) (__x << 1) + +/* 7-bit address is 000110Xb. Where 'X' is determined + * by the voltage on the ADDR pin + */ +#define LIS2DH_ADDR0 LIS2DH_I2C_ADDR(0x18) +#define LIS2DH_ADDR1 LIS2DH_I2C_ADDR(0x19) + +/* Who Am I */ +#define LIS2DH_WHO_AM_I_REG 0x0f +#define LIS2DH_WHO_AM_I 0x33 + +/* COMMON DEFINE FOR ACCEL SENSOR */ +#define LIS2DH_EN_BIT 0x01 +#define LIS2DH_DIS_BIT 0x00 + +#define LIS2DH_INT2_ON_INT1_ADDR 0x13 +#define LIS2DH_INT2_ON_INT1_MASK 0x20 + +#define LIS2DH_OUT_X_L_ADDR 0x28 + +#define LIS2DH_CTRL1_ADDR 0x20 +#define LIS2DH_INT2_ON_INT1_MASK 0x20 +#define LIS2DH_ENABLE_ALL_AXES 0x07 + +#define LIS2DH_CTRL2_ADDR 0x21 +#define LIS2DH_CTRL2_RESET_VAL 0x00 + +#define LIS2DH_CTRL3_ADDR 0x22 +#define LIS2DH_CTRL3_RESET_VAL 0x00 + +#define LIS2DH_CTRL4_ADDR 0x23 +#define LIS2DH_BDU_MASK 0x80 + +#define LIS2DH_CTRL5_ADDR 0x24 +#define LIS2DH_CTRL5_RESET_VAL 0x00 + +#define LIS2DH_CTRL6_ADDR 0x25 +#define LIS2DH_CTRL6_RESET_VAL 0x00 + +#define LIS2DH_STATUS_REG 0x27 +#define LIS2DH_STS_XLDA_UP 0x80 + +#ifdef CONFIG_ACCEL_FIFO + +/* FIFO regs, masks and define */ +#define LIS2DH_FIFO_WTM_INT_MASK 0x04 +#define LIS2DH_FIFO_CTRL_REG 0x2e +#define LIS2DH_FIFO_MODE_MASK 0xc0 +#define LIS2DH_FIFO_THR_MASK 0x1f + +/* Select FIFO supported mode: + * BYPASS - Bypass FIFO + * FIFO - FIFO mode collect data + * STREAM - FIFO older data is replaced by new data + * SFIFO - Stream-to-FIFO mode. Mix FIFO & STREAM + */ +enum lis2dh_fifo_modes { + LIS2DH_FIFO_BYPASS_MODE = 0x00, + LIS2DH_FIFO_MODE, + LIS2DH_FIFO_STREAM_MODE, + LIS2DH_FIFO_SFIFO_MODE +}; + +/* Defines for LIS2DH_CTRL5_ADDR FIFO register */ +#define LIS2DH_FIFO_EN_MASK 0x40 + +#define LIS2DH_FIFO_SRC_REG 0x2f +#define LIS2DH_FIFO_EMPTY_FLAG 0x20 +#define LIS2DH_FIFO_UNREAD_MASK 0x1f +#endif /* CONFIG_ACCEL_FIFO */ + +/* Interrupt source status register */ +#define LIS2DH_INT1_SRC_REG 0x31 + +/* Output data rate Mask register */ +#define LIS2DH_ACC_ODR_MASK 0xf0 + +/* Acc data rate */ +enum lis2dh_odr { + LIS2DH_ODR_1HZ_VAL = 0x01, + LIS2DH_ODR_10HZ_VAL, + LIS2DH_ODR_25HZ_VAL, + LIS2DH_ODR_50HZ_VAL, + LIS2DH_ODR_100HZ_VAL, + LIS2DH_ODR_200HZ_VAL, + LIS2DH_ODR_400HZ_VAL, + LIS2DH_ODR_LIST_NUM +}; + +/* Return ODR reg value based on data rate set */ +#define LIS2DH_ODR_TO_REG(_odr) \ + (_odr <= 1000) ? LIS2DH_ODR_1HZ_VAL : \ + (_odr <= 10000) ? LIS2DH_ODR_10HZ_VAL : \ + ((31 - __builtin_clz(_odr / 25000))) + 3 + +/* Return ODR real value normalized to sensor capabilities */ +#define LIS2DH_ODR_TO_NORMALIZE(_odr) \ + (_odr <= 1000) ? 1000 : (_odr <= 10000) ? 10000 : \ + (25000 * (1 << (31 - __builtin_clz(_odr / 25000)))) + +/* Return ODR real value normalized to sensor capabilities from reg value */ +#define LIS2DH_REG_TO_NORMALIZE(_reg) \ + (_reg == LIS2DH_ODR_1HZ_VAL) ? 1000 : \ + (_reg == LIS2DH_ODR_10HZ_VAL) ? 10000 : (25000 * (1 << (_reg - 3))) + +/* Full scale range Mask register */ +#define LIS2DH_FS_MASK 0x30 + +/* Acc FS value */ +enum lis2dh_fs { + LIS2DH_FS_2G_VAL = 0x00, + LIS2DH_FS_4G_VAL, + LIS2DH_FS_8G_VAL, + LIS2DH_FS_16G_VAL, + LIS2DH_FS_LIST_NUM +}; + +/* FS reg value from Full Scale */ +#define LIS2DH_FS_TO_REG(_fs) \ + (31 - __builtin_clz(_fs) - 1) + +/* Full Scale range real value normalized to sensor capabilities */ +#define LIS2DH_FS_TO_NORMALIZE(_fs) \ + (1 << (31 - __builtin_clz(_fs))) + +/* Acc Gain value */ +#define LIS2DH_FS_2G_GAIN 4 +#define LIS2DH_FS_4G_GAIN 8 +#define LIS2DH_FS_8G_GAIN 16 +#define LIS2DH_FS_16G_GAIN 48 + +/* Return Gain from Full Scale range + * TODO: This work only for 2, 4 and 8 G full scale */ +#define LIS2DH_FS_TO_GAIN(_fs) \ + (LIS2DH_FS_2G_GAIN << (30 - __builtin_clz(_fs))) + +/* Return Full Scale Range from normalized gain */ +#define LIS2DH_GAIN_TO_FS(_gain) \ + (1 << (30 - __builtin_clz(_gain))) + +/* Sensor resolution in number of bits + * This sensor has variable precision (8/10/12 bits) depending Power Mode + * selected + * TODO: Only Normal Power mode supported (10 bits) + */ +#define LIS2DH_RESOLUTION 10 + +extern const struct accelgyro_drv lis2dh_drv; + +#endif /* __CROS_EC_ACCEL_LIS2DH_H */ |