diff options
Diffstat (limited to 'drivers/usb/storage/usual-tables.c')
| -rw-r--r-- | drivers/usb/storage/usual-tables.c | 35 | 
1 files changed, 21 insertions, 14 deletions
diff --git a/drivers/usb/storage/usual-tables.c b/drivers/usb/storage/usual-tables.c index 468bde7d197..5ef8ce74aae 100644 --- a/drivers/usb/storage/usual-tables.c +++ b/drivers/usb/storage/usual-tables.c @@ -34,30 +34,37 @@  		    vendorName, productName, useProtocol, useTransport, \  		    initFunction, flags) \  { USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \ -  .driver_info = (flags)|(USB_US_TYPE_STOR<<24) } - -#define COMPLIANT_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \ -		    vendorName, productName, useProtocol, useTransport, \ -		    initFunction, flags) \ -{ USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \    .driver_info = (flags) } -#define USUAL_DEV(useProto, useTrans, useType) \ -{ USB_INTERFACE_INFO(USB_CLASS_MASS_STORAGE, useProto, useTrans), \ -  .driver_info = ((useType)<<24) } +#define COMPLIANT_DEV	UNUSUAL_DEV + +#define USUAL_DEV(useProto, useTrans) \ +{ USB_INTERFACE_INFO(USB_CLASS_MASS_STORAGE, useProto, useTrans) } + +/* Define the device is matched with Vendor ID and interface descriptors */ +#define UNUSUAL_VENDOR_INTF(id_vendor, cl, sc, pr, \ +			vendorName, productName, useProtocol, useTransport, \ +			initFunction, flags) \ +{ \ +	.match_flags = USB_DEVICE_ID_MATCH_INT_INFO \ +				| USB_DEVICE_ID_MATCH_VENDOR, \ +	.idVendor    = (id_vendor), \ +	.bInterfaceClass = (cl), \ +	.bInterfaceSubClass = (sc), \ +	.bInterfaceProtocol = (pr), \ +	.driver_info = (flags) \ +}  struct usb_device_id usb_storage_usb_ids[] = {  #	include "unusual_devs.h"  	{ }		/* Terminating entry */  }; -EXPORT_SYMBOL_GPL(usb_storage_usb_ids); -  MODULE_DEVICE_TABLE(usb, usb_storage_usb_ids);  #undef UNUSUAL_DEV  #undef COMPLIANT_DEV  #undef USUAL_DEV - +#undef UNUSUAL_VENDOR_INTF  /*   * The table of devices to ignore @@ -80,11 +87,13 @@ static struct ignore_entry ignore_ids[] = {  #	include "unusual_alauda.h"  #	include "unusual_cypress.h"  #	include "unusual_datafab.h" +#	include "unusual_ene_ub6250.h"  #	include "unusual_freecom.h"  #	include "unusual_isd200.h"  #	include "unusual_jumpshot.h"  #	include "unusual_karma.h"  #	include "unusual_onetouch.h" +#	include "unusual_realtek.h"  #	include "unusual_sddr09.h"  #	include "unusual_sddr55.h"  #	include "unusual_usbat.h" @@ -93,7 +102,6 @@ static struct ignore_entry ignore_ids[] = {  #undef UNUSUAL_DEV -  /* Return an error if a device is in the ignore_ids list */  int usb_usual_ignore_device(struct usb_interface *intf)  { @@ -113,4 +121,3 @@ int usb_usual_ignore_device(struct usb_interface *intf)  	}  	return 0;  } -EXPORT_SYMBOL_GPL(usb_usual_ignore_device);  | 
