123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- /*
- * Gadget Function Driver for Android USB accessories
- *
- * Copyright (C) 2011 Google, Inc.
- * Author: Mike Lockwood <lockwood@android.com>
- *
- * This software is licensed under the terms of the GNU General Public
- * License version 2, as published by the Free Software Foundation, and
- * may be copied, distributed, and modified under those terms.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- */
- #ifndef __LINUX_USB_F_ACCESSORY_H
- #define __LINUX_USB_F_ACCESSORY_H
- /* Use Google Vendor ID when in accessory mode */
- #define USB_ACCESSORY_VENDOR_ID 0x18D1
- /* Product ID to use when in accessory mode */
- #define USB_ACCESSORY_PRODUCT_ID 0x2D00
- /* Product ID to use when in accessory mode and adb is enabled */
- #define USB_ACCESSORY_ADB_PRODUCT_ID 0x2D01
- /* Indexes for strings sent by the host via ACCESSORY_SEND_STRING */
- #define ACCESSORY_STRING_MANUFACTURER 0
- #define ACCESSORY_STRING_MODEL 1
- #define ACCESSORY_STRING_DESCRIPTION 2
- #define ACCESSORY_STRING_VERSION 3
- #define ACCESSORY_STRING_URI 4
- #define ACCESSORY_STRING_SERIAL 5
- /* Control request for retrieving device's protocol version
- *
- * requestType: USB_DIR_IN | USB_TYPE_VENDOR
- * request: ACCESSORY_GET_PROTOCOL
- * value: 0
- * index: 0
- * data version number (16 bits little endian)
- * 1 for original accessory support
- * 2 adds HID and device to host audio support
- */
- #define ACCESSORY_GET_PROTOCOL 51
- /* Control request for host to send a string to the device
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_SEND_STRING
- * value: 0
- * index: string ID
- * data zero terminated UTF8 string
- *
- * The device can later retrieve these strings via the
- * ACCESSORY_GET_STRING_* ioctls
- */
- #define ACCESSORY_SEND_STRING 52
- /* Control request for starting device in accessory mode.
- * The host sends this after setting all its strings to the device.
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_START
- * value: 0
- * index: 0
- * data none
- */
- #define ACCESSORY_START 53
- /* Control request for registering a HID device.
- * Upon registering, a unique ID is sent by the accessory in the
- * value parameter. This ID will be used for future commands for
- * the device
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_REGISTER_HID_DEVICE
- * value: Accessory assigned ID for the HID device
- * index: total length of the HID report descriptor
- * data none
- */
- #define ACCESSORY_REGISTER_HID 54
- /* Control request for unregistering a HID device.
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_REGISTER_HID
- * value: Accessory assigned ID for the HID device
- * index: 0
- * data none
- */
- #define ACCESSORY_UNREGISTER_HID 55
- /* Control request for sending the HID report descriptor.
- * If the HID descriptor is longer than the endpoint zero max packet size,
- * the descriptor will be sent in multiple ACCESSORY_SET_HID_REPORT_DESC
- * commands. The data for the descriptor must be sent sequentially
- * if multiple packets are needed.
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_SET_HID_REPORT_DESC
- * value: Accessory assigned ID for the HID device
- * index: offset of data in descriptor
- * (needed when HID descriptor is too big for one packet)
- * data the HID report descriptor
- */
- #define ACCESSORY_SET_HID_REPORT_DESC 56
- /* Control request for sending HID events.
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_SEND_HID_EVENT
- * value: Accessory assigned ID for the HID device
- * index: 0
- * data the HID report for the event
- */
- #define ACCESSORY_SEND_HID_EVENT 57
- /* Control request for setting the audio mode.
- *
- * requestType: USB_DIR_OUT | USB_TYPE_VENDOR
- * request: ACCESSORY_SET_AUDIO_MODE
- * value: 0 - no audio
- * 1 - device to host, 44100 16-bit stereo PCM
- * index: 0
- * data none
- */
- #define ACCESSORY_SET_AUDIO_MODE 58
- /* ioctls for retrieving strings set by the host */
- #define ACCESSORY_GET_STRING_MANUFACTURER _IOW('M', 1, char[256])
- #define ACCESSORY_GET_STRING_MODEL _IOW('M', 2, char[256])
- #define ACCESSORY_GET_STRING_DESCRIPTION _IOW('M', 3, char[256])
- #define ACCESSORY_GET_STRING_VERSION _IOW('M', 4, char[256])
- #define ACCESSORY_GET_STRING_URI _IOW('M', 5, char[256])
- #define ACCESSORY_GET_STRING_SERIAL _IOW('M', 6, char[256])
- /* returns 1 if there is a start request pending */
- #define ACCESSORY_IS_START_REQUESTED _IO('M', 7)
- /* returns audio mode (set via the ACCESSORY_SET_AUDIO_MODE control request) */
- #define ACCESSORY_GET_AUDIO_MODE _IO('M', 8)
- #endif /* __LINUX_USB_F_ACCESSORY_H */
|