2 * Gadget Function Driver for Android USB accessories
4 * Copyright (C) 2011 Google, Inc.
5 * Author: Mike Lockwood <lockwood@android.com>
7 * This software is licensed under the terms of the GNU General Public
8 * License version 2, as published by the Free Software Foundation, and
9 * may be copied, distributed, and modified under those terms.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
18 #ifndef __LINUX_USB_F_ACCESSORY_H
19 #define __LINUX_USB_F_ACCESSORY_H
21 /* Use Google Vendor ID when in accessory mode */
22 #define USB_ACCESSORY_VENDOR_ID 0x18D1
25 /* Product ID to use when in accessory mode */
26 #define USB_ACCESSORY_PRODUCT_ID 0x2D00
28 /* Product ID to use when in accessory mode and adb is enabled */
29 #define USB_ACCESSORY_ADB_PRODUCT_ID 0x2D01
31 /* Indexes for strings sent by the host via ACCESSORY_SEND_STRING */
32 #define ACCESSORY_STRING_MANUFACTURER 0
33 #define ACCESSORY_STRING_MODEL 1
34 #define ACCESSORY_STRING_DESCRIPTION 2
35 #define ACCESSORY_STRING_VERSION 3
36 #define ACCESSORY_STRING_URI 4
37 #define ACCESSORY_STRING_SERIAL 5
39 /* Control request for retrieving device's protocol version
41 * requestType: USB_DIR_IN | USB_TYPE_VENDOR
42 * request: ACCESSORY_GET_PROTOCOL
45 * data version number (16 bits little endian)
46 * 1 for original accessory support
47 * 2 adds HID and device to host audio support
49 #define ACCESSORY_GET_PROTOCOL 51
51 /* Control request for host to send a string to the device
53 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
54 * request: ACCESSORY_SEND_STRING
57 * data zero terminated UTF8 string
59 * The device can later retrieve these strings via the
60 * ACCESSORY_GET_STRING_* ioctls
62 #define ACCESSORY_SEND_STRING 52
64 /* Control request for starting device in accessory mode.
65 * The host sends this after setting all its strings to the device.
67 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
68 * request: ACCESSORY_START
73 #define ACCESSORY_START 53
75 /* Control request for registering a HID device.
76 * Upon registering, a unique ID is sent by the accessory in the
77 * value parameter. This ID will be used for future commands for
80 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
81 * request: ACCESSORY_REGISTER_HID_DEVICE
82 * value: Accessory assigned ID for the HID device
83 * index: total length of the HID report descriptor
86 #define ACCESSORY_REGISTER_HID 54
88 /* Control request for unregistering a HID device.
90 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
91 * request: ACCESSORY_REGISTER_HID
92 * value: Accessory assigned ID for the HID device
96 #define ACCESSORY_UNREGISTER_HID 55
98 /* Control request for sending the HID report descriptor.
99 * If the HID descriptor is longer than the endpoint zero max packet size,
100 * the descriptor will be sent in multiple ACCESSORY_SET_HID_REPORT_DESC
101 * commands. The data for the descriptor must be sent sequentially
102 * if multiple packets are needed.
104 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
105 * request: ACCESSORY_SET_HID_REPORT_DESC
106 * value: Accessory assigned ID for the HID device
107 * index: offset of data in descriptor
108 * (needed when HID descriptor is too big for one packet)
109 * data the HID report descriptor
111 #define ACCESSORY_SET_HID_REPORT_DESC 56
113 /* Control request for sending HID events.
115 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
116 * request: ACCESSORY_SEND_HID_EVENT
117 * value: Accessory assigned ID for the HID device
119 * data the HID report for the event
121 #define ACCESSORY_SEND_HID_EVENT 57
123 /* Control request for setting the audio mode.
125 * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
126 * request: ACCESSORY_SET_AUDIO_MODE
127 * value: 0 - no audio
128 * 1 - device to host, 44100 16-bit stereo PCM
132 #define ACCESSORY_SET_AUDIO_MODE 58
134 /* ioctls for retrieving strings set by the host */
135 #define ACCESSORY_GET_STRING_MANUFACTURER _IOW('M', 1, char[256])
136 #define ACCESSORY_GET_STRING_MODEL _IOW('M', 2, char[256])
137 #define ACCESSORY_GET_STRING_DESCRIPTION _IOW('M', 3, char[256])
138 #define ACCESSORY_GET_STRING_VERSION _IOW('M', 4, char[256])
139 #define ACCESSORY_GET_STRING_URI _IOW('M', 5, char[256])
140 #define ACCESSORY_GET_STRING_SERIAL _IOW('M', 6, char[256])
141 /* returns 1 if there is a start request pending */
142 #define ACCESSORY_IS_START_REQUESTED _IO('M', 7)
143 /* returns audio mode (set via the ACCESSORY_SET_AUDIO_MODE control request) */
144 #define ACCESSORY_GET_AUDIO_MODE _IO('M', 8)
146 #endif /* __LINUX_USB_F_ACCESSORY_H */