2005-10-23 11:15:09 +08:00
|
|
|
/*
|
|
|
|
* Interface to the libusual.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2005 Pete Zaitcev <zaitcev@redhat.com>
|
|
|
|
* Copyright (c) 1999-2002 Matthew Dharm (mdharm-usb@one-eyed-alien.net)
|
|
|
|
* Copyright (c) 1999 Michael Gee (michael@linuxspecific.com)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LINUX_USB_USUAL_H
|
|
|
|
#define __LINUX_USB_USUAL_H
|
|
|
|
|
|
|
|
|
|
|
|
/* We should do this for cleanliness... But other usb_foo.h do not do this. */
|
|
|
|
/* #include <linux/usb.h> */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The flags field, which we store in usb_device_id.driver_info.
|
|
|
|
* It is compatible with the old usb-storage flags in lower 24 bits.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Static flag definitions. We use this roundabout technique so that the
|
|
|
|
* proc_info() routine can automatically display a message for each flag.
|
|
|
|
*/
|
|
|
|
#define US_DO_ALL_FLAGS \
|
|
|
|
US_FLAG(SINGLE_LUN, 0x00000001) \
|
|
|
|
/* allow access to only LUN 0 */ \
|
|
|
|
US_FLAG(NEED_OVERRIDE, 0x00000002) \
|
|
|
|
/* unusual_devs entry is necessary */ \
|
|
|
|
US_FLAG(SCM_MULT_TARG, 0x00000004) \
|
|
|
|
/* supports multiple targets */ \
|
|
|
|
US_FLAG(FIX_INQUIRY, 0x00000008) \
|
|
|
|
/* INQUIRY response needs faking */ \
|
|
|
|
US_FLAG(FIX_CAPACITY, 0x00000010) \
|
|
|
|
/* READ CAPACITY response too big */ \
|
|
|
|
US_FLAG(IGNORE_RESIDUE, 0x00000020) \
|
|
|
|
/* reported residue is wrong */ \
|
|
|
|
US_FLAG(BULK32, 0x00000040) \
|
|
|
|
/* Uses 32-byte CBW length */ \
|
|
|
|
US_FLAG(NOT_LOCKABLE, 0x00000080) \
|
|
|
|
/* PREVENT/ALLOW not supported */ \
|
|
|
|
US_FLAG(GO_SLOW, 0x00000100) \
|
|
|
|
/* Need delay after Command phase */ \
|
|
|
|
US_FLAG(NO_WP_DETECT, 0x00000200) \
|
|
|
|
/* Don't check for write-protect */ \
|
2006-06-25 08:27:10 +08:00
|
|
|
US_FLAG(MAX_SECTORS_64, 0x00000400) \
|
2006-07-26 20:59:23 +08:00
|
|
|
/* Sets max_sectors to 64 */ \
|
|
|
|
US_FLAG(IGNORE_DEVICE, 0x00000800) \
|
2007-02-08 16:04:48 +08:00
|
|
|
/* Don't claim device */ \
|
|
|
|
US_FLAG(CAPACITY_HEURISTICS, 0x00001000) \
|
2007-12-06 13:36:45 +08:00
|
|
|
/* sometimes sizes is too big */ \
|
|
|
|
US_FLAG(MAX_SECTORS_MIN,0x00002000) \
|
2008-03-17 04:04:23 +08:00
|
|
|
/* Sets max_sectors to arch min */ \
|
|
|
|
US_FLAG(BULK_IGNORE_TAG,0x00004000) \
|
2008-11-19 05:31:13 +08:00
|
|
|
/* Ignore tag mismatch in bulk operations */ \
|
USB: storage: add last-sector hacks
This patch (as1189b) adds some hacks to usb-storage for dealing with
the growing problems involving bad capacity values and last-sector
accesses:
A new flag, US_FL_CAPACITY_OK, is created to indicate that
the device is known to report its capacity correctly. An
unusual_devs entry for Linux's own File-backed Storage Gadget
is added with this flag set, since g_file_storage always
reports the correct capacity and since the capacity need
not be even (it is determined by the size of the backing
file).
An entry in unusual_devs.h which has only the CAPACITY_OK
flag set shouldn't prejudice libusual, since the device will
work perfectly well with either usb-storage or ub. So a
new macro, COMPLIANT_DEV, is added to let libusual know
about these entries.
When a last-sector access succeeds and the total number of
sectors is odd (the unexpected case, in which guessing that
the number is even might cause trouble), a WARN is triggered.
The kerneloops.org project will collect these warnings,
allowing us to add CAPACITY_OK flags for the devices in
question before implementing the default-to-even heuristic.
If users want to prevent the stack dump produced by the WARN,
they can disable the hack by adding an unusual_devs entry
for their device with the CAPACITY_OK flag.
When a last-sector access fails three times in a row and
neither the FIX_CAPACITY nor the CAPACITY_OK flag is set,
we assume the last-sector bug is present. We replace the
existing status and sense data with values that will cause
the SCSI core to fail the access immediately rather than
retry indefinitely. This should fix the difficulties
people have been having with Nokia phones.
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Cc: stable <stable@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-16 01:43:41 +08:00
|
|
|
US_FLAG(SANE_SENSE, 0x00008000) \
|
|
|
|
/* Sane Sense (> 18 bytes) */ \
|
|
|
|
US_FLAG(CAPACITY_OK, 0x00010000) \
|
2009-12-08 05:39:16 +08:00
|
|
|
/* READ CAPACITY response is correct */ \
|
|
|
|
US_FLAG(BAD_SENSE, 0x00020000) \
|
2010-10-02 05:20:10 +08:00
|
|
|
/* Bad Sense (never more than 18 bytes) */ \
|
|
|
|
US_FLAG(NO_READ_DISC_INFO, 0x00040000) \
|
2010-10-02 05:20:11 +08:00
|
|
|
/* cannot handle READ_DISC_INFO */ \
|
|
|
|
US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
|
2011-06-07 23:35:52 +08:00
|
|
|
/* cannot handle READ_CAPACITY_16 */ \
|
|
|
|
US_FLAG(INITIAL_READ10, 0x00100000) \
|
2012-07-08 11:05:28 +08:00
|
|
|
/* Initial READ(10) (and others) must be retried */ \
|
|
|
|
US_FLAG(WRITE_CACHE, 0x00200000) \
|
|
|
|
/* Write Cache status is not available */
|
2005-10-23 11:15:09 +08:00
|
|
|
|
|
|
|
#define US_FLAG(name, value) US_FL_##name = value ,
|
|
|
|
enum { US_DO_ALL_FLAGS };
|
|
|
|
#undef US_FLAG
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The bias field for libusual and friends.
|
|
|
|
*/
|
|
|
|
#define USB_US_TYPE_NONE 0
|
|
|
|
#define USB_US_TYPE_STOR 1 /* usb-storage */
|
|
|
|
#define USB_US_TYPE_UB 2 /* ub */
|
|
|
|
|
|
|
|
#define USB_US_TYPE(flags) (((flags) >> 24) & 0xFF)
|
|
|
|
#define USB_US_ORIG_FLAGS(flags) ((flags) & 0x00FFFFFF)
|
|
|
|
|
2010-10-07 19:05:22 +08:00
|
|
|
#include <linux/usb/storage.h>
|
2005-10-23 11:15:09 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
*/
|
usb-storage: prepare for subdriver separation
This patch (as1206) is the first step in converting usb-storage's
subdrivers into separate modules. It makes the following large-scale
changes:
Remove a bunch of unnecessary #ifdef's from usb_usual.h.
Not truly necessary, but it does clean things up.
Move the USB device-ID table (which is duplicated between
libusual and usb-storage) into its own source file,
usual-tables.c, and arrange for this to be linked with
either libusual or usb-storage according to whether
USB_LIBUSUAL is configured.
Add to usual-tables.c a new usb_usual_ignore_device()
function to detect whether a particular device needs to be
managed by a subdriver and not by the standard handlers
in usb-storage.
Export a whole bunch of functions in usb-storage, renaming
some of them because their names don't already begin with
"usb_stor_". These functions will be needed by the new
subdriver modules.
Split usb-storage's probe routine into two functions.
The subdrivers will call the probe1 routine, then fill in
their transport and protocol settings, and then call the
probe2 routine.
Take the default cases and error checking out of
get_transport() and get_protocol(), which run during
probe1, and instead put a check for invalid transport
or protocol values into the probe2 function.
Add a new probe routine to be used for standard devices,
i.e., those that don't need a subdriver. This new routine
checks whether the device should be ignored (because it
should be handled by ub or by a subdriver), and if not,
calls the probe1 and probe2 functions.
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
CC: Matthew Dharm <mdharm-usb@one-eyed-alien.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2009-02-13 03:47:44 +08:00
|
|
|
extern int usb_usual_ignore_device(struct usb_interface *intf);
|
|
|
|
extern struct usb_device_id usb_storage_usb_ids[];
|
|
|
|
|
2005-10-23 11:15:09 +08:00
|
|
|
#ifdef CONFIG_USB_LIBUSUAL
|
|
|
|
|
|
|
|
extern void usb_usual_set_present(int type);
|
|
|
|
extern void usb_usual_clear_present(int type);
|
|
|
|
extern int usb_usual_check_type(const struct usb_device_id *, int type);
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define usb_usual_set_present(t) do { } while(0)
|
|
|
|
#define usb_usual_clear_present(t) do { } while(0)
|
|
|
|
#define usb_usual_check_type(id, t) (0)
|
|
|
|
#endif /* CONFIG_USB_LIBUSUAL */
|
|
|
|
|
|
|
|
#endif /* __LINUX_USB_USUAL_H */
|