#include <linux/device.h>
#include <linux/hid.h>
#include <linux/module.h>
#include <linux/slab.h>
#include <linux/input/mt.h>
#include <linux/jiffies.h>
#include <linux/string.h>
#include <linux/timer.h>
MODULE_AUTHOR(…) …;
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;
#include "hid-ids.h"
#define MT_QUIRK_NOT_SEEN_MEANS_UP …
#define MT_QUIRK_SLOT_IS_CONTACTID …
#define MT_QUIRK_CYPRESS …
#define MT_QUIRK_SLOT_IS_CONTACTNUMBER …
#define MT_QUIRK_ALWAYS_VALID …
#define MT_QUIRK_VALID_IS_INRANGE …
#define MT_QUIRK_VALID_IS_CONFIDENCE …
#define MT_QUIRK_CONFIDENCE …
#define MT_QUIRK_SLOT_IS_CONTACTID_MINUS_ONE …
#define MT_QUIRK_NO_AREA …
#define MT_QUIRK_IGNORE_DUPLICATES …
#define MT_QUIRK_HOVERING …
#define MT_QUIRK_CONTACT_CNT_ACCURATE …
#define MT_QUIRK_FORCE_GET_FEATURE …
#define MT_QUIRK_FIX_CONST_CONTACT_ID …
#define MT_QUIRK_TOUCH_SIZE_SCALING …
#define MT_QUIRK_STICKY_FINGERS …
#define MT_QUIRK_ASUS_CUSTOM_UP …
#define MT_QUIRK_WIN8_PTP_BUTTONS …
#define MT_QUIRK_SEPARATE_APP_REPORT …
#define MT_QUIRK_FORCE_MULTI_INPUT …
#define MT_QUIRK_DISABLE_WAKEUP …
#define MT_QUIRK_ORIENTATION_INVERT …
#define MT_INPUTMODE_TOUCHSCREEN …
#define MT_INPUTMODE_TOUCHPAD …
#define MT_BUTTONTYPE_CLICKPAD …
enum latency_mode { … };
#define MT_IO_FLAGS_RUNNING …
#define MT_IO_FLAGS_ACTIVE_SLOTS …
#define MT_IO_FLAGS_PENDING_SLOTS …
static const bool mtrue = …;
static const bool mfalse;
static const __s32 mzero;
#define DEFAULT_TRUE …
#define DEFAULT_FALSE …
#define DEFAULT_ZERO …
struct mt_usages { … };
struct mt_application { … };
struct mt_class { … };
struct mt_report_data { … };
struct mt_device { … };
static void mt_post_parse_default_settings(struct mt_device *td,
struct mt_application *app);
static void mt_post_parse(struct mt_device *td, struct mt_application *app);
#define MT_CLS_DEFAULT …
#define MT_CLS_SERIAL …
#define MT_CLS_CONFIDENCE …
#define MT_CLS_CONFIDENCE_CONTACT_ID …
#define MT_CLS_CONFIDENCE_MINUS_ONE …
#define MT_CLS_DUAL_INRANGE_CONTACTID …
#define MT_CLS_DUAL_INRANGE_CONTACTNUMBER …
#define MT_CLS_INRANGE_CONTACTNUMBER …
#define MT_CLS_NSMU …
#define MT_CLS_WIN_8 …
#define MT_CLS_EXPORT_ALL_INPUTS …
#define MT_CLS_WIN_8_FORCE_MULTI_INPUT …
#define MT_CLS_WIN_8_DISABLE_WAKEUP …
#define MT_CLS_WIN_8_NO_STICKY_FINGERS …
#define MT_CLS_WIN_8_FORCE_MULTI_INPUT_NSMU …
#define MT_CLS_3M …
#define MT_CLS_EGALAX …
#define MT_CLS_EGALAX_SERIAL …
#define MT_CLS_TOPSEED …
#define MT_CLS_PANASONIC …
#define MT_CLS_FLATFROG …
#define MT_CLS_GENERALTOUCH_TWOFINGERS …
#define MT_CLS_GENERALTOUCH_PWT_TENFINGERS …
#define MT_CLS_LG …
#define MT_CLS_ASUS …
#define MT_CLS_VTL …
#define MT_CLS_GOOGLE …
#define MT_CLS_RAZER_BLADE_STEALTH …
#define MT_CLS_SMART_TECH …
#define MT_CLS_SIS …
#define MT_DEFAULT_MAXCONTACT …
#define MT_MAX_MAXCONTACT …
#define MAX_TIMESTAMP_INTERVAL …
#define MT_USB_DEVICE(v, p) …
#define MT_BT_DEVICE(v, p) …
static int cypress_compute_slot(struct mt_application *application,
struct mt_usages *slot)
{ … }
static const struct mt_class mt_classes[] = …;
static ssize_t mt_show_quirks(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t mt_set_quirks(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t count)
{ … }
static DEVICE_ATTR(quirks, S_IWUSR | S_IRUGO, mt_show_quirks, mt_set_quirks);
static struct attribute *sysfs_attrs[] = …;
static const struct attribute_group mt_attribute_group = …;
static void mt_get_feature(struct hid_device *hdev, struct hid_report *report)
{ … }
static void mt_feature_mapping(struct hid_device *hdev,
struct hid_field *field, struct hid_usage *usage)
{ … }
static void set_abs(struct input_dev *input, unsigned int code,
struct hid_field *field, int snratio)
{ … }
static struct mt_usages *mt_allocate_usage(struct hid_device *hdev,
struct mt_application *application)
{ … }
static struct mt_application *mt_allocate_application(struct mt_device *td,
struct hid_report *report)
{ … }
static struct mt_application *mt_find_application(struct mt_device *td,
struct hid_report *report)
{ … }
static struct mt_report_data *mt_allocate_report_data(struct mt_device *td,
struct hid_report *report)
{ … }
static struct mt_report_data *mt_find_report_data(struct mt_device *td,
struct hid_report *report)
{ … }
static void mt_store_field(struct hid_device *hdev,
struct mt_application *application,
__s32 *value,
size_t offset)
{ … }
#define MT_STORE_FIELD(__name) …
static int mt_touch_input_mapping(struct hid_device *hdev, struct hid_input *hi,
struct hid_field *field, struct hid_usage *usage,
unsigned long **bit, int *max, struct mt_application *app)
{ … }
static int mt_compute_slot(struct mt_device *td, struct mt_application *app,
struct mt_usages *slot,
struct input_dev *input)
{ … }
static void mt_release_pending_palms(struct mt_device *td,
struct mt_application *app,
struct input_dev *input)
{ … }
static void mt_sync_frame(struct mt_device *td, struct mt_application *app,
struct input_dev *input)
{ … }
static int mt_compute_timestamp(struct mt_application *app, __s32 value)
{ … }
static int mt_touch_event(struct hid_device *hid, struct hid_field *field,
struct hid_usage *usage, __s32 value)
{ … }
static int mt_process_slot(struct mt_device *td, struct input_dev *input,
struct mt_application *app,
struct mt_usages *slot)
{ … }
static void mt_process_mt_event(struct hid_device *hid,
struct mt_application *app,
struct hid_field *field,
struct hid_usage *usage,
__s32 value,
bool first_packet)
{ … }
static void mt_touch_report(struct hid_device *hid,
struct mt_report_data *rdata)
{ … }
static int mt_touch_input_configured(struct hid_device *hdev,
struct hid_input *hi,
struct mt_application *app)
{ … }
#define mt_map_key_clear(c) …
static int mt_input_mapping(struct hid_device *hdev, struct hid_input *hi,
struct hid_field *field, struct hid_usage *usage,
unsigned long **bit, int *max)
{ … }
static int mt_input_mapped(struct hid_device *hdev, struct hid_input *hi,
struct hid_field *field, struct hid_usage *usage,
unsigned long **bit, int *max)
{ … }
static int mt_event(struct hid_device *hid, struct hid_field *field,
struct hid_usage *usage, __s32 value)
{ … }
static const __u8 *mt_report_fixup(struct hid_device *hdev, __u8 *rdesc,
unsigned int *size)
{ … }
static void mt_report(struct hid_device *hid, struct hid_report *report)
{ … }
static bool mt_need_to_apply_feature(struct hid_device *hdev,
struct hid_field *field,
struct hid_usage *usage,
enum latency_mode latency,
bool surface_switch,
bool button_switch,
bool *inputmode_found)
{ … }
static void mt_set_modes(struct hid_device *hdev, enum latency_mode latency,
bool surface_switch, bool button_switch)
{ … }
static void mt_post_parse_default_settings(struct mt_device *td,
struct mt_application *app)
{ … }
static void mt_post_parse(struct mt_device *td, struct mt_application *app)
{ … }
static int mt_input_configured(struct hid_device *hdev, struct hid_input *hi)
{ … }
static void mt_fix_const_field(struct hid_field *field, unsigned int usage)
{ … }
static void mt_fix_const_fields(struct hid_device *hdev, unsigned int usage)
{ … }
static void mt_release_contacts(struct hid_device *hid)
{ … }
static void mt_expired_timeout(struct timer_list *t)
{ … }
static int mt_probe(struct hid_device *hdev, const struct hid_device_id *id)
{ … }
static int mt_suspend(struct hid_device *hdev, pm_message_t state)
{ … }
static int mt_reset_resume(struct hid_device *hdev)
{ … }
static int mt_resume(struct hid_device *hdev)
{ … }
static void mt_remove(struct hid_device *hdev)
{ … }
static const struct hid_device_id mt_devices[] = …;
MODULE_DEVICE_TABLE(hid, mt_devices);
static const struct hid_usage_id mt_grabbed_usages[] = …;
static struct hid_driver mt_driver = …;
module_hid_driver(…) …;