|
@@ -148,8 +148,15 @@ static int acm_ctrl_msg(struct acm *acm, int request, int value,
|
|
|
/* devices aren't required to support these requests.
|
|
|
* the cdc acm descriptor tells whether they do...
|
|
|
*/
|
|
|
-#define acm_set_control(acm, control) \
|
|
|
- acm_ctrl_msg(acm, USB_CDC_REQ_SET_CONTROL_LINE_STATE, control, NULL, 0)
|
|
|
+static inline int acm_set_control(struct acm *acm, int control)
|
|
|
+{
|
|
|
+ if (acm->quirks & QUIRK_CONTROL_LINE_STATE)
|
|
|
+ return -EOPNOTSUPP;
|
|
|
+
|
|
|
+ return acm_ctrl_msg(acm, USB_CDC_REQ_SET_CONTROL_LINE_STATE,
|
|
|
+ control, NULL, 0);
|
|
|
+}
|
|
|
+
|
|
|
#define acm_set_line(acm, line) \
|
|
|
acm_ctrl_msg(acm, USB_CDC_REQ_SET_LINE_CODING, 0, line, sizeof *(line))
|
|
|
#define acm_send_break(acm, ms) \
|
|
@@ -1320,6 +1327,7 @@ made_compressed_probe:
|
|
|
tty_port_init(&acm->port);
|
|
|
acm->port.ops = &acm_port_ops;
|
|
|
init_usb_anchor(&acm->delayed);
|
|
|
+ acm->quirks = quirks;
|
|
|
|
|
|
buf = usb_alloc_coherent(usb_dev, ctrlsize, GFP_KERNEL, &acm->ctrl_dma);
|
|
|
if (!buf) {
|
|
@@ -1687,6 +1695,8 @@ static const struct usb_device_id acm_ids[] = {
|
|
|
{ USB_DEVICE(0x0572, 0x1328), /* Shiro / Aztech USB MODEM UM-3100 */
|
|
|
.driver_info = NO_UNION_NORMAL, /* has no union descriptor */
|
|
|
},
|
|
|
+ { USB_DEVICE(0x20df, 0x0001), /* Simtec Electronics Entropy Key */
|
|
|
+ .driver_info = QUIRK_CONTROL_LINE_STATE, },
|
|
|
{ USB_DEVICE(0x2184, 0x001c) }, /* GW Instek AFG-2225 */
|
|
|
{ USB_DEVICE(0x22b8, 0x6425), /* Motorola MOTOMAGX phones */
|
|
|
},
|