提交 4e5a494e 编写于 作者: J Jiri Kosina

Merge branch 'for-3.12/sensor-hub' into for-linus

Conflicts:
	drivers/hid/hid-sensor-hub.c
...@@ -103,8 +103,7 @@ static int sensor_hub_get_physical_device_count( ...@@ -103,8 +103,7 @@ static int sensor_hub_get_physical_device_count(
list_for_each_entry(report, &report_enum->report_list, list) { list_for_each_entry(report, &report_enum->report_list, list) {
field = report->field[0]; field = report->field[0];
if (report->maxfield && field && if (report->maxfield && field && field->physical)
field->physical)
cnt++; cnt++;
} }
...@@ -192,12 +191,12 @@ int sensor_hub_set_feature(struct hid_sensor_hub_device *hsdev, u32 report_id, ...@@ -192,12 +191,12 @@ int sensor_hub_set_feature(struct hid_sensor_hub_device *hsdev, u32 report_id,
u32 field_index, s32 value) u32 field_index, s32 value)
{ {
struct hid_report *report; struct hid_report *report;
struct sensor_hub_data *data = hid_get_drvdata(hsdev->hdev); struct sensor_hub_data *data = hid_get_drvdata(hsdev->hdev);
int ret = 0; int ret = 0;
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT); report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT);
if (!report || (field_index >= report->maxfield)) { if (!report || (field_index >= report->maxfield)) {
ret = -EINVAL; ret = -EINVAL;
goto done_proc; goto done_proc;
} }
...@@ -216,12 +215,12 @@ int sensor_hub_get_feature(struct hid_sensor_hub_device *hsdev, u32 report_id, ...@@ -216,12 +215,12 @@ int sensor_hub_get_feature(struct hid_sensor_hub_device *hsdev, u32 report_id,
u32 field_index, s32 *value) u32 field_index, s32 *value)
{ {
struct hid_report *report; struct hid_report *report;
struct sensor_hub_data *data = hid_get_drvdata(hsdev->hdev); struct sensor_hub_data *data = hid_get_drvdata(hsdev->hdev);
int ret = 0; int ret = 0;
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT); report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT);
if (!report || (field_index >= report->maxfield) || if (!report || (field_index >= report->maxfield) ||
report->field[field_index]->report_count < 1) { report->field[field_index]->report_count < 1) {
ret = -EINVAL; ret = -EINVAL;
goto done_proc; goto done_proc;
...@@ -242,7 +241,7 @@ int sensor_hub_input_attr_get_raw_value(struct hid_sensor_hub_device *hsdev, ...@@ -242,7 +241,7 @@ int sensor_hub_input_attr_get_raw_value(struct hid_sensor_hub_device *hsdev,
u32 usage_id, u32 usage_id,
u32 attr_usage_id, u32 report_id) u32 attr_usage_id, u32 report_id)
{ {
struct sensor_hub_data *data = hid_get_drvdata(hsdev->hdev); struct sensor_hub_data *data = hid_get_drvdata(hsdev->hdev);
unsigned long flags; unsigned long flags;
struct hid_report *report; struct hid_report *report;
int ret_val = 0; int ret_val = 0;
...@@ -303,7 +302,7 @@ int sensor_hub_input_get_attribute_info(struct hid_sensor_hub_device *hsdev, ...@@ -303,7 +302,7 @@ int sensor_hub_input_get_attribute_info(struct hid_sensor_hub_device *hsdev,
/* Initialize with defaults */ /* Initialize with defaults */
info->usage_id = usage_id; info->usage_id = usage_id;
info->attrib_id = attr_usage_id; info->attrib_id = attr_usage_id;
info->report_id = -1; info->report_id = -1;
info->index = -1; info->index = -1;
info->units = -1; info->units = -1;
...@@ -334,7 +333,7 @@ int sensor_hub_input_get_attribute_info(struct hid_sensor_hub_device *hsdev, ...@@ -334,7 +333,7 @@ int sensor_hub_input_get_attribute_info(struct hid_sensor_hub_device *hsdev,
if (field->usage[j].hid == if (field->usage[j].hid ==
attr_usage_id && attr_usage_id &&
field->usage[j].collection_index == field->usage[j].collection_index ==
collection_index) { collection_index) {
sensor_hub_fill_attr_info(info, sensor_hub_fill_attr_info(info,
i, report->id, i, report->id,
field->unit, field->unit,
...@@ -358,7 +357,7 @@ EXPORT_SYMBOL_GPL(sensor_hub_input_get_attribute_info); ...@@ -358,7 +357,7 @@ EXPORT_SYMBOL_GPL(sensor_hub_input_get_attribute_info);
#ifdef CONFIG_PM #ifdef CONFIG_PM
static int sensor_hub_suspend(struct hid_device *hdev, pm_message_t message) static int sensor_hub_suspend(struct hid_device *hdev, pm_message_t message)
{ {
struct sensor_hub_data *pdata = hid_get_drvdata(hdev); struct sensor_hub_data *pdata = hid_get_drvdata(hdev);
struct hid_sensor_hub_callbacks_list *callback; struct hid_sensor_hub_callbacks_list *callback;
hid_dbg(hdev, " sensor_hub_suspend\n"); hid_dbg(hdev, " sensor_hub_suspend\n");
...@@ -375,7 +374,7 @@ static int sensor_hub_suspend(struct hid_device *hdev, pm_message_t message) ...@@ -375,7 +374,7 @@ static int sensor_hub_suspend(struct hid_device *hdev, pm_message_t message)
static int sensor_hub_resume(struct hid_device *hdev) static int sensor_hub_resume(struct hid_device *hdev)
{ {
struct sensor_hub_data *pdata = hid_get_drvdata(hdev); struct sensor_hub_data *pdata = hid_get_drvdata(hdev);
struct hid_sensor_hub_callbacks_list *callback; struct hid_sensor_hub_callbacks_list *callback;
hid_dbg(hdev, " sensor_hub_resume\n"); hid_dbg(hdev, " sensor_hub_resume\n");
...@@ -395,6 +394,7 @@ static int sensor_hub_reset_resume(struct hid_device *hdev) ...@@ -395,6 +394,7 @@ static int sensor_hub_reset_resume(struct hid_device *hdev)
return 0; return 0;
} }
#endif #endif
/* /*
* Handle raw report as sent by device * Handle raw report as sent by device
*/ */
...@@ -422,7 +422,6 @@ static int sensor_hub_raw_event(struct hid_device *hdev, ...@@ -422,7 +422,6 @@ static int sensor_hub_raw_event(struct hid_device *hdev,
spin_lock_irqsave(&pdata->lock, flags); spin_lock_irqsave(&pdata->lock, flags);
for (i = 0; i < report->maxfield; ++i) { for (i = 0; i < report->maxfield; ++i) {
hid_dbg(hdev, "%d collection_index:%x hid:%x sz:%x\n", hid_dbg(hdev, "%d collection_index:%x hid:%x sz:%x\n",
i, report->field[i]->usage->collection_index, i, report->field[i]->usage->collection_index,
report->field[i]->usage->hid, report->field[i]->usage->hid,
...@@ -432,11 +431,10 @@ static int sensor_hub_raw_event(struct hid_device *hdev, ...@@ -432,11 +431,10 @@ static int sensor_hub_raw_event(struct hid_device *hdev,
if (pdata->pending.status && pdata->pending.attr_usage_id == if (pdata->pending.status && pdata->pending.attr_usage_id ==
report->field[i]->usage->hid) { report->field[i]->usage->hid) {
hid_dbg(hdev, "data was pending ...\n"); hid_dbg(hdev, "data was pending ...\n");
pdata->pending.raw_data = kmalloc(sz, GFP_ATOMIC); pdata->pending.raw_data = kmemdup(ptr, sz, GFP_ATOMIC);
if (pdata->pending.raw_data) { if (pdata->pending.raw_data)
memcpy(pdata->pending.raw_data, ptr, sz); pdata->pending.raw_size = sz;
pdata->pending.raw_size = sz; else
} else
pdata->pending.raw_size = 0; pdata->pending.raw_size = 0;
complete(&pdata->pending.ready); complete(&pdata->pending.ready);
} }
...@@ -479,16 +477,15 @@ static int sensor_hub_probe(struct hid_device *hdev, ...@@ -479,16 +477,15 @@ static int sensor_hub_probe(struct hid_device *hdev,
struct hid_field *field; struct hid_field *field;
int dev_cnt; int dev_cnt;
sd = kzalloc(sizeof(struct sensor_hub_data), GFP_KERNEL); sd = devm_kzalloc(&hdev->dev, sizeof(*sd), GFP_KERNEL);
if (!sd) { if (!sd) {
hid_err(hdev, "cannot allocate Sensor data\n"); hid_err(hdev, "cannot allocate Sensor data\n");
return -ENOMEM; return -ENOMEM;
} }
sd->hsdev = kzalloc(sizeof(struct hid_sensor_hub_device), GFP_KERNEL); sd->hsdev = devm_kzalloc(&hdev->dev, sizeof(*sd->hsdev), GFP_KERNEL);
if (!sd->hsdev) { if (!sd->hsdev) {
hid_err(hdev, "cannot allocate hid_sensor_hub_device\n"); hid_err(hdev, "cannot allocate hid_sensor_hub_device\n");
ret = -ENOMEM; return -ENOMEM;
goto err_free_hub;
} }
hid_set_drvdata(hdev, sd); hid_set_drvdata(hdev, sd);
sd->hsdev->hdev = hdev; sd->hsdev->hdev = hdev;
...@@ -500,14 +497,14 @@ static int sensor_hub_probe(struct hid_device *hdev, ...@@ -500,14 +497,14 @@ static int sensor_hub_probe(struct hid_device *hdev,
ret = hid_parse(hdev); ret = hid_parse(hdev);
if (ret) { if (ret) {
hid_err(hdev, "parse failed\n"); hid_err(hdev, "parse failed\n");
goto err_free; return ret;
} }
INIT_LIST_HEAD(&hdev->inputs); INIT_LIST_HEAD(&hdev->inputs);
ret = hid_hw_start(hdev, 0); ret = hid_hw_start(hdev, 0);
if (ret) { if (ret) {
hid_err(hdev, "hw start failed\n"); hid_err(hdev, "hw start failed\n");
goto err_free; return ret;
} }
ret = hid_hw_open(hdev); ret = hid_hw_open(hdev);
if (ret) { if (ret) {
...@@ -540,7 +537,7 @@ static int sensor_hub_probe(struct hid_device *hdev, ...@@ -540,7 +537,7 @@ static int sensor_hub_probe(struct hid_device *hdev,
field->physical) { field->physical) {
name = kasprintf(GFP_KERNEL, "HID-SENSOR-%x", name = kasprintf(GFP_KERNEL, "HID-SENSOR-%x",
field->physical); field->physical);
if (name == NULL) { if (name == NULL) {
hid_err(hdev, "Failed MFD device name\n"); hid_err(hdev, "Failed MFD device name\n");
ret = -ENOMEM; ret = -ENOMEM;
goto err_free_names; goto err_free_names;
...@@ -572,10 +569,6 @@ static int sensor_hub_probe(struct hid_device *hdev, ...@@ -572,10 +569,6 @@ static int sensor_hub_probe(struct hid_device *hdev,
hid_hw_close(hdev); hid_hw_close(hdev);
err_stop_hw: err_stop_hw:
hid_hw_stop(hdev); hid_hw_stop(hdev);
err_free:
kfree(sd->hsdev);
err_free_hub:
kfree(sd);
return ret; return ret;
} }
...@@ -599,8 +592,6 @@ static void sensor_hub_remove(struct hid_device *hdev) ...@@ -599,8 +592,6 @@ static void sensor_hub_remove(struct hid_device *hdev)
kfree(data->hid_sensor_hub_client_devs); kfree(data->hid_sensor_hub_client_devs);
hid_set_drvdata(hdev, NULL); hid_set_drvdata(hdev, NULL);
mutex_destroy(&data->mutex); mutex_destroy(&data->mutex);
kfree(data->hsdev);
kfree(data);
} }
static const struct hid_device_id sensor_hub_devices[] = { static const struct hid_device_id sensor_hub_devices[] = {
...@@ -618,8 +609,8 @@ static struct hid_driver sensor_hub_driver = { ...@@ -618,8 +609,8 @@ static struct hid_driver sensor_hub_driver = {
.raw_event = sensor_hub_raw_event, .raw_event = sensor_hub_raw_event,
#ifdef CONFIG_PM #ifdef CONFIG_PM
.suspend = sensor_hub_suspend, .suspend = sensor_hub_suspend,
.resume = sensor_hub_resume, .resume = sensor_hub_resume,
.reset_resume = sensor_hub_reset_resume, .reset_resume = sensor_hub_reset_resume,
#endif #endif
}; };
module_hid_driver(sensor_hub_driver); module_hid_driver(sensor_hub_driver);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册