usb_core.h revision 190174
1/* $FreeBSD: head/sys/dev/usb/usb_core.h 190174 2009-03-20 19:04:31Z thompsa $ */ 2/*- 3 * Copyright (c) 2008 Hans Petter Selasky. All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 */ 26 27/* 28 * Including this file is mandatory for all USB related c-files in the 29 * kernel. 30 */ 31 32#ifndef _USB2_CORE_H_ 33#define _USB2_CORE_H_ 34 35/* Default USB configuration */ 36 37#ifndef USB_USE_CONDVAR 38#define USB_USE_CONDVAR 0 39#endif 40 41#ifndef USB_HAVE_UGEN 42#define USB_HAVE_UGEN 1 43#endif 44 45#ifndef USB_TD_GET_PROC 46#define USB_TD_GET_PROC(td) (td)->td_proc 47#endif 48 49#ifndef USB_PROC_GET_GID 50#define USB_PROC_GET_GID(td) (td)->p_pgid 51#endif 52 53/* Include files */ 54 55#include <sys/stdint.h> 56#include <sys/stddef.h> 57#include <sys/param.h> 58#include <sys/queue.h> 59#include <sys/types.h> 60#include <sys/systm.h> 61#include <sys/kernel.h> 62#include <sys/bus.h> 63#include <sys/linker_set.h> 64#include <sys/module.h> 65#include <sys/lock.h> 66#include <sys/mutex.h> 67#include <sys/condvar.h> 68#include <sys/sysctl.h> 69#include <sys/sx.h> 70#include <sys/unistd.h> 71#include <sys/callout.h> 72#include <sys/malloc.h> 73#include <sys/priv.h> 74 75#include <dev/usb/usb_mfunc.h> 76#include <dev/usb/usb_revision.h> 77 78#include "usb_if.h" 79#include "opt_usb.h" 80#include "opt_bus.h" 81 82#define USB_STACK_VERSION 2000 /* 2.0 */ 83 84#define USB_HOST_ALIGN 8 /* bytes, must be power of two */ 85 86#define USB_ISOC_TIME_MAX 128 /* ms */ 87#define USB_FS_ISOC_UFRAME_MAX 4 /* exclusive unit */ 88 89#if (USB_FS_ISOC_UFRAME_MAX > 6) 90#error "USB_FS_ISOC_UFRAME_MAX cannot be set higher than 6" 91#endif 92 93#define USB_MAX_FS_ISOC_FRAMES_PER_XFER (120) /* units */ 94#define USB_MAX_HS_ISOC_FRAMES_PER_XFER (8*120) /* units */ 95 96#define USB_MAX_IPACKET 8 /* maximum size of the initial USB 97 * data packet */ 98#ifndef USB_VERBOSE 99#define USB_VERBOSE 1 100#endif 101 102#define USB_HUB_MAX_DEPTH 5 103 104/* USB transfer states */ 105 106#define USB_ST_SETUP 0 107#define USB_ST_TRANSFERRED 1 108#define USB_ST_ERROR 2 109 110/* 111 * The following macro will return the current state of an USB 112 * transfer like defined by the "USB_ST_XXX" enums. 113 */ 114#define USB_GET_STATE(xfer) ((xfer)->usb2_state) 115 116/* 117 * The following macro will tell if an USB transfer is currently 118 * receiving or transferring data. 119 */ 120#define USB_GET_DATA_ISREAD(xfer) (((xfer)->flags_int.usb2_mode == \ 121 USB_MODE_DEVICE) ? ((xfer->endpoint & UE_DIR_IN) ? 0 : 1) : \ 122 ((xfer->endpoint & UE_DIR_IN) ? 1 : 0)) 123 124/* 125 * The following macros are used used to convert milliseconds into 126 * HZ. We use 1024 instead of 1000 milliseconds per second to save a 127 * full division. 128 */ 129#define USB_MS_HZ 1024 130 131#define USB_MS_TO_TICKS(ms) \ 132 (((uint32_t)((((uint32_t)(ms)) * ((uint32_t)(hz))) + USB_MS_HZ - 1)) / USB_MS_HZ) 133 134/* macros */ 135 136#define usb2_callout_init_mtx(c,m,f) callout_init_mtx(&(c)->co,m,f) 137#define usb2_callout_reset(c,t,f,d) callout_reset(&(c)->co,t,f,d) 138#define usb2_callout_stop(c) callout_stop(&(c)->co) 139#define usb2_callout_drain(c) callout_drain(&(c)->co) 140#define usb2_callout_pending(c) callout_pending(&(c)->co) 141 142#define USB_BUS_LOCK(_b) mtx_lock(&(_b)->bus_mtx) 143#define USB_BUS_UNLOCK(_b) mtx_unlock(&(_b)->bus_mtx) 144#define USB_BUS_LOCK_ASSERT(_b, _t) mtx_assert(&(_b)->bus_mtx, _t) 145#define USB_XFER_LOCK(_x) mtx_lock((_x)->xroot->xfer_mtx) 146#define USB_XFER_UNLOCK(_x) mtx_unlock((_x)->xroot->xfer_mtx) 147#define USB_XFER_LOCK_ASSERT(_x, _t) mtx_assert((_x)->xroot->xfer_mtx, _t) 148/* structure prototypes */ 149 150struct file; 151struct usb2_bus; 152struct usb2_device; 153struct usb2_page; 154struct usb2_page_cache; 155struct usb2_xfer; 156struct usb2_xfer_root; 157 158/* typedefs */ 159 160typedef void (usb2_callback_t)(struct usb2_xfer *); 161 162#ifndef USB_HAVE_USB_ERROR_T 163typedef uint8_t usb2_error_t; /* see "USB_ERR_XXX" */ 164#endif 165 166#ifndef USB_HAVE_TIMEOUT_T 167typedef uint32_t usb2_timeout_t; /* milliseconds */ 168#endif 169 170#ifndef USB_HAVE_LENGTH_T 171typedef uint32_t usb2_length_t; /* bytes */ 172#endif 173 174#ifndef USB_HAVE_FRAMES_T 175typedef uint32_t usb2_frames_t; /* units */ 176#endif 177 178#ifndef USB_HAVE_INTERVAL_T 179typedef uint32_t usb2_interval_t; /* milliseconds */ 180#endif 181 182#ifndef USB_HAVE_SIZE_T 183typedef uint32_t usb2_size_t; /* bytes */ 184#endif 185 186#ifndef USB_HAVE_REFS_T 187typedef uint32_t usb2_refs_t; /* units */ 188#endif 189 190#ifndef USB_HAVE_TICKS_T 191typedef uint32_t usb2_ticks_t; /* system defined */ 192#endif 193 194/* structures */ 195 196/* 197 * Common queue structure for USB transfers. 198 */ 199struct usb2_xfer_queue { 200 TAILQ_HEAD(, usb2_xfer) head; 201 struct usb2_xfer *curr; /* current USB transfer processed */ 202 void (*command) (struct usb2_xfer_queue *pq); 203 uint8_t recurse_1:1; 204 uint8_t recurse_2:1; 205}; 206 207/* 208 * The following is a wrapper for the callout structure to ease 209 * porting the code to other platforms. 210 */ 211struct usb2_callout { 212 struct callout co; 213}; 214 215/* 216 * The following structure defines a set of USB transfer flags. 217 */ 218struct usb2_xfer_flags { 219 uint8_t force_short_xfer:1; /* force a short transmit transfer 220 * last */ 221 uint8_t short_xfer_ok:1; /* allow short receive transfers */ 222 uint8_t short_frames_ok:1; /* allow short frames */ 223 uint8_t pipe_bof:1; /* block pipe on failure */ 224 uint8_t proxy_buffer:1; /* makes buffer size a factor of 225 * "max_frame_size" */ 226 uint8_t ext_buffer:1; /* uses external DMA buffer */ 227 uint8_t manual_status:1; /* non automatic status stage on 228 * control transfers */ 229 uint8_t no_pipe_ok:1; /* set if "USB_ERR_NO_PIPE" error can 230 * be ignored */ 231 uint8_t stall_pipe:1; /* set if the endpoint belonging to 232 * this USB transfer should be stalled 233 * before starting this transfer! */ 234}; 235 236/* 237 * The following structure defines a set of internal USB transfer 238 * flags. 239 */ 240struct usb2_xfer_flags_int { 241 uint16_t control_rem; /* remainder in bytes */ 242 243 uint8_t open:1; /* set if USB pipe has been opened */ 244 uint8_t transferring:1; /* set if an USB transfer is in 245 * progress */ 246 uint8_t did_dma_delay:1; /* set if we waited for HW DMA */ 247 uint8_t did_close:1; /* set if we closed the USB transfer */ 248 uint8_t draining:1; /* set if we are draining an USB 249 * transfer */ 250 uint8_t started:1; /* keeps track of started or stopped */ 251 uint8_t bandwidth_reclaimed:1; 252 uint8_t control_xfr:1; /* set if control transfer */ 253 uint8_t control_hdr:1; /* set if control header should be 254 * sent */ 255 uint8_t control_act:1; /* set if control transfer is active */ 256 257 uint8_t short_frames_ok:1; /* filtered version */ 258 uint8_t short_xfer_ok:1; /* filtered version */ 259 uint8_t bdma_enable:1; /* filtered version (only set if 260 * hardware supports DMA) */ 261 uint8_t bdma_no_post_sync:1; /* set if the USB callback wrapper 262 * should not do the BUS-DMA post sync 263 * operation */ 264 uint8_t bdma_setup:1; /* set if BUS-DMA has been setup */ 265 uint8_t isochronous_xfr:1; /* set if isochronous transfer */ 266 uint8_t usb2_mode:1; /* shadow copy of "udev->usb2_mode" */ 267 uint8_t curr_dma_set:1; /* used by USB HC/DC driver */ 268 uint8_t can_cancel_immed:1; /* set if USB transfer can be 269 * cancelled immediately */ 270}; 271 272/* 273 * The following structure defines the symmetric part of an USB config 274 * structure. 275 */ 276struct usb2_config_sub { 277 usb2_callback_t *callback; /* USB transfer callback */ 278 uint32_t bufsize; /* total pipe buffer size in bytes */ 279 uint32_t frames; /* maximum number of USB frames */ 280 uint16_t interval; /* interval in milliseconds */ 281#define USB_DEFAULT_INTERVAL 0 282 uint16_t timeout; /* transfer timeout in milliseconds */ 283 struct usb2_xfer_flags flags; /* transfer flags */ 284}; 285 286/* 287 * The following structure define an USB configuration, that basically 288 * is used when setting up an USB transfer. 289 */ 290struct usb2_config { 291 struct usb2_config_sub mh; /* parameters for USB_MODE_HOST */ 292 struct usb2_config_sub md; /* parameters for USB_MODE_DEVICE */ 293 uint8_t type; /* pipe type */ 294 uint8_t endpoint; /* pipe number */ 295 uint8_t direction; /* pipe direction */ 296 uint8_t ep_index; /* pipe index match to use */ 297 uint8_t if_index; /* "ifaces" index to use */ 298}; 299 300/* 301 * The following structure defines an USB transfer. 302 */ 303struct usb2_xfer { 304 struct usb2_callout timeout_handle; 305 TAILQ_ENTRY(usb2_xfer) wait_entry; /* used at various places */ 306 307 struct usb2_page_cache *buf_fixup; /* fixup buffer(s) */ 308 struct usb2_xfer_queue *wait_queue; /* pointer to queue that we 309 * are waiting on */ 310 struct usb2_page *dma_page_ptr; 311 struct usb2_pipe *pipe; /* our USB pipe */ 312 struct usb2_xfer_root *xroot; /* used by HC driver */ 313 void *qh_start[2]; /* used by HC driver */ 314 void *td_start[2]; /* used by HC driver */ 315 void *td_transfer_first; /* used by HC driver */ 316 void *td_transfer_last; /* used by HC driver */ 317 void *td_transfer_cache; /* used by HC driver */ 318 void *priv_sc; /* device driver data pointer 1 */ 319 void *priv_fifo; /* device driver data pointer 2 */ 320 void *local_buffer; 321 uint32_t *frlengths; 322 struct usb2_page_cache *frbuffers; 323 usb2_callback_t *callback; 324 325 uint32_t max_usb2_frame_size; 326 uint32_t max_data_length; 327 uint32_t sumlen; /* sum of all lengths in bytes */ 328 uint32_t actlen; /* actual length in bytes */ 329 uint32_t timeout; /* milliseconds */ 330#define USB_NO_TIMEOUT 0 331#define USB_DEFAULT_TIMEOUT 5000 /* 5000 ms = 5 seconds */ 332 333 uint32_t max_frame_count; /* initial value of "nframes" after 334 * setup */ 335 uint32_t nframes; /* number of USB frames to transfer */ 336 uint32_t aframes; /* actual number of USB frames 337 * transferred */ 338 339 uint16_t max_packet_size; 340 uint16_t max_frame_size; 341 uint16_t qh_pos; 342 uint16_t isoc_time_complete; /* in ms */ 343 uint16_t interval; /* milliseconds */ 344 345 uint8_t address; /* physical USB address */ 346 uint8_t endpoint; /* physical USB endpoint */ 347 uint8_t max_packet_count; 348 uint8_t usb2_smask; 349 uint8_t usb2_cmask; 350 uint8_t usb2_uframe; 351 uint8_t usb2_state; 352 353 usb2_error_t error; 354 355 struct usb2_xfer_flags flags; 356 struct usb2_xfer_flags_int flags_int; 357}; 358 359/* 360 * The following structure keeps information that is used to match 361 * against an array of "usb2_device_id" elements. 362 */ 363struct usb2_lookup_info { 364 uint16_t idVendor; 365 uint16_t idProduct; 366 uint16_t bcdDevice; 367 uint8_t bDeviceClass; 368 uint8_t bDeviceSubClass; 369 uint8_t bDeviceProtocol; 370 uint8_t bInterfaceClass; 371 uint8_t bInterfaceSubClass; 372 uint8_t bInterfaceProtocol; 373 uint8_t bIfaceIndex; 374 uint8_t bIfaceNum; 375 uint8_t bConfigIndex; 376 uint8_t bConfigNum; 377}; 378 379/* Structure used by probe and attach */ 380 381struct usb2_attach_arg { 382 struct usb2_lookup_info info; 383 device_t temp_dev; /* for internal use */ 384 const void *driver_info; /* for internal use */ 385 struct usb2_device *device; /* current device */ 386 struct usb2_interface *iface; /* current interface */ 387 uint8_t usb2_mode; /* see USB_MODE_XXX */ 388 uint8_t port; 389 uint8_t use_generic; /* hint for generic drivers */ 390}; 391 392/* external variables */ 393 394MALLOC_DECLARE(M_USB); 395MALLOC_DECLARE(M_USBDEV); 396MALLOC_DECLARE(M_USBHC); 397 398extern struct mtx usb2_ref_lock; 399 400/* typedefs */ 401 402typedef struct malloc_type *usb2_malloc_type; 403 404/* prototypes */ 405 406const char *usb2_errstr(usb2_error_t error); 407struct usb2_config_descriptor *usb2_get_config_descriptor( 408 struct usb2_device *udev); 409struct usb2_device_descriptor *usb2_get_device_descriptor( 410 struct usb2_device *udev); 411struct usb2_interface *usb2_get_iface(struct usb2_device *udev, 412 uint8_t iface_index); 413struct usb2_interface_descriptor *usb2_get_interface_descriptor( 414 struct usb2_interface *iface); 415uint8_t usb2_clear_stall_callback(struct usb2_xfer *xfer1, 416 struct usb2_xfer *xfer2); 417uint8_t usb2_get_interface_altindex(struct usb2_interface *iface); 418usb2_error_t usb2_set_alt_interface_index(struct usb2_device *udev, 419 uint8_t iface_index, uint8_t alt_index); 420uint8_t usb2_get_mode(struct usb2_device *udev); 421uint8_t usb2_get_speed(struct usb2_device *udev); 422uint32_t usb2_get_isoc_fps(struct usb2_device *udev); 423usb2_error_t usb2_transfer_setup(struct usb2_device *udev, 424 const uint8_t *ifaces, struct usb2_xfer **pxfer, 425 const struct usb2_config *setup_start, uint16_t n_setup, 426 void *priv_sc, struct mtx *priv_mtx); 427void usb2_set_frame_data(struct usb2_xfer *xfer, void *ptr, 428 uint32_t frindex); 429void usb2_set_frame_offset(struct usb2_xfer *xfer, uint32_t offset, 430 uint32_t frindex); 431void usb2_start_hardware(struct usb2_xfer *xfer); 432void usb2_transfer_clear_stall(struct usb2_xfer *xfer); 433void usb2_transfer_drain(struct usb2_xfer *xfer); 434void usb2_transfer_set_stall(struct usb2_xfer *xfer); 435uint8_t usb2_transfer_pending(struct usb2_xfer *xfer); 436void usb2_transfer_start(struct usb2_xfer *xfer); 437void usb2_transfer_stop(struct usb2_xfer *xfer); 438void usb2_transfer_unsetup(struct usb2_xfer **pxfer, uint16_t n_setup); 439void usb2_set_parent_iface(struct usb2_device *udev, uint8_t iface_index, 440 uint8_t parent_index); 441uint8_t usb2_get_bus_index(struct usb2_device *udev); 442uint8_t usb2_get_device_index(struct usb2_device *udev); 443void usb2_set_power_mode(struct usb2_device *udev, uint8_t power_mode); 444 445#endif /* _USB2_CORE_H_ */ 446