/* * HID over I2C protocol implementation * * Copyright (c) 2012 Benjamin Tissoires <benjamin.tissoires@gmail.com> * Copyright (c) 2012 Ecole Nationale de l'Aviation Civile, France * * This file is subject to the terms and conditions of the GNU General Public * License. See the file COPYING in the main directory of this archive for * more details. */ #ifndef __LINUX_I2C_HID_H #define __LINUX_I2C_HID_H #include <linux/regulator/consumer.h> #include <linux/types.h> /** * struct i2chid_platform_data - used by hid over i2c implementation. * @hid_descriptor_address: i2c register where the HID descriptor is stored. * @supplies: regulators for powering on the device. * @post_power_delay_ms: delay after powering on before device is usable. * * Note that it is the responsibility of the platform driver (or the acpi 5.0 * driver, or the flattened device tree) to setup the irq related to the gpio in * the struct i2c_board_info. * The platform driver should also setup the gpio according to the device: * * A typical example is the following: * irq = gpio_to_irq(intr_gpio); * hkdk4412_i2c_devs5[0].irq = irq; // store the irq in i2c_board_info * gpio_request(intr_gpio, "elan-irq"); * s3c_gpio_setpull(intr_gpio, S3C_GPIO_PULL_UP); */ struct i2c_hid_platform_data { u16 hid_descriptor_address; struct regulator_bulk_data supplies[2]; int post_power_delay_ms; }; #endif /* __LINUX_I2C_HID_H */ |