From af2d9a0801a3b6c2f91ae1feb2e2024e4393386d Mon Sep 17 00:00:00 2001 From: guoyi Date: Wed, 5 Mar 2014 15:32:13 +0800 Subject: [PATCH] porting sensor-dev to 3.10 --- arch/arm/boot/dts/rk3188-tb.dts | 9 + arch/arm/boot/dts/rk3188.dtsi | 1 + drivers/input/Kconfig | 1 + drivers/input/Makefile | 2 +- drivers/input/sensors/sensor-dev.c | 272 +++++++++++++++++++++++++---- drivers/input/sensors/sensor-i2c.c | 42 ++++- include/dt-bindings/sensor-dev.h | 17 ++ include/linux/sensor-dev.h | 68 ++++++-- 8 files changed, 359 insertions(+), 53 deletions(-) create mode 100755 include/dt-bindings/sensor-dev.h diff --git a/arch/arm/boot/dts/rk3188-tb.dts b/arch/arm/boot/dts/rk3188-tb.dts index 74c4d0a29b57..a9fe3696676a 100755 --- a/arch/arm/boot/dts/rk3188-tb.dts +++ b/arch/arm/boot/dts/rk3188-tb.dts @@ -157,6 +157,15 @@ pa_enable_time = <1000>; }; + sensor@1d { + compatible = "gs_mma8452"; + reg = <0x1d>; + type = ; + irq-gpio = <&gpio0 GPIO_B7 IRQ_TYPE_EDGE_FALLING>; + irq_enable = <1>; + poll_delay_ms = <30>; + layout = <1>; + }; }; &i2c1 { diff --git a/arch/arm/boot/dts/rk3188.dtsi b/arch/arm/boot/dts/rk3188.dtsi index 812fa29349ef..08aceec98230 100755 --- a/arch/arm/boot/dts/rk3188.dtsi +++ b/arch/arm/boot/dts/rk3188.dtsi @@ -4,6 +4,7 @@ #include #include "rk3188_io_vol_domain.dtsi" +#include / { compatible = "rockchip,rk3188"; diff --git a/drivers/input/Kconfig b/drivers/input/Kconfig index 9c13b63ef915..12eaec2e9a7e 100644 --- a/drivers/input/Kconfig +++ b/drivers/input/Kconfig @@ -197,6 +197,7 @@ source "drivers/input/touchscreen/Kconfig" source "drivers/input/misc/Kconfig" +source "drivers/input/sensors/Kconfig" endif menu "Hardware I/O ports" diff --git a/drivers/input/Makefile b/drivers/input/Makefile index 191ea43d0800..1b7621cae016 100644 --- a/drivers/input/Makefile +++ b/drivers/input/Makefile @@ -23,6 +23,6 @@ obj-$(CONFIG_INPUT_JOYSTICK) += joystick/ obj-$(CONFIG_INPUT_TABLET) += tablet/ obj-$(CONFIG_INPUT_TOUCHSCREEN) += touchscreen/ obj-$(CONFIG_INPUT_MISC) += misc/ - +obj-$(CONFIG_SENSOR_DEVICE) += sensors/ obj-$(CONFIG_INPUT_APMPOWER) += apm-power.o obj-$(CONFIG_INPUT_KEYRESET) += keyreset.o diff --git a/drivers/input/sensors/sensor-dev.c b/drivers/input/sensors/sensor-dev.c index 81852bde8377..37da5c5479dd 100755 --- a/drivers/input/sensors/sensor-dev.c +++ b/drivers/input/sensors/sensor-dev.c @@ -27,13 +27,16 @@ #include #include #include -#include -#include +#include +#include +#include #ifdef CONFIG_HAS_EARLYSUSPEND #include #endif #include #include +#include + /* @@ -327,22 +330,22 @@ static int sensor_irq_init(struct i2c_client *client) (struct sensor_private_data *) i2c_get_clientdata(client); int result = 0; int irq; - if((sensor->pdata->irq_enable)&&(sensor->ops->trig != SENSOR_UNKNOW_DATA)) + if((sensor->pdata->irq_enable)&&(sensor->pdata->irq_flags!= SENSOR_UNKNOW_DATA)) { //INIT_DELAYED_WORK(&sensor->delaywork, sensor_delaywork_func); if(sensor->pdata->poll_delay_ms < 0) sensor->pdata->poll_delay_ms = 30; - result = gpio_request(client->irq, sensor->i2c_id->name); if (result) { printk("%s:fail to request gpio :%d\n",__func__,client->irq); } - - gpio_pull_updown(client->irq, PullEnable); + + //gpio_pull_updown(client->irq, PullEnable); irq = gpio_to_irq(client->irq); //result = request_irq(irq, sensor_interrupt, sensor->ops->trig, sensor->ops->name, sensor); - result = request_threaded_irq(irq, NULL, sensor_interrupt, sensor->ops->trig, sensor->ops->name, sensor); + //result = request_threaded_irq(irq, NULL, sensor_interrupt, sensor->ops->trig, sensor->ops->name, sensor); + result = devm_request_threaded_irq(&client->dev, irq, NULL, sensor_interrupt, sensor->pdata->irq_flags | IRQF_ONESHOT, sensor->ops->name, sensor); if (result) { printk(KERN_ERR "%s:fail to request irq = %d, ret = 0x%x\n",__func__, irq, result); goto error; @@ -354,7 +357,7 @@ static int sensor_irq_init(struct i2c_client *client) disable_irq_nosync(client->irq);//disable irq if(((sensor->pdata->type == SENSOR_TYPE_TEMPERATURE) || (sensor->pdata->type == SENSOR_TYPE_PRESSURE))&& (!(sensor->ops->trig & IRQF_SHARED))) disable_irq_nosync(client->irq);//disable irq - printk("%s:use irq=%d\n",__func__,irq); + DBG("%s:use irq=%d\n",__func__,irq); } else if(!sensor->pdata->irq_enable) { @@ -362,7 +365,7 @@ static int sensor_irq_init(struct i2c_client *client) if(sensor->pdata->poll_delay_ms < 0) sensor->pdata->poll_delay_ms = 30; - printk("%s:use polling,delay=%d ms\n",__func__,sensor->pdata->poll_delay_ms); + DBG("%s:use polling,delay=%d ms\n",__func__,sensor->pdata->poll_delay_ms); } error: @@ -1647,6 +1650,9 @@ int sensor_probe(struct i2c_client *client, const struct i2c_device_id *devid) struct sensor_private_data *sensor = (struct sensor_private_data *) i2c_get_clientdata(client); struct sensor_platform_data *pdata; + struct device_node *np = client->dev.of_node; + enum of_gpio_flags rst_flags, pwr_flags; + unsigned long irq_flags; int result = 0; int type = 0; @@ -1656,54 +1662,212 @@ int sensor_probe(struct i2c_client *client, const struct i2c_device_id *devid) result = -ENODEV; goto out_no_free; } - - pdata = client->dev.platform_data; + if (!np) { + dev_err(&client->dev, "no device tree\n"); + return -EINVAL; + } + pdata = devm_kzalloc(&client->dev,sizeof(*pdata), GFP_KERNEL); if (!pdata) { - dev_err(&client->adapter->dev, - "Missing platform data for slave %s\n", devid->name); - result = -EFAULT; + result = -ENOMEM; goto out_no_free; } - - sensor = kzalloc(sizeof(*sensor), GFP_KERNEL); + sensor = devm_kzalloc(&client->dev,sizeof(*sensor), GFP_KERNEL); if (!sensor) { result = -ENOMEM; goto out_no_free; } + + of_property_read_u32(np,"type",&(pdata->type)); + + pdata->irq_pin = of_get_named_gpio_flags(np, "irq-gpio", 0,(enum of_gpio_flags *)&irq_flags); + pdata->reset_pin = of_get_named_gpio_flags(np, "reset-gpio",0,&rst_flags); + pdata->power_pin = of_get_named_gpio_flags(np, "power-gpio",0,&pwr_flags); + + of_property_read_u32(np,"irq_enable",&(pdata->irq_enable)); + of_property_read_u32(np,"poll_delay_ms",&(pdata->poll_delay_ms)); + + of_property_read_u32(np,"x_min",&(pdata->x_min)); + of_property_read_u32(np,"y_min",&(pdata->y_min)); + of_property_read_u32(np,"z_min",&(pdata->z_min)); + of_property_read_u32(np,"factory",&(pdata->factory)); + of_property_read_u32(np,"layout",&(pdata->layout)); + + of_property_read_u8(np,"address",&(pdata->address)); + pdata->project_name = of_get_property(np, "project_name", NULL); + + + switch(pdata->layout) + { + case 1: + pdata->orientation[0] = 1; + pdata->orientation[1] = 0; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 0; + pdata->orientation[4] = 1; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = 1; + break; + + case 2: + pdata->orientation[0] = 0; + pdata->orientation[1] = -1; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 1; + pdata->orientation[4] = 0; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = 1; + break; + + case 3: + pdata->orientation[0] = -1; + pdata->orientation[1] = 0; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 0; + pdata->orientation[4] = -1; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = 1; + break; + + case 4: + pdata->orientation[0] = 0; + pdata->orientation[1] = 1; + pdata->orientation[2] = 0; + + pdata->orientation[3] = -1; + pdata->orientation[4] = 0; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = 1; + break; + + case 5: + pdata->orientation[0] = 1; + pdata->orientation[1] = 0; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 0; + pdata->orientation[4] = -1; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = -1; + break; + + case 6: + pdata->orientation[0] = 0; + pdata->orientation[1] = -1; + pdata->orientation[2] = 0; + + pdata->orientation[3] = -1; + pdata->orientation[4] = 0; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = -1; + break; + + case 7: + pdata->orientation[0] = -1; + pdata->orientation[1] = 0; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 0; + pdata->orientation[4] = 1; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = -1; + break; + + case 8: + pdata->orientation[0] = 0; + pdata->orientation[1] = 1; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 1; + pdata->orientation[4] = 0; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = -1; + break; + + default: + pdata->orientation[0] = 1; + pdata->orientation[1] = 0; + pdata->orientation[2] = 0; + + pdata->orientation[3] = 0; + pdata->orientation[4] = 1; + pdata->orientation[5] = 0; + + pdata->orientation[6] = 0; + pdata->orientation[7] = 0; + pdata->orientation[8] = 1; + break; + } - type= pdata->type; + client->irq = pdata->irq_pin; + type = pdata->type; + pdata->irq_flags = irq_flags; + printk("irq_flags = %lu padta->irq_flags = %lu\n",irq_flags, pdata->irq_flags); + printk("type = %d \n",pdata->type); + printk("irq = %d \n",pdata->irq); + printk("irq_pin = %d \n",pdata->irq_pin); + printk("pwer_pin = %d \n",pdata->power_pin); + printk("reset_pin = %d \n",pdata->reset_pin); + printk("irq_enable = %d \n",pdata->irq_enable); + + printk("poll_delay_ms = %d \n",pdata->poll_delay_ms); + printk("x_min = %d \n",pdata->x_min); + printk("y_min = %d \n",pdata->y_min); + printk("z_min = %d \n",pdata->z_min); + printk("factory = %d \n",pdata->factory); + printk("layout = %d \n",pdata->layout); + printk("address = 0x%x \n",pdata->address); + printk("project_name = [%s] \n",pdata->project_name); + + printk(" == %d,%d ,%d \t ,%d ,%d ,%d , \t ,%d, %d, %d ,==%d\n",pdata->orientation[0],pdata->orientation[1],pdata->orientation[2] + ,pdata->orientation[3],pdata->orientation[4],pdata->orientation[5] + ,pdata->orientation[6],pdata->orientation[7],pdata->orientation[8],ARRAY_SIZE(pdata->orientation)); + if((type >= SENSOR_NUM_TYPES) || (type <= SENSOR_TYPE_NULL)) { - dev_err(&client->adapter->dev, "sensor type is error %d\n", pdata->type); + dev_err(&client->adapter->dev, "sensor type is error %d\n", type); result = -EFAULT; goto out_no_free; } - if(((int)devid->driver_data >= SENSOR_NUM_ID) || ((int)devid->driver_data <= ID_INVALID)) { dev_err(&client->adapter->dev, "sensor id is error %d\n", (int)devid->driver_data); result = -EFAULT; goto out_no_free; } - i2c_set_clientdata(client, sensor); sensor->client = client; sensor->pdata = pdata; sensor->type = type; sensor->i2c_id = (struct i2c_device_id *)devid; - if (pdata->init_platform_hw) { - result = pdata->init_platform_hw(); - if (result < 0) - goto out_free_memory; - } - - if(pdata->reset_pin) - gpio_request(pdata->reset_pin,"sensor_reset_pin"); - - if(pdata->power_pin) - gpio_request(pdata->power_pin,"sensor_power_pin"); memset(&(sensor->axis), 0, sizeof(struct sensor_axis) ); atomic_set(&(sensor->data_ready), 0); @@ -1718,7 +1882,7 @@ int sensor_probe(struct i2c_client *client, const struct i2c_device_id *devid) atomic_set(&sensor->flags.a_flag, 1); atomic_set(&sensor->flags.mv_flag, 1); atomic_set(&sensor->flags.open_flag, 0); - atomic_set(&sensor->flags.debug_flag, 0); + atomic_set(&sensor->flags.debug_flag, 1); init_waitqueue_head(&sensor->flags.open_wq); sensor->flags.delay = 100; @@ -1972,6 +2136,47 @@ static const struct i2c_device_id sensor_id[] = { {}, }; +static struct of_device_id sensor_dt_ids[] = { + /*gsensor*/ + { .compatible = "gs_mma8452" }, + { .compatible = "gs_lis3dh" }, + { .compatible = "gs_lsm303d" }, + { .compatible = "gs_mma7660" }, + + /*compass*/ + { .compatible = "ak8975" }, + { .compatible = "ak8963" }, + { .compatible = "ak09911" }, + { .compatible = "mmc314x" }, + + /* gyroscop*/ + { .compatible = "l3g4200d_gyro" }, + { .compatible = "l3g20d_gyro" }, + { .compatible = "ewtsa_gyro" }, + { .compatible = "k3g" }, + + + /*light sensor*/ + { .compatible = "light_cm3217" }, + { .compatible = "light_cm3232" }, + { .compatible = "light_al3006" }, + { .compatible = "ls_stk3171" }, + { .compatible = "ls_ap321xx" }, + + { .compatible = "ls_photoresistor" }, + { .compatible = "ls_us5152" }, + + /*temperature sensor*/ + { .compatible = "tmp_ms5607" }, + + /*pressure sensor*/ + { .compatible = "pr_ms5607" }, + + /*hall sensor*/ + { .compatible = "hall_och165t" }, + { } +}; + static struct i2c_driver sensor_driver = { .probe = sensor_probe, @@ -1981,7 +2186,8 @@ static struct i2c_driver sensor_driver = { .driver = { .owner = THIS_MODULE, .name = "sensors", - }, + .of_match_table = of_match_ptr(sensor_dt_ids), + }, }; static int __init sensor_init(void) diff --git a/drivers/input/sensors/sensor-i2c.c b/drivers/input/sensors/sensor-i2c.c index a5326bf8b8f7..7a36954cd24d 100755 --- a/drivers/input/sensors/sensor-i2c.c +++ b/drivers/input/sensors/sensor-i2c.c @@ -25,8 +25,7 @@ #include #include #include -#include -#include +#include #ifdef CONFIG_HAS_EARLYSUSPEND #include #endif @@ -100,8 +99,8 @@ static int senosr_i2c_read(struct i2c_adapter *i2c_adap, int sensor_rx_data(struct i2c_client *client, char *rxData, int length) { - struct sensor_private_data* sensor = - (struct sensor_private_data *)i2c_get_clientdata(client); + //struct sensor_private_data* sensor = + // (struct sensor_private_data *)i2c_get_clientdata(client); int i = 0; int ret = 0; char reg = rxData[0]; @@ -117,8 +116,8 @@ EXPORT_SYMBOL(sensor_rx_data); int sensor_tx_data(struct i2c_client *client, char *txData, int length) { - struct sensor_private_data* sensor = - (struct sensor_private_data *)i2c_get_clientdata(client); + //struct sensor_private_data* sensor = + //(struct sensor_private_data *)i2c_get_clientdata(client); int i = 0; int ret = 0; @@ -165,6 +164,37 @@ int sensor_read_reg(struct i2c_client *client, int addr) EXPORT_SYMBOL(sensor_read_reg); +static int i2c_master_normal_recv(const struct i2c_client *client, char *buf, int count, int scl_rate) + { + struct i2c_adapter *adap=client->adapter; + struct i2c_msg msg; + int ret; + + msg.addr = client->addr; + msg.flags = client->flags | I2C_M_RD; + msg.len = count; + msg.buf = (char *)buf; + msg.scl_rate = scl_rate; + ret = i2c_transfer(adap, &msg, 1); + + return (ret == 1) ? count : ret; +} + +static int i2c_master_normal_send(const struct i2c_client *client, const char *buf, int count, int scl_rate) +{ + int ret; + struct i2c_adapter *adap=client->adapter; + struct i2c_msg msg; + + msg.addr = client->addr; + msg.flags = client->flags; + msg.len = count; + msg.buf = (char *)buf; + msg.scl_rate = scl_rate; + + ret = i2c_transfer(adap, &msg, 1); + return (ret == 1) ? count : ret; +} int sensor_tx_data_normal(struct i2c_client *client, char *buf, int num) { diff --git a/include/dt-bindings/sensor-dev.h b/include/dt-bindings/sensor-dev.h new file mode 100755 index 000000000000..1533243cd892 --- /dev/null +++ b/include/dt-bindings/sensor-dev.h @@ -0,0 +1,17 @@ + +#ifndef __DT_BINDINGS_ROCKCHIP_SENSORDEV_H__ +#define __DT_BINDINGS_ROCKCHIP_SENSORDEV_H__ + +#define SENSOR_TYPE_NULL 0 +#define SENSOR_TYPE_ANGLE 1 +#define SENSOR_TYPE_ACCEL 2 +#define SENSOR_TYPE_COMPASS 3 +#define SENSOR_TYPE_GYROSCOPE 4 +#define SENSOR_TYPE_LIGHT 5 +#define SENSOR_TYPE_PROXIMITY 6 +#define SENSOR_TYPE_TEMPERATURE 7 +#define SENSOR_TYPE_PRESSURE 8 +#define SENSOR_TYPE_HALL 9 +#define SENSOR_NUM_TYPES 10 + +#endif diff --git a/include/linux/sensor-dev.h b/include/linux/sensor-dev.h index 582994c49834..2a86fd6a72b3 100755 --- a/include/linux/sensor-dev.h +++ b/include/linux/sensor-dev.h @@ -19,23 +19,14 @@ #include #endif +#include #define SENSOR_ON 1 #define SENSOR_OFF 0 #define SENSOR_UNKNOW_DATA -1 -enum sensor_type { - SENSOR_TYPE_NULL, - SENSOR_TYPE_ANGLE, - SENSOR_TYPE_ACCEL, - SENSOR_TYPE_COMPASS, - SENSOR_TYPE_GYROSCOPE, - SENSOR_TYPE_LIGHT, - SENSOR_TYPE_PROXIMITY, - SENSOR_TYPE_TEMPERATURE, - SENSOR_TYPE_PRESSURE, - SENSOR_NUM_TYPES -}; +#define GPIO_HIGH 1 +#define GPIO_LOW 0 enum sensor_id { ID_INVALID = 0, @@ -107,6 +98,10 @@ enum sensor_id { PRESSURE_ID_ALL, PRESSURE_ID_BMA085, PRESSURE_ID_MS5607, + + HALL_ID_ALL, + HALL_ID_OCH165T, + SENSOR_NUM_ID, }; @@ -183,6 +178,53 @@ struct sensor_private_data { #endif }; +struct sensor_platform_data { + int type; + int irq; + int irq_pin; + int power_pin; + int reset_pin; + int standby_pin; + int irq_enable; //if irq_enable=1 then use irq else use polling + int poll_delay_ms; //polling + int x_min; //filter + int y_min; + int z_min; + int factory; + int layout; + unsigned char address; + unsigned long irq_flags; + signed char orientation[9]; + short m_layout[4][3][3]; + char* project_name; +}; + + struct gsensor_platform_data { + u16 model; + u16 swap_xy; + u16 swap_xyz; + signed char orientation[9]; + int (*get_pendown_state)(void); + int (*init_platform_hw)(void); + int (*gsensor_platform_sleep)(void); + int (*gsensor_platform_wakeup)(void); + void (*exit_platform_hw)(void); + }; + + struct akm8975_platform_data { + short m_layout[4][3][3]; + char project_name[64]; + int gpio_DRDY; + }; + + struct akm_platform_data { + short m_layout[4][3][3]; + char project_name[64]; + char layout; + char outbit; + int gpio_DRDY; + int gpio_RST; + }; extern int sensor_register_slave(int type,struct i2c_client *client, struct sensor_platform_data *slave_pdata, @@ -193,7 +235,7 @@ extern int sensor_unregister_slave(int type,struct i2c_client *client, struct sensor_platform_data *slave_pdata, struct sensor_operate *(*get_sensor_ops)(void)); -#if 1 +#if 0 #define DBG(x...) if((atomic_read(&sensor->flags.debug_flag) == sensor->pdata->type) || (atomic_read(&sensor->flags.debug_flag) == SENSOR_NUM_TYPES))printk(x) #else #define DBG(x...) -- 2.34.1