mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 13:34:30 +00:00
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid
Pull HID fixes from Jiri Kosina: - fix for Intel-ISH driver to make sure it gets aoutoloaded only on matching devices and not universally (Thomas Weißschuh) - fix for Wacom driver reporting invalid contact under certain circumstances (Jason Gerecke) - probing fix for ft260 dirver (Michael Zaidman) - fix for generic keycode remapping (Thomas Weißschuh) - fix for division by zero in hid-magicmouse (Claudia Pellegrino) - other tiny assorted fixes and new device IDs * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid: HID: multitouch: Fix Iiyama ProLite T1931SAW (0eef:0001 again!) HID: nintendo: eliminate dead datastructures in !CONFIG_NINTENDO_FF case HID: magicmouse: prevent division by 0 on scroll HID: thrustmaster: fix sparse warnings HID: Ignore battery for Elan touchscreen on HP Envy X360 15-eu0xxx HID: input: set usage type to key on keycode remap HID: input: Fix parsing of HID_CP_CONSUMER_CONTROL fields HID: ft260: fix i2c probing for hwmon devices Revert "HID: hid-asus.c: Maps key 0x35 (display off) to KEY_SCREENLOCK" HID: intel-ish-hid: fix module device-id handling mod_devicetable: fix kdocs for ishtp_device_id HID: wacom: Use "Confidence" flag to prevent reporting invalid contacts HID: nintendo: unlock on error in joycon_leds_create() platform/x86: isthp_eclite: only load for matching devices platform/chrome: chros_ec_ishtp: only load for matching devices HID: intel-ish-hid: hid-client: only load for matching devices HID: intel-ish-hid: fw-loader: only load for matching devices HID: intel-ish-hid: use constants for modaliases HID: intel-ish-hid: add support for MODULE_DEVICE_TABLE()
This commit is contained in:
commit
740bebf421
@ -854,7 +854,7 @@ static int asus_input_mapping(struct hid_device *hdev,
|
||||
switch (usage->hid & HID_USAGE) {
|
||||
case 0x10: asus_map_key_clear(KEY_BRIGHTNESSDOWN); break;
|
||||
case 0x20: asus_map_key_clear(KEY_BRIGHTNESSUP); break;
|
||||
case 0x35: asus_map_key_clear(KEY_SCREENLOCK); break;
|
||||
case 0x35: asus_map_key_clear(KEY_DISPLAY_OFF); break;
|
||||
case 0x6c: asus_map_key_clear(KEY_SLEEP); break;
|
||||
case 0x7c: asus_map_key_clear(KEY_MICMUTE); break;
|
||||
case 0x82: asus_map_key_clear(KEY_CAMERA); break;
|
||||
|
@ -966,24 +966,23 @@ static int ft260_probe(struct hid_device *hdev, const struct hid_device_id *id)
|
||||
mutex_init(&dev->lock);
|
||||
init_completion(&dev->wait);
|
||||
|
||||
ret = ft260_xfer_status(dev);
|
||||
if (ret)
|
||||
ft260_i2c_reset(hdev);
|
||||
|
||||
i2c_set_adapdata(&dev->adap, dev);
|
||||
ret = i2c_add_adapter(&dev->adap);
|
||||
if (ret) {
|
||||
hid_err(hdev, "failed to add i2c adapter\n");
|
||||
goto err_hid_close;
|
||||
}
|
||||
|
||||
i2c_set_adapdata(&dev->adap, dev);
|
||||
|
||||
ret = sysfs_create_group(&hdev->dev.kobj, &ft260_attr_group);
|
||||
if (ret < 0) {
|
||||
hid_err(hdev, "failed to create sysfs attrs\n");
|
||||
goto err_i2c_free;
|
||||
}
|
||||
|
||||
ret = ft260_xfer_status(dev);
|
||||
if (ret)
|
||||
ft260_i2c_reset(hdev);
|
||||
|
||||
return 0;
|
||||
|
||||
err_i2c_free:
|
||||
|
@ -397,6 +397,7 @@
|
||||
#define USB_DEVICE_ID_TOSHIBA_CLICK_L9W 0x0401
|
||||
#define USB_DEVICE_ID_HP_X2 0x074d
|
||||
#define USB_DEVICE_ID_HP_X2_10_COVER 0x0755
|
||||
#define I2C_DEVICE_ID_HP_ENVY_X360_15 0x2d05
|
||||
#define I2C_DEVICE_ID_HP_SPECTRE_X360_15 0x2817
|
||||
#define USB_DEVICE_ID_ASUS_UX550_TOUCHSCREEN 0x2706
|
||||
#define I2C_DEVICE_ID_SURFACE_GO_TOUCHSCREEN 0x261A
|
||||
|
@ -160,6 +160,7 @@ static int hidinput_setkeycode(struct input_dev *dev,
|
||||
if (usage) {
|
||||
*old_keycode = usage->type == EV_KEY ?
|
||||
usage->code : KEY_RESERVED;
|
||||
usage->type = EV_KEY;
|
||||
usage->code = ke->keycode;
|
||||
|
||||
clear_bit(*old_keycode, dev->keybit);
|
||||
@ -324,6 +325,8 @@ static const struct hid_device_id hid_battery_quirks[] = {
|
||||
HID_BATTERY_QUIRK_IGNORE },
|
||||
{ HID_USB_DEVICE(USB_VENDOR_ID_ELAN, USB_DEVICE_ID_ASUS_UX550_TOUCHSCREEN),
|
||||
HID_BATTERY_QUIRK_IGNORE },
|
||||
{ HID_I2C_DEVICE(USB_VENDOR_ID_ELAN, I2C_DEVICE_ID_HP_ENVY_X360_15),
|
||||
HID_BATTERY_QUIRK_IGNORE },
|
||||
{ HID_I2C_DEVICE(USB_VENDOR_ID_ELAN, I2C_DEVICE_ID_HP_SPECTRE_X360_15),
|
||||
HID_BATTERY_QUIRK_IGNORE },
|
||||
{ HID_I2C_DEVICE(USB_VENDOR_ID_ELAN, I2C_DEVICE_ID_SURFACE_GO_TOUCHSCREEN),
|
||||
@ -650,10 +653,9 @@ static void hidinput_configure_usage(struct hid_input *hidinput, struct hid_fiel
|
||||
code += KEY_MACRO1;
|
||||
else
|
||||
code += BTN_TRIGGER_HAPPY - 0x1e;
|
||||
} else {
|
||||
goto ignore;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
fallthrough;
|
||||
default:
|
||||
switch (field->physical) {
|
||||
case HID_GD_MOUSE:
|
||||
|
@ -256,8 +256,11 @@ static void magicmouse_emit_touch(struct magicmouse_sc *msc, int raw_id, u8 *tda
|
||||
unsigned long now = jiffies;
|
||||
int step_x = msc->touches[id].scroll_x - x;
|
||||
int step_y = msc->touches[id].scroll_y - y;
|
||||
int step_hr = ((64 - (int)scroll_speed) * msc->scroll_accel) /
|
||||
SCROLL_HR_STEPS;
|
||||
int step_hr =
|
||||
max_t(int,
|
||||
((64 - (int)scroll_speed) * msc->scroll_accel) /
|
||||
SCROLL_HR_STEPS,
|
||||
1);
|
||||
int step_x_hr = msc->touches[id].scroll_x_hr - x;
|
||||
int step_y_hr = msc->touches[id].scroll_y_hr - y;
|
||||
|
||||
|
@ -1888,6 +1888,11 @@ static const struct hid_device_id mt_devices[] = {
|
||||
MT_USB_DEVICE(USB_VENDOR_ID_CVTOUCH,
|
||||
USB_DEVICE_ID_CVTOUCH_SCREEN) },
|
||||
|
||||
/* eGalax devices (SAW) */
|
||||
{ .driver_data = MT_CLS_EXPORT_ALL_INPUTS,
|
||||
MT_USB_DEVICE(USB_VENDOR_ID_DWAV,
|
||||
USB_DEVICE_ID_EGALAX_TOUCHCONTROLLER) },
|
||||
|
||||
/* eGalax devices (resistive) */
|
||||
{ .driver_data = MT_CLS_EGALAX,
|
||||
MT_USB_DEVICE(USB_VENDOR_ID_DWAV,
|
||||
|
@ -189,6 +189,7 @@ struct joycon_rumble_amp_data {
|
||||
u16 amp;
|
||||
};
|
||||
|
||||
#if IS_ENABLED(CONFIG_NINTENDO_FF)
|
||||
/*
|
||||
* These tables are from
|
||||
* https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/rumble_data_table.md
|
||||
@ -289,6 +290,10 @@ static const struct joycon_rumble_amp_data joycon_rumble_amplitudes[] = {
|
||||
{ 0xc2, 0x8070, 940 }, { 0xc4, 0x0071, 960 }, { 0xc6, 0x8071, 981 },
|
||||
{ 0xc8, 0x0072, joycon_max_rumble_amp }
|
||||
};
|
||||
static const u16 JC_RUMBLE_DFLT_LOW_FREQ = 160;
|
||||
static const u16 JC_RUMBLE_DFLT_HIGH_FREQ = 320;
|
||||
#endif /* IS_ENABLED(CONFIG_NINTENDO_FF) */
|
||||
static const u16 JC_RUMBLE_PERIOD_MS = 50;
|
||||
|
||||
/* States for controller state machine */
|
||||
enum joycon_ctlr_state {
|
||||
@ -397,9 +402,6 @@ struct joycon_input_report {
|
||||
#define JC_RUMBLE_DATA_SIZE 8
|
||||
#define JC_RUMBLE_QUEUE_SIZE 8
|
||||
|
||||
static const u16 JC_RUMBLE_DFLT_LOW_FREQ = 160;
|
||||
static const u16 JC_RUMBLE_DFLT_HIGH_FREQ = 320;
|
||||
static const u16 JC_RUMBLE_PERIOD_MS = 50;
|
||||
static const unsigned short JC_RUMBLE_ZERO_AMP_PKT_CNT = 5;
|
||||
|
||||
static const char * const joycon_player_led_names[] = {
|
||||
@ -1850,8 +1852,10 @@ static int joycon_leds_create(struct joycon_ctlr *ctlr)
|
||||
d_name,
|
||||
"green",
|
||||
joycon_player_led_names[i]);
|
||||
if (!name)
|
||||
if (!name) {
|
||||
mutex_unlock(&joycon_input_num_mutex);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
led = &ctlr->leds[i];
|
||||
led->name = name;
|
||||
@ -1864,6 +1868,7 @@ static int joycon_leds_create(struct joycon_ctlr *ctlr)
|
||||
ret = devm_led_classdev_register(&hdev->dev, led);
|
||||
if (ret) {
|
||||
hid_err(hdev, "Failed registering %s LED\n", led->name);
|
||||
mutex_unlock(&joycon_input_num_mutex);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
@ -205,7 +205,7 @@ static void thrustmaster_model_handler(struct urb *urb)
|
||||
struct tm_wheel *tm_wheel = hid_get_drvdata(hdev);
|
||||
uint16_t model = 0;
|
||||
int i, ret;
|
||||
const struct tm_wheel_info *twi = 0;
|
||||
const struct tm_wheel_info *twi = NULL;
|
||||
|
||||
if (urb->status) {
|
||||
hid_err(hdev, "URB to get model id failed with error %d\n", urb->status);
|
||||
@ -238,7 +238,7 @@ static void thrustmaster_model_handler(struct urb *urb)
|
||||
tm_wheel->usb_dev,
|
||||
usb_sndctrlpipe(tm_wheel->usb_dev, 0),
|
||||
(char *)tm_wheel->change_request,
|
||||
0, 0, // We do not expect any response from the wheel
|
||||
NULL, 0, // We do not expect any response from the wheel
|
||||
thrustmaster_change_handler,
|
||||
hdev
|
||||
);
|
||||
@ -272,7 +272,7 @@ static void thrustmaster_remove(struct hid_device *hdev)
|
||||
static int thrustmaster_probe(struct hid_device *hdev, const struct hid_device_id *id)
|
||||
{
|
||||
int ret = 0;
|
||||
struct tm_wheel *tm_wheel = 0;
|
||||
struct tm_wheel *tm_wheel = NULL;
|
||||
|
||||
ret = hid_parse(hdev);
|
||||
if (ret) {
|
||||
|
@ -76,9 +76,12 @@ enum ish_loader_commands {
|
||||
#define LOADER_XFER_MODE_ISHTP BIT(1)
|
||||
|
||||
/* ISH Transport Loader client unique GUID */
|
||||
static const guid_t loader_ishtp_guid =
|
||||
GUID_INIT(0xc804d06a, 0x55bd, 0x4ea7,
|
||||
0xad, 0xed, 0x1e, 0x31, 0x22, 0x8c, 0x76, 0xdc);
|
||||
static const struct ishtp_device_id loader_ishtp_id_table[] = {
|
||||
{ .guid = GUID_INIT(0xc804d06a, 0x55bd, 0x4ea7,
|
||||
0xad, 0xed, 0x1e, 0x31, 0x22, 0x8c, 0x76, 0xdc) },
|
||||
{ }
|
||||
};
|
||||
MODULE_DEVICE_TABLE(ishtp, loader_ishtp_id_table);
|
||||
|
||||
#define FILENAME_SIZE 256
|
||||
|
||||
@ -880,7 +883,7 @@ static int loader_init(struct ishtp_cl *loader_ishtp_cl, int reset)
|
||||
|
||||
fw_client =
|
||||
ishtp_fw_cl_get_client(ishtp_get_ishtp_device(loader_ishtp_cl),
|
||||
&loader_ishtp_guid);
|
||||
&loader_ishtp_id_table[0].guid);
|
||||
if (!fw_client) {
|
||||
dev_err(cl_data_to_dev(client_data),
|
||||
"ISH client uuid not found\n");
|
||||
@ -1057,7 +1060,7 @@ static int loader_ishtp_cl_reset(struct ishtp_cl_device *cl_device)
|
||||
|
||||
static struct ishtp_cl_driver loader_ishtp_cl_driver = {
|
||||
.name = "ish-loader",
|
||||
.guid = &loader_ishtp_guid,
|
||||
.id = loader_ishtp_id_table,
|
||||
.probe = loader_ishtp_cl_probe,
|
||||
.remove = loader_ishtp_cl_remove,
|
||||
.reset = loader_ishtp_cl_reset,
|
||||
@ -1083,4 +1086,3 @@ MODULE_DESCRIPTION("ISH ISH-TP Host firmware Loader Client Driver");
|
||||
MODULE_AUTHOR("Rushikesh S Kadam <rushikesh.s.kadam@intel.com>");
|
||||
|
||||
MODULE_LICENSE("GPL v2");
|
||||
MODULE_ALIAS("ishtp:*");
|
||||
|
@ -12,9 +12,12 @@
|
||||
#include "ishtp-hid.h"
|
||||
|
||||
/* ISH Transport protocol (ISHTP in short) GUID */
|
||||
static const guid_t hid_ishtp_guid =
|
||||
GUID_INIT(0x33AECD58, 0xB679, 0x4E54,
|
||||
0x9B, 0xD9, 0xA0, 0x4D, 0x34, 0xF0, 0xC2, 0x26);
|
||||
static const struct ishtp_device_id hid_ishtp_id_table[] = {
|
||||
{ .guid = GUID_INIT(0x33AECD58, 0xB679, 0x4E54,
|
||||
0x9B, 0xD9, 0xA0, 0x4D, 0x34, 0xF0, 0xC2, 0x26), },
|
||||
{ }
|
||||
};
|
||||
MODULE_DEVICE_TABLE(ishtp, hid_ishtp_id_table);
|
||||
|
||||
/* Rx ring buffer pool size */
|
||||
#define HID_CL_RX_RING_SIZE 32
|
||||
@ -662,7 +665,7 @@ static int hid_ishtp_cl_init(struct ishtp_cl *hid_ishtp_cl, int reset)
|
||||
ishtp_set_tx_ring_size(hid_ishtp_cl, HID_CL_TX_RING_SIZE);
|
||||
ishtp_set_rx_ring_size(hid_ishtp_cl, HID_CL_RX_RING_SIZE);
|
||||
|
||||
fw_client = ishtp_fw_cl_get_client(dev, &hid_ishtp_guid);
|
||||
fw_client = ishtp_fw_cl_get_client(dev, &hid_ishtp_id_table[0].guid);
|
||||
if (!fw_client) {
|
||||
dev_err(cl_data_to_dev(client_data),
|
||||
"ish client uuid not found\n");
|
||||
@ -945,7 +948,7 @@ static const struct dev_pm_ops hid_ishtp_pm_ops = {
|
||||
|
||||
static struct ishtp_cl_driver hid_ishtp_cl_driver = {
|
||||
.name = "ish-hid",
|
||||
.guid = &hid_ishtp_guid,
|
||||
.id = hid_ishtp_id_table,
|
||||
.probe = hid_ishtp_cl_probe,
|
||||
.remove = hid_ishtp_cl_remove,
|
||||
.reset = hid_ishtp_cl_reset,
|
||||
@ -981,4 +984,3 @@ MODULE_AUTHOR("Daniel Drubin <daniel.drubin@intel.com>");
|
||||
MODULE_AUTHOR("Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>");
|
||||
|
||||
MODULE_LICENSE("GPL");
|
||||
MODULE_ALIAS("ishtp:*");
|
||||
|
@ -241,7 +241,7 @@ static int ishtp_cl_bus_match(struct device *dev, struct device_driver *drv)
|
||||
struct ishtp_cl_device *device = to_ishtp_cl_device(dev);
|
||||
struct ishtp_cl_driver *driver = to_ishtp_cl_driver(drv);
|
||||
|
||||
return guid_equal(driver->guid,
|
||||
return guid_equal(&driver->id[0].guid,
|
||||
&device->fw_client->props.protocol_name);
|
||||
}
|
||||
|
||||
@ -350,7 +350,7 @@ static ssize_t modalias_show(struct device *dev, struct device_attribute *a,
|
||||
{
|
||||
int len;
|
||||
|
||||
len = snprintf(buf, PAGE_SIZE, "ishtp:%s\n", dev_name(dev));
|
||||
len = snprintf(buf, PAGE_SIZE, ISHTP_MODULE_PREFIX "%s\n", dev_name(dev));
|
||||
return (len >= PAGE_SIZE) ? (PAGE_SIZE - 1) : len;
|
||||
}
|
||||
static DEVICE_ATTR_RO(modalias);
|
||||
@ -363,7 +363,7 @@ ATTRIBUTE_GROUPS(ishtp_cl_dev);
|
||||
|
||||
static int ishtp_cl_uevent(struct device *dev, struct kobj_uevent_env *env)
|
||||
{
|
||||
if (add_uevent_var(env, "MODALIAS=ishtp:%s", dev_name(dev)))
|
||||
if (add_uevent_var(env, "MODALIAS=" ISHTP_MODULE_PREFIX "%s", dev_name(dev)))
|
||||
return -ENOMEM;
|
||||
return 0;
|
||||
}
|
||||
|
@ -2603,6 +2603,9 @@ static void wacom_wac_finger_event(struct hid_device *hdev,
|
||||
return;
|
||||
|
||||
switch (equivalent_usage) {
|
||||
case HID_DG_CONFIDENCE:
|
||||
wacom_wac->hid_data.confidence = value;
|
||||
break;
|
||||
case HID_GD_X:
|
||||
wacom_wac->hid_data.x = value;
|
||||
break;
|
||||
@ -2635,7 +2638,8 @@ static void wacom_wac_finger_event(struct hid_device *hdev,
|
||||
}
|
||||
|
||||
if (usage->usage_index + 1 == field->report_count) {
|
||||
if (equivalent_usage == wacom_wac->hid_data.last_slot_field)
|
||||
if (equivalent_usage == wacom_wac->hid_data.last_slot_field &&
|
||||
wacom_wac->hid_data.confidence)
|
||||
wacom_wac_finger_slot(wacom_wac, wacom_wac->touch_input);
|
||||
}
|
||||
}
|
||||
@ -2653,6 +2657,8 @@ static void wacom_wac_finger_pre_report(struct hid_device *hdev,
|
||||
|
||||
wacom_wac->is_invalid_bt_frame = false;
|
||||
|
||||
hid_data->confidence = true;
|
||||
|
||||
for (i = 0; i < report->maxfield; i++) {
|
||||
struct hid_field *field = report->field[i];
|
||||
int j;
|
||||
|
@ -301,6 +301,7 @@ struct hid_data {
|
||||
bool barrelswitch;
|
||||
bool barrelswitch2;
|
||||
bool serialhi;
|
||||
bool confidence;
|
||||
int x;
|
||||
int y;
|
||||
int pressure;
|
||||
|
@ -41,9 +41,12 @@ enum cros_ec_ish_channel {
|
||||
#define ISHTP_SEND_TIMEOUT (3 * HZ)
|
||||
|
||||
/* ISH Transport CrOS EC ISH client unique GUID */
|
||||
static const guid_t cros_ish_guid =
|
||||
GUID_INIT(0x7b7154d0, 0x56f4, 0x4bdc,
|
||||
0xb0, 0xd8, 0x9e, 0x7c, 0xda, 0xe0, 0xd6, 0xa0);
|
||||
static const struct ishtp_device_id cros_ec_ishtp_id_table[] = {
|
||||
{ .guid = GUID_INIT(0x7b7154d0, 0x56f4, 0x4bdc,
|
||||
0xb0, 0xd8, 0x9e, 0x7c, 0xda, 0xe0, 0xd6, 0xa0), },
|
||||
{ }
|
||||
};
|
||||
MODULE_DEVICE_TABLE(ishtp, cros_ec_ishtp_id_table);
|
||||
|
||||
struct header {
|
||||
u8 channel;
|
||||
@ -389,7 +392,7 @@ static int cros_ish_init(struct ishtp_cl *cros_ish_cl)
|
||||
ishtp_set_tx_ring_size(cros_ish_cl, CROS_ISH_CL_TX_RING_SIZE);
|
||||
ishtp_set_rx_ring_size(cros_ish_cl, CROS_ISH_CL_RX_RING_SIZE);
|
||||
|
||||
fw_client = ishtp_fw_cl_get_client(dev, &cros_ish_guid);
|
||||
fw_client = ishtp_fw_cl_get_client(dev, &cros_ec_ishtp_id_table[0].guid);
|
||||
if (!fw_client) {
|
||||
dev_err(cl_data_to_dev(client_data),
|
||||
"ish client uuid not found\n");
|
||||
@ -765,7 +768,7 @@ static SIMPLE_DEV_PM_OPS(cros_ec_ishtp_pm_ops, cros_ec_ishtp_suspend,
|
||||
|
||||
static struct ishtp_cl_driver cros_ec_ishtp_driver = {
|
||||
.name = "cros_ec_ishtp",
|
||||
.guid = &cros_ish_guid,
|
||||
.id = cros_ec_ishtp_id_table,
|
||||
.probe = cros_ec_ishtp_probe,
|
||||
.remove = cros_ec_ishtp_remove,
|
||||
.reset = cros_ec_ishtp_reset,
|
||||
@ -791,4 +794,3 @@ MODULE_DESCRIPTION("ChromeOS EC ISHTP Client Driver");
|
||||
MODULE_AUTHOR("Rushikesh S Kadam <rushikesh.s.kadam@intel.com>");
|
||||
|
||||
MODULE_LICENSE("GPL v2");
|
||||
MODULE_ALIAS("ishtp:*");
|
||||
|
@ -93,9 +93,12 @@ struct ishtp_opregion_dev {
|
||||
};
|
||||
|
||||
/* eclite ishtp client UUID: 6a19cc4b-d760-4de3-b14d-f25ebd0fbcd9 */
|
||||
static const guid_t ecl_ishtp_guid =
|
||||
GUID_INIT(0x6a19cc4b, 0xd760, 0x4de3,
|
||||
0xb1, 0x4d, 0xf2, 0x5e, 0xbd, 0xf, 0xbc, 0xd9);
|
||||
static const struct ishtp_device_id ecl_ishtp_id_table[] = {
|
||||
{ .guid = GUID_INIT(0x6a19cc4b, 0xd760, 0x4de3,
|
||||
0xb1, 0x4d, 0xf2, 0x5e, 0xbd, 0xf, 0xbc, 0xd9), },
|
||||
{ }
|
||||
};
|
||||
MODULE_DEVICE_TABLE(ishtp, ecl_ishtp_id_table);
|
||||
|
||||
/* ACPI DSM UUID: 91d936a7-1f01-49c6-a6b4-72f00ad8d8a5 */
|
||||
static const guid_t ecl_acpi_guid =
|
||||
@ -462,7 +465,7 @@ static int ecl_ishtp_cl_init(struct ishtp_cl *ecl_ishtp_cl)
|
||||
ishtp_set_tx_ring_size(ecl_ishtp_cl, ECL_CL_TX_RING_SIZE);
|
||||
ishtp_set_rx_ring_size(ecl_ishtp_cl, ECL_CL_RX_RING_SIZE);
|
||||
|
||||
fw_client = ishtp_fw_cl_get_client(dev, &ecl_ishtp_guid);
|
||||
fw_client = ishtp_fw_cl_get_client(dev, &ecl_ishtp_id_table[0].guid);
|
||||
if (!fw_client) {
|
||||
dev_err(cl_data_to_dev(opr_dev), "fw client not found\n");
|
||||
return -ENOENT;
|
||||
@ -674,7 +677,7 @@ static const struct dev_pm_ops ecl_ishtp_pm_ops = {
|
||||
|
||||
static struct ishtp_cl_driver ecl_ishtp_cl_driver = {
|
||||
.name = "ishtp-eclite",
|
||||
.guid = &ecl_ishtp_guid,
|
||||
.id = ecl_ishtp_id_table,
|
||||
.probe = ecl_ishtp_cl_probe,
|
||||
.remove = ecl_ishtp_cl_remove,
|
||||
.reset = ecl_ishtp_cl_reset,
|
||||
@ -698,4 +701,3 @@ MODULE_DESCRIPTION("ISH ISHTP eclite client opregion driver");
|
||||
MODULE_AUTHOR("K Naduvalath, Sumesh <sumesh.k.naduvalath@intel.com>");
|
||||
|
||||
MODULE_LICENSE("GPL v2");
|
||||
MODULE_ALIAS("ishtp:*");
|
||||
|
@ -9,7 +9,7 @@
|
||||
#define _INTEL_ISH_CLIENT_IF_H_
|
||||
|
||||
#include <linux/device.h>
|
||||
#include <linux/uuid.h>
|
||||
#include <linux/mod_devicetable.h>
|
||||
|
||||
struct ishtp_cl_device;
|
||||
struct ishtp_device;
|
||||
@ -40,7 +40,7 @@ enum cl_state {
|
||||
struct ishtp_cl_driver {
|
||||
struct device_driver driver;
|
||||
const char *name;
|
||||
const guid_t *guid;
|
||||
const struct ishtp_device_id *id;
|
||||
int (*probe)(struct ishtp_cl_device *dev);
|
||||
void (*remove)(struct ishtp_cl_device *dev);
|
||||
int (*reset)(struct ishtp_cl_device *dev);
|
||||
|
@ -895,4 +895,18 @@ struct dfl_device_id {
|
||||
kernel_ulong_t driver_data;
|
||||
};
|
||||
|
||||
/* ISHTP (Integrated Sensor Hub Transport Protocol) */
|
||||
|
||||
#define ISHTP_MODULE_PREFIX "ishtp:"
|
||||
|
||||
/**
|
||||
* struct ishtp_device_id - ISHTP device identifier
|
||||
* @guid: GUID of the device.
|
||||
* @driver_data: pointer to driver specific data
|
||||
*/
|
||||
struct ishtp_device_id {
|
||||
guid_t guid;
|
||||
kernel_ulong_t driver_data;
|
||||
};
|
||||
|
||||
#endif /* LINUX_MOD_DEVICETABLE_H */
|
||||
|
@ -259,5 +259,8 @@ int main(void)
|
||||
DEVID_FIELD(dfl_device_id, type);
|
||||
DEVID_FIELD(dfl_device_id, feature_id);
|
||||
|
||||
DEVID(ishtp_device_id);
|
||||
DEVID_FIELD(ishtp_device_id, guid);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -115,6 +115,17 @@ static inline void add_uuid(char *str, uuid_le uuid)
|
||||
uuid.b[12], uuid.b[13], uuid.b[14], uuid.b[15]);
|
||||
}
|
||||
|
||||
static inline void add_guid(char *str, guid_t guid)
|
||||
{
|
||||
int len = strlen(str);
|
||||
|
||||
sprintf(str + len, "%02X%02X%02X%02X-%02X%02X-%02X%02X-%02X%02X-%02X%02X%02X%02X%02X%02X",
|
||||
guid.b[3], guid.b[2], guid.b[1], guid.b[0],
|
||||
guid.b[5], guid.b[4], guid.b[7], guid.b[6],
|
||||
guid.b[8], guid.b[9], guid.b[10], guid.b[11],
|
||||
guid.b[12], guid.b[13], guid.b[14], guid.b[15]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Check that sizeof(device_id type) are consistent with size of section
|
||||
* in .o file. If in-consistent then userspace and kernel does not agree
|
||||
@ -1380,6 +1391,18 @@ static int do_mhi_entry(const char *filename, void *symval, char *alias)
|
||||
return 1;
|
||||
}
|
||||
|
||||
/* Looks like: ishtp:{guid} */
|
||||
static int do_ishtp_entry(const char *filename, void *symval, char *alias)
|
||||
{
|
||||
DEF_FIELD(symval, ishtp_device_id, guid);
|
||||
|
||||
strcpy(alias, ISHTP_MODULE_PREFIX "{");
|
||||
add_guid(alias, guid);
|
||||
strcat(alias, "}");
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int do_auxiliary_entry(const char *filename, void *symval, char *alias)
|
||||
{
|
||||
DEF_FIELD_ADDR(symval, auxiliary_device_id, name);
|
||||
@ -1499,6 +1522,7 @@ static const struct devtable devtable[] = {
|
||||
{"auxiliary", SIZE_auxiliary_device_id, do_auxiliary_entry},
|
||||
{"ssam", SIZE_ssam_device_id, do_ssam_entry},
|
||||
{"dfl", SIZE_dfl_device_id, do_dfl_entry},
|
||||
{"ishtp", SIZE_ishtp_device_id, do_ishtp_entry},
|
||||
};
|
||||
|
||||
/* Create MODULE_ALIAS() statements.
|
||||
|
Loading…
x
Reference in New Issue
Block a user