123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- /* Copyright (c) 2013-2015, The Linux Foundation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 and
- * only version 2 as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
- #ifndef __LINUX_SENSORS_H_INCLUDED
- #define __LINUX_SENSORS_H_INCLUDED
- #include <linux/list.h>
- #include <linux/spinlock.h>
- #include <linux/rwsem.h>
- #define SENSORS_ACCELERATION_HANDLE 0
- #define SENSORS_MAGNETIC_FIELD_HANDLE 1
- #define SENSORS_ORIENTATION_HANDLE 2
- #define SENSORS_LIGHT_HANDLE 3
- #define SENSORS_PROXIMITY_HANDLE 4
- #define SENSORS_GYROSCOPE_HANDLE 5
- #define SENSORS_PRESSURE_HANDLE 6
- #define SENSOR_TYPE_ACCELEROMETER 1
- #define SENSOR_TYPE_GEOMAGNETIC_FIELD 2
- #define SENSOR_TYPE_MAGNETIC_FIELD SENSOR_TYPE_GEOMAGNETIC_FIELD
- #define SENSOR_TYPE_ORIENTATION 3
- #define SENSOR_TYPE_GYROSCOPE 4
- #define SENSOR_TYPE_LIGHT 5
- #define SENSOR_TYPE_PRESSURE 6
- #define SENSOR_TYPE_TEMPERATURE 7
- #define SENSOR_TYPE_PROXIMITY 8
- #define SENSOR_TYPE_GRAVITY 9
- #define SENSOR_TYPE_LINEAR_ACCELERATION 10
- #define SENSOR_TYPE_ROTATION_VECTOR 11
- #define SENSOR_TYPE_RELATIVE_HUMIDITY 12
- #define SENSOR_TYPE_AMBIENT_TEMPERATURE 13
- #define SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED 14
- #define SENSOR_TYPE_GAME_ROTATION_VECTOR 15
- #define SENSOR_TYPE_GYROSCOPE_UNCALIBRATED 16
- #define SENSOR_TYPE_SIGNIFICANT_MOTION 17
- #define SENSOR_TYPE_STEP_DETECTOR 18
- #define SENSOR_TYPE_STEP_COUNTER 19
- #define SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR 20
- enum LIS3DH_AXIS {
- AXIS_X = 0,
- AXIS_Y,
- AXIS_Z,
- AXIS_XYZ,
- };
- enum LIS3DH_THRES {
- AXIS_THRESHOLD_H = 0,
- AXIS_THRESHOLD_L,
- AXIS_BIAS,
- };
- #define AXIS_FACTOR 0
- #define AXIS_OFFSET 1
- struct cal_result_t {
- union {
- struct {
- int offset_x; /*axis offset of x axis*/
- int offset_y; /*axis offset of x axis*/
- int offset_z; /*axis offset of x axis*/
- };
- struct {
- int threshold_h; /*proximity threshold_h*/
- int threshold_l; /*proximity threshold_l*/
- int bias; /*proximity measure data noise*/
- };
- int offset[3];
- };
- int factor; /*light sensor factor for real ligt strength*/
- int range;
- struct cal_result_t *node;
- };
- /**
- * struct sensors_classdev - hold the sensor general parameters and APIs
- * @dev: The device to register.
- * @node: The list for the all the sensor drivers.
- * @name: Name of this sensor.
- * @vendor: The vendor of the hardware part.
- * @handle: The handle that identifies this sensors.
- * @type: The sensor type.
- * @max_range: The maximum range of this sensor's value in SI units.
- * @resolution: The smallest difference between two values reported by
- * this sensor.
- * @sensor_power: The rough estimate of this sensor's power consumption
- * in mA.
- * @min_delay: This value depends on the trigger mode:
- * continuous: minimum period allowed in microseconds
- * on-change : 0
- * one-shot :-1
- * special : 0, unless otherwise noted
- * @fifo_reserved_event_count: The number of events reserved for this sensor
- * in the batch mode FIFO.
- * @fifo_max_event_count: The maximum number of events of this sensor
- * that could be batched.
- * @max_delay: The slowest rate the sensor supports in millisecond.
- * @flags: Should be '1' if the sensor is a wake up sensor.
- * set it to '0' otherwise.
- * @enabled: Store the sensor driver enable status.
- * @delay_msec: Store the sensor driver delay value. The data unit is
- * millisecond.
- * @wakeup: Indicate if the wake up interrupt has been enabled.
- * @max_latency: Max report latency in millisecond
- * @sensors_enable: The handle for enable and disable sensor.
- * @sensors_poll_delay: The handle for set the sensor polling delay time.
- * @sensors_set_latency:Set the max report latency of the sensor.
- * @sensors_flush: Flush sensor events in FIFO and report it to user space.
- * @params The sensor calibrate string format params up to userspace.
- * @cal_result The sensor calibrate parameters, cal_result is a struct for sensor.
- */
- struct sensors_classdev {
- struct device *dev;
- struct list_head node;
- const char *name;
- const char *vendor;
- int version;
- int handle;
- int type;
- const char *max_range;
- const char *resolution;
- const char *sensor_power;
- int min_delay;
- int fifo_reserved_event_count;
- int fifo_max_event_count;
- int32_t max_delay;
- uint32_t flags;
- unsigned int enabled;
- unsigned int delay_msec;
- unsigned int wakeup;
- unsigned int max_latency;
- char *params;
- struct cal_result_t cal_result;
- /* enable and disable the sensor handle*/
- int (*sensors_enable)(struct sensors_classdev *sensors_cdev,
- unsigned int enabled);
- int (*sensors_poll_delay)(struct sensors_classdev *sensors_cdev,
- unsigned int delay_msec);
- int (*sensors_self_test)(struct sensors_classdev *sensors_cdev);
- int (*sensors_set_latency)(struct sensors_classdev *sensor_cdev,
- unsigned int max_latency);
- int (*sensors_enable_wakeup)(struct sensors_classdev *sensor_cdev,
- unsigned int enable);
- int (*sensors_flush)(struct sensors_classdev *sensors_cdev);
- int (*sensors_calibrate)(struct sensors_classdev *sensor_cdev,
- int axis, int apply_now);
- int (*sensors_write_cal_params)(struct sensors_classdev
- *sensor_cdev, struct cal_result_t *cal_result);
- };
- extern int sensors_classdev_register(struct device *parent,
- struct sensors_classdev *sensors_cdev);
- extern void sensors_classdev_unregister(struct sensors_classdev *sensors_cdev);
- #endif /* __LINUX_SENSORS_H_INCLUDED */
|