2 * Copyright (C) 2014 Intel Corporation.
7 #include <cutils/properties.h>
8 #include <hardware/sensors.h>
9 #include "enumeration.h"
11 #define IIO_SENSOR_HAL_VERSION 1
14 static int sensor_get_st_prop (int s, const char* sel, char val[MAX_NAME_SIZE])
16 char prop_name[PROP_NAME_MAX];
17 char prop_val[PROP_VALUE_MAX];
18 int i = sensor_info[s].catalog_index;
19 const char *prefix = sensor_catalog[i].tag;
21 sprintf(prop_name, PROP_BASE, prefix, sel);
23 if (property_get(prop_name, prop_val, "")) {
24 strncpy(val, prop_val, MAX_NAME_SIZE-1);
25 val[MAX_NAME_SIZE-1] = '\0';
33 int sensor_get_fl_prop (int s, const char* sel, float* val)
35 char buf[MAX_NAME_SIZE];
37 if (sensor_get_st_prop(s, sel, buf))
40 *val = (float) strtod(buf, NULL);
45 char* sensor_get_name (int s)
47 if (sensor_info[s].friendly_name[0] != '\0' ||
48 !sensor_get_st_prop(s, "name", sensor_info[s].friendly_name))
49 return sensor_info[s].friendly_name;
51 /* If we got a iio device name from sysfs, use it */
52 if (sensor_info[s].internal_name[0]) {
53 snprintf(sensor_info[s].friendly_name, MAX_NAME_SIZE, "S%d-%s",
54 s, sensor_info[s].internal_name);
56 sprintf(sensor_info[s].friendly_name, "S%d", s);
59 return sensor_info[s].friendly_name;
63 char* sensor_get_vendor (int s)
65 if (sensor_info[s].vendor_name[0] ||
66 !sensor_get_st_prop(s, "vendor", sensor_info[s].vendor_name))
67 return sensor_info[s].vendor_name;
73 int sensor_get_version (int s)
75 return IIO_SENSOR_HAL_VERSION;
79 float sensor_get_max_range (int s)
84 if (sensor_info[s].max_range != 0.0 ||
85 !sensor_get_fl_prop(s, "max_range", &sensor_info[s].max_range))
86 return sensor_info[s].max_range;
88 /* Try returning a sensible value given the sensor type */
90 /* We should cap returned samples accordingly... */
92 catalog_index = sensor_info[s].catalog_index;
93 sensor_type = sensor_catalog[catalog_index].type;
95 switch (sensor_type) {
96 case SENSOR_TYPE_ACCELEROMETER: /* m/s^2 */
99 case SENSOR_TYPE_MAGNETIC_FIELD: /* micro-tesla */
102 case SENSOR_TYPE_ORIENTATION: /* degrees */
105 case SENSOR_TYPE_GYROSCOPE: /* radians/s */
108 case SENSOR_TYPE_LIGHT: /* SI lux units */
111 case SENSOR_TYPE_AMBIENT_TEMPERATURE: /* °C */
112 case SENSOR_TYPE_TEMPERATURE: /* °C */
113 case SENSOR_TYPE_PROXIMITY: /* centimeters */
114 case SENSOR_TYPE_PRESSURE: /* hecto-pascal */
115 case SENSOR_TYPE_RELATIVE_HUMIDITY: /* percent */
124 float sensor_get_resolution (int s)
126 if (sensor_info[s].resolution != 0.0 ||
127 !sensor_get_fl_prop(s, "resolution", &sensor_info[s].resolution))
128 return sensor_info[s].resolution;
134 float sensor_get_power (int s)
136 /* mA used while sensor is in use ; not sure about volts :) */
137 if (sensor_info[s].power != 0.0 ||
138 !sensor_get_fl_prop(s, "power", &sensor_info[s].power))
139 return sensor_info[s].power;
145 float sensor_get_illumincalib (int s)
147 /* calibrating the ALS Sensor*/
148 if (sensor_info[s].illumincalib != 0.0 ||
149 !sensor_get_fl_prop(s, "illumincalib", &sensor_info[s].illumincalib)) {
150 return sensor_info[s].illumincalib;
157 int sensor_get_order (int s, unsigned char map[MAX_CHANNELS])
159 char buf[MAX_NAME_SIZE];
161 int count = sensor_catalog[sensor_info[s].catalog_index].num_channels;
163 memset(map, 0, MAX_CHANNELS);
165 if (sensor_get_st_prop(s, "order", buf))
166 return 0; /* No order property */
168 /* Assume ASCII characters, in the '0'..'9' range */
170 for (i=0; i<count; i++)
171 map[i] = buf[i] - '0';
173 /* Check that our indices are in range */
174 for (i=0; i<count; i++)
175 if (map[i] >= count) {
176 ALOGE("Order index out of range for sensor %d\n", s);
180 return 1; /* OK to use modified ordering map */