Linux Audio

Check our new training course

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