Loading...
1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Driver for USB Mass Storage devices
4 * Usual Tables File for usb-storage and libusual
5 *
6 * Copyright (C) 2009 Alan Stern (stern@rowland.harvard.edu)
7 */
8
9#include <linux/kernel.h>
10#include <linux/module.h>
11#include <linux/usb.h>
12#include <linux/usb_usual.h>
13
14
15/*
16 * The table of devices
17 */
18#define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
19 vendorName, productName, useProtocol, useTransport, \
20 initFunction, flags) \
21{ USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \
22 .driver_info = (kernel_ulong_t)(flags) }
23
24#define COMPLIANT_DEV UNUSUAL_DEV
25
26#define USUAL_DEV(useProto, useTrans) \
27{ USB_INTERFACE_INFO(USB_CLASS_MASS_STORAGE, useProto, useTrans) }
28
29const struct usb_device_id usb_storage_usb_ids[] = {
30# include "unusual_devs.h"
31 { } /* Terminating entry */
32};
33MODULE_DEVICE_TABLE(usb, usb_storage_usb_ids);
34
35#undef UNUSUAL_DEV
36#undef COMPLIANT_DEV
37#undef USUAL_DEV
38
39/*
40 * The table of devices to ignore
41 */
42struct ignore_entry {
43 u16 vid, pid, bcdmin, bcdmax;
44};
45
46#define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
47 vendorName, productName, useProtocol, useTransport, \
48 initFunction, flags) \
49{ \
50 .vid = id_vendor, \
51 .pid = id_product, \
52 .bcdmin = bcdDeviceMin, \
53 .bcdmax = bcdDeviceMax, \
54}
55
56static const struct ignore_entry ignore_ids[] = {
57# include "unusual_alauda.h"
58# include "unusual_cypress.h"
59# include "unusual_datafab.h"
60# include "unusual_ene_ub6250.h"
61# include "unusual_freecom.h"
62# include "unusual_isd200.h"
63# include "unusual_jumpshot.h"
64# include "unusual_karma.h"
65# include "unusual_onetouch.h"
66# include "unusual_realtek.h"
67# include "unusual_sddr09.h"
68# include "unusual_sddr55.h"
69# include "unusual_usbat.h"
70 { } /* Terminating entry */
71};
72
73#undef UNUSUAL_DEV
74
75/* Return an error if a device is in the ignore_ids list */
76int usb_usual_ignore_device(struct usb_interface *intf)
77{
78 struct usb_device *udev;
79 unsigned vid, pid, bcd;
80 const struct ignore_entry *p;
81
82 udev = interface_to_usbdev(intf);
83 vid = le16_to_cpu(udev->descriptor.idVendor);
84 pid = le16_to_cpu(udev->descriptor.idProduct);
85 bcd = le16_to_cpu(udev->descriptor.bcdDevice);
86
87 for (p = ignore_ids; p->vid; ++p) {
88 if (p->vid == vid && p->pid == pid &&
89 p->bcdmin <= bcd && p->bcdmax >= bcd)
90 return -ENXIO;
91 }
92 return 0;
93}
1/*
2 * Driver for USB Mass Storage devices
3 * Usual Tables File for usb-storage and libusual
4 *
5 * Copyright (C) 2009 Alan Stern (stern@rowland.harvard.edu)
6 *
7 * Please see http://www.one-eyed-alien.net/~mdharm/linux-usb for more
8 * information about this driver.
9 *
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU General Public License as published by the
12 * Free Software Foundation; either version 2, or (at your option) any
13 * later version.
14 *
15 * This program is distributed in the hope that it will be useful, but
16 * WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 * General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License along
21 * with this program; if not, write to the Free Software Foundation, Inc.,
22 * 675 Mass Ave, Cambridge, MA 02139, USA.
23 */
24
25#include <linux/kernel.h>
26#include <linux/module.h>
27#include <linux/usb.h>
28#include <linux/usb_usual.h>
29
30
31/*
32 * The table of devices
33 */
34#define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
35 vendorName, productName, useProtocol, useTransport, \
36 initFunction, flags) \
37{ USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \
38 .driver_info = (flags) }
39
40#define COMPLIANT_DEV UNUSUAL_DEV
41
42#define USUAL_DEV(useProto, useTrans) \
43{ USB_INTERFACE_INFO(USB_CLASS_MASS_STORAGE, useProto, useTrans) }
44
45/* Define the device is matched with Vendor ID and interface descriptors */
46#define UNUSUAL_VENDOR_INTF(id_vendor, cl, sc, pr, \
47 vendorName, productName, useProtocol, useTransport, \
48 initFunction, flags) \
49{ \
50 .match_flags = USB_DEVICE_ID_MATCH_INT_INFO \
51 | USB_DEVICE_ID_MATCH_VENDOR, \
52 .idVendor = (id_vendor), \
53 .bInterfaceClass = (cl), \
54 .bInterfaceSubClass = (sc), \
55 .bInterfaceProtocol = (pr), \
56 .driver_info = (flags) \
57}
58
59struct usb_device_id usb_storage_usb_ids[] = {
60# include "unusual_devs.h"
61 { } /* Terminating entry */
62};
63MODULE_DEVICE_TABLE(usb, usb_storage_usb_ids);
64
65#undef UNUSUAL_DEV
66#undef COMPLIANT_DEV
67#undef USUAL_DEV
68#undef UNUSUAL_VENDOR_INTF
69
70/*
71 * The table of devices to ignore
72 */
73struct ignore_entry {
74 u16 vid, pid, bcdmin, bcdmax;
75};
76
77#define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
78 vendorName, productName, useProtocol, useTransport, \
79 initFunction, flags) \
80{ \
81 .vid = id_vendor, \
82 .pid = id_product, \
83 .bcdmin = bcdDeviceMin, \
84 .bcdmax = bcdDeviceMax, \
85}
86
87static struct ignore_entry ignore_ids[] = {
88# include "unusual_alauda.h"
89# include "unusual_cypress.h"
90# include "unusual_datafab.h"
91# include "unusual_ene_ub6250.h"
92# include "unusual_freecom.h"
93# include "unusual_isd200.h"
94# include "unusual_jumpshot.h"
95# include "unusual_karma.h"
96# include "unusual_onetouch.h"
97# include "unusual_realtek.h"
98# include "unusual_sddr09.h"
99# include "unusual_sddr55.h"
100# include "unusual_usbat.h"
101 { } /* Terminating entry */
102};
103
104#undef UNUSUAL_DEV
105
106/* Return an error if a device is in the ignore_ids list */
107int usb_usual_ignore_device(struct usb_interface *intf)
108{
109 struct usb_device *udev;
110 unsigned vid, pid, bcd;
111 struct ignore_entry *p;
112
113 udev = interface_to_usbdev(intf);
114 vid = le16_to_cpu(udev->descriptor.idVendor);
115 pid = le16_to_cpu(udev->descriptor.idProduct);
116 bcd = le16_to_cpu(udev->descriptor.bcdDevice);
117
118 for (p = ignore_ids; p->vid; ++p) {
119 if (p->vid == vid && p->pid == pid &&
120 p->bcdmin <= bcd && p->bcdmax >= bcd)
121 return -ENXIO;
122 }
123 return 0;
124}