Skip to content
Snippets Groups Projects
Select Git revision
  • a91b593edd4b3e8aa91f671b763b27b8119eb49d
  • vme-testing default
  • ci-test
  • master
  • remoteproc
  • am625-sk-ov5640
  • pcal6534-upstreaming
  • lps22df-upstreaming
  • msc-upstreaming
  • imx8mp
  • iio/noa1305
  • vme-next
  • vme-next-4.14-rc4
  • v4.14-rc4
  • v4.14-rc3
  • v4.14-rc2
  • v4.14-rc1
  • v4.13
  • vme-next-4.13-rc7
  • v4.13-rc7
  • v4.13-rc6
  • v4.13-rc5
  • v4.13-rc4
  • v4.13-rc3
  • v4.13-rc2
  • v4.13-rc1
  • v4.12
  • v4.12-rc7
  • v4.12-rc6
  • v4.12-rc5
  • v4.12-rc4
  • v4.12-rc3
32 results

usb.c

Blame
  • usb.c 28.98 KiB
    /* Driver for USB Mass Storage compliant devices
     *
     * Current development and maintenance by:
     *   (c) 1999-2003 Matthew Dharm (mdharm-usb@one-eyed-alien.net)
     *
     * Developed with the assistance of:
     *   (c) 2000 David L. Brown, Jr. (usb-storage@davidb.org)
     *   (c) 2003-2009 Alan Stern (stern@rowland.harvard.edu)
     *
     * Initial work by:
     *   (c) 1999 Michael Gee (michael@linuxspecific.com)
     *
     * usb_device_id support by Adam J. Richter (adam@yggdrasil.com):
     *   (c) 2000 Yggdrasil Computing, Inc.
     *
     * This driver is based on the 'USB Mass Storage Class' document. This
     * describes in detail the protocol used to communicate with such
     * devices.  Clearly, the designers had SCSI and ATAPI commands in
     * mind when they created this document.  The commands are all very
     * similar to commands in the SCSI-II and ATAPI specifications.
     *
     * It is important to note that in a number of cases this class
     * exhibits class-specific exemptions from the USB specification.
     * Notably the usage of NAK, STALL and ACK differs from the norm, in
     * that they are used to communicate wait, failed and OK on commands.
     *
     * Also, for certain devices, the interrupt endpoint is used to convey
     * status of a command.
     *
     * Please see http://www.one-eyed-alien.net/~mdharm/linux-usb for more
     * information about this driver.
     *
     * This program is free software; you can redistribute it and/or modify it
     * under the terms of the GNU General Public License as published by the
     * Free Software Foundation; either version 2, or (at your option) any
     * later version.
     *
     * 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.
     *
     * You should have received a copy of the GNU General Public License along
     * with this program; if not, write to the Free Software Foundation, Inc.,
     * 675 Mass Ave, Cambridge, MA 02139, USA.
     */
    
    #ifdef CONFIG_USB_STORAGE_DEBUG
    #define DEBUG
    #endif
    
    #include <linux/sched.h>
    #include <linux/errno.h>
    #include <linux/freezer.h>
    #include <linux/module.h>
    #include <linux/init.h>
    #include <linux/slab.h>
    #include <linux/kthread.h>
    #include <linux/mutex.h>
    #include <linux/utsname.h>
    
    #include <scsi/scsi.h>
    #include <scsi/scsi_cmnd.h>
    #include <scsi/scsi_device.h>
    
    #include "usb.h"
    #include "scsiglue.h"
    #include "transport.h"
    #include "protocol.h"
    #include "debug.h"