| @@ -1,14 +1,14 @@ | | | @@ -1,14 +1,14 @@ |
1 | /* $NetBSD: uftdi.c,v 1.55 2013/01/20 13:43:24 reinoud Exp $ */ | | 1 | /* $NetBSD: uftdi.c,v 1.56 2013/01/21 19:08:42 mlelstv Exp $ */ |
2 | | | 2 | |
3 | /* | | 3 | /* |
4 | * Copyright (c) 2000 The NetBSD Foundation, Inc. | | 4 | * Copyright (c) 2000 The NetBSD Foundation, Inc. |
5 | * All rights reserved. | | 5 | * All rights reserved. |
6 | * | | 6 | * |
7 | * This code is derived from software contributed to The NetBSD Foundation | | 7 | * This code is derived from software contributed to The NetBSD Foundation |
8 | * by Lennart Augustsson (lennart@augustsson.net). | | 8 | * by Lennart Augustsson (lennart@augustsson.net). |
9 | * | | 9 | * |
10 | * Redistribution and use in source and binary forms, with or without | | 10 | * Redistribution and use in source and binary forms, with or without |
11 | * modification, are permitted provided that the following conditions | | 11 | * modification, are permitted provided that the following conditions |
12 | * are met: | | 12 | * are met: |
13 | * 1. Redistributions of source code must retain the above copyright | | 13 | * 1. Redistributions of source code must retain the above copyright |
14 | * notice, this list of conditions and the following disclaimer. | | 14 | * notice, this list of conditions and the following disclaimer. |
| @@ -20,27 +20,27 @@ | | | @@ -20,27 +20,27 @@ |
20 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED | | 20 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED |
21 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | | 21 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS | | 22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS |
23 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | | 23 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
24 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | | 24 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
25 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | | 25 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
26 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | | 26 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
27 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | | 27 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
28 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | | 28 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
29 | * POSSIBILITY OF SUCH DAMAGE. | | 29 | * POSSIBILITY OF SUCH DAMAGE. |
30 | */ | | 30 | */ |
31 | | | 31 | |
32 | #include <sys/cdefs.h> | | 32 | #include <sys/cdefs.h> |
33 | __KERNEL_RCSID(0, "$NetBSD: uftdi.c,v 1.55 2013/01/20 13:43:24 reinoud Exp $"); | | 33 | __KERNEL_RCSID(0, "$NetBSD: uftdi.c,v 1.56 2013/01/21 19:08:42 mlelstv Exp $"); |
34 | | | 34 | |
35 | #include <sys/param.h> | | 35 | #include <sys/param.h> |
36 | #include <sys/systm.h> | | 36 | #include <sys/systm.h> |
37 | #include <sys/kernel.h> | | 37 | #include <sys/kernel.h> |
38 | #include <sys/device.h> | | 38 | #include <sys/device.h> |
39 | #include <sys/conf.h> | | 39 | #include <sys/conf.h> |
40 | #include <sys/tty.h> | | 40 | #include <sys/tty.h> |
41 | | | 41 | |
42 | #include <dev/usb/usb.h> | | 42 | #include <dev/usb/usb.h> |
43 | | | 43 | |
44 | #include <dev/usb/usbdi.h> | | 44 | #include <dev/usb/usbdi.h> |
45 | #include <dev/usb/usbdi_util.h> | | 45 | #include <dev/usb/usbdi_util.h> |
46 | #include <dev/usb/usbdevs.h> | | 46 | #include <dev/usb/usbdevs.h> |
| @@ -116,26 +116,27 @@ struct ucom_methods uftdi_methods = { | | | @@ -116,26 +116,27 @@ struct ucom_methods uftdi_methods = { |
116 | uftdi_read, | | 116 | uftdi_read, |
117 | uftdi_write, | | 117 | uftdi_write, |
118 | }; | | 118 | }; |
119 | | | 119 | |
120 | /* | | 120 | /* |
121 | * The devices default to UFTDI_TYPE_8U232AM. | | 121 | * The devices default to UFTDI_TYPE_8U232AM. |
122 | * Remember to update uftdi_attach() if it should be UFTDI_TYPE_SIO instead | | 122 | * Remember to update uftdi_attach() if it should be UFTDI_TYPE_SIO instead |
123 | */ | | 123 | */ |
124 | static const struct usb_devno uftdi_devs[] = { | | 124 | static const struct usb_devno uftdi_devs[] = { |
125 | { USB_VENDOR_BBELECTRONICS, USB_PRODUCT_BBELECTRONICS_USOTL4 }, | | 125 | { USB_VENDOR_BBELECTRONICS, USB_PRODUCT_BBELECTRONICS_USOTL4 }, |
126 | { USB_VENDOR_FALCOM, USB_PRODUCT_FALCOM_TWIST }, | | 126 | { USB_VENDOR_FALCOM, USB_PRODUCT_FALCOM_TWIST }, |
127 | { USB_VENDOR_FALCOM, USB_PRODUCT_FALCOM_SAMBA }, | | 127 | { USB_VENDOR_FALCOM, USB_PRODUCT_FALCOM_SAMBA }, |
128 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_232H }, | | 128 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_232H }, |
| | | 129 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_232RL }, |
129 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_2232C }, | | 130 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_2232C }, |
130 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_4232H }, | | 131 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_4232H }, |
131 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_8U100AX }, | | 132 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_8U100AX }, |
132 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_8U232AM }, | | 133 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_SERIAL_8U232AM }, |
133 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_KW }, | | 134 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_KW }, |
134 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_YS }, | | 135 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_YS }, |
135 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_Y6 }, | | 136 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_Y6 }, |
136 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_Y8 }, | | 137 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_Y8 }, |
137 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_IC }, | | 138 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_IC }, |
138 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_DB9 }, | | 139 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_DB9 }, |
139 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_RS232 }, | | 140 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_RS232 }, |
140 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_Y9 }, | | 141 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_MHAM_Y9 }, |
141 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_COASTAL_TNCX }, | | 142 | { USB_VENDOR_FTDI, USB_PRODUCT_FTDI_COASTAL_TNCX }, |
| @@ -515,26 +516,35 @@ uftdi_set(void *vsc, int portno, int reg | | | @@ -515,26 +516,35 @@ uftdi_set(void *vsc, int portno, int reg |
515 | Static int | | 516 | Static int |
516 | uftdi_param(void *vsc, int portno, struct termios *t) | | 517 | uftdi_param(void *vsc, int portno, struct termios *t) |
517 | { | | 518 | { |
518 | struct uftdi_softc *sc = vsc; | | 519 | struct uftdi_softc *sc = vsc; |
519 | usb_device_request_t req; | | 520 | usb_device_request_t req; |
520 | usbd_status err; | | 521 | usbd_status err; |
521 | int rate, data, flow; | | 522 | int rate, data, flow; |
522 | | | 523 | |
523 | DPRINTF(("uftdi_param: sc=%p\n", sc)); | | 524 | DPRINTF(("uftdi_param: sc=%p\n", sc)); |
524 | | | 525 | |
525 | if (sc->sc_dying) | | 526 | if (sc->sc_dying) |
526 | return (EIO); | | 527 | return (EIO); |
527 | | | 528 | |
| | | 529 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE; |
| | | 530 | req.bRequest = FTDI_SIO_SET_BITMODE; |
| | | 531 | USETW(req.wValue, FTDI_BITMODE_RESET << 8 | 0x00); |
| | | 532 | USETW(req.wIndex, portno); |
| | | 533 | USETW(req.wLength, 0); |
| | | 534 | err = usbd_do_request(sc->sc_udev, &req, NULL); |
| | | 535 | if (err) |
| | | 536 | return (EIO); |
| | | 537 | |
528 | switch (sc->sc_type) { | | 538 | switch (sc->sc_type) { |
529 | case UFTDI_TYPE_SIO: | | 539 | case UFTDI_TYPE_SIO: |
530 | switch (t->c_ospeed) { | | 540 | switch (t->c_ospeed) { |
531 | case 300: rate = ftdi_sio_b300; break; | | 541 | case 300: rate = ftdi_sio_b300; break; |
532 | case 600: rate = ftdi_sio_b600; break; | | 542 | case 600: rate = ftdi_sio_b600; break; |
533 | case 1200: rate = ftdi_sio_b1200; break; | | 543 | case 1200: rate = ftdi_sio_b1200; break; |
534 | case 2400: rate = ftdi_sio_b2400; break; | | 544 | case 2400: rate = ftdi_sio_b2400; break; |
535 | case 4800: rate = ftdi_sio_b4800; break; | | 545 | case 4800: rate = ftdi_sio_b4800; break; |
536 | case 9600: rate = ftdi_sio_b9600; break; | | 546 | case 9600: rate = ftdi_sio_b9600; break; |
537 | case 19200: rate = ftdi_sio_b19200; break; | | 547 | case 19200: rate = ftdi_sio_b19200; break; |
538 | case 38400: rate = ftdi_sio_b38400; break; | | 548 | case 38400: rate = ftdi_sio_b38400; break; |
539 | case 57600: rate = ftdi_sio_b57600; break; | | 549 | case 57600: rate = ftdi_sio_b57600; break; |
540 | case 115200: rate = ftdi_sio_b115200; break; | | 550 | case 115200: rate = ftdi_sio_b115200; break; |