blob: 1fb088239d12b9f4a5a849a2ce662343743c8bd9 [file] [log] [blame]
Benjamin Tissoires4a200c32012-11-12 15:42:59 +01001/*
2 * HID over I2C protocol implementation
3 *
4 * Copyright (c) 2012 Benjamin Tissoires <benjamin.tissoires@gmail.com>
5 * Copyright (c) 2012 Ecole Nationale de l'Aviation Civile, France
6 *
7 * This file is subject to the terms and conditions of the GNU General Public
8 * License. See the file COPYING in the main directory of this archive for
9 * more details.
10 */
11
12#ifndef __LINUX_I2C_HID_H
13#define __LINUX_I2C_HID_H
14
15#include <linux/types.h>
16
Brian Norris572d3c62017-02-09 18:03:57 -080017struct regulator;
18
Benjamin Tissoires4a200c32012-11-12 15:42:59 +010019/**
20 * struct i2chid_platform_data - used by hid over i2c implementation.
21 * @hid_descriptor_address: i2c register where the HID descriptor is stored.
Brian Norris572d3c62017-02-09 18:03:57 -080022 * @supply: regulator for powering on the device.
23 * @post_power_delay_ms: delay after powering on before device is usable.
Benjamin Tissoires4a200c32012-11-12 15:42:59 +010024 *
25 * Note that it is the responsibility of the platform driver (or the acpi 5.0
Benjamin Tissoires3d7d2482013-06-13 09:50:35 +020026 * driver, or the flattened device tree) to setup the irq related to the gpio in
27 * the struct i2c_board_info.
Benjamin Tissoires4a200c32012-11-12 15:42:59 +010028 * The platform driver should also setup the gpio according to the device:
29 *
30 * A typical example is the following:
31 * irq = gpio_to_irq(intr_gpio);
32 * hkdk4412_i2c_devs5[0].irq = irq; // store the irq in i2c_board_info
33 * gpio_request(intr_gpio, "elan-irq");
34 * s3c_gpio_setpull(intr_gpio, S3C_GPIO_PULL_UP);
35 */
36struct i2c_hid_platform_data {
37 u16 hid_descriptor_address;
Brian Norris572d3c62017-02-09 18:03:57 -080038 struct regulator *supply;
39 int post_power_delay_ms;
Benjamin Tissoires4a200c32012-11-12 15:42:59 +010040};
41
42#endif /* __LINUX_I2C_HID_H */