summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2006-10-26 06:02:44 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2006-10-26 06:02:44 +0000
commit6cd44b05b739b43cf54f14cbd77d1b935a9157b1 (patch)
tree43a6e2d6acdcee4b1f3f0d9826368074cfd89a10 /sys
parentf59482fdaef7f606dfd2be38bd99e1aee2b6ceb2 (diff)
Move from a switch based baud rate selection to range checking
based selection as hardware is not limited to fixed rates. Suggested by deraadt
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/usb/moscom.c37
1 files changed, 8 insertions, 29 deletions
diff --git a/sys/dev/usb/moscom.c b/sys/dev/usb/moscom.c
index 94a01c54665..3226693688b 100644
--- a/sys/dev/usb/moscom.c
+++ b/sys/dev/usb/moscom.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: moscom.c,v 1.1 2006/10/26 04:14:09 jsg Exp $ */
+/* $OpenBSD: moscom.c,v 1.2 2006/10/26 06:02:43 jsg Exp $ */
/*
* Copyright (c) 2006 Jonathan Gray <jsg@openbsd.org>
@@ -130,19 +130,7 @@
#define MOSCOM_MSR_RI 0x40
#define MOSCOM_MSR_CD 0x80
-#define MOSCOM_BAUD_150 768
-#define MOSCOM_BAUD_300 384
-#define MOSCOM_BAUD_600 192
-#define MOSCOM_BAUD_1200 96
-#define MOSCOM_BAUD_1800 64
-#define MOSCOM_BAUD_2400 48
-#define MOSCOM_BAUD_4800 24
-#define MOSCOM_BAUD_9600 12
-#define MOSCOM_BAUD_19200 6
-#define MOSCOM_BAUD_38400 3
-#define MOSCOM_BAUD_57600 2
-#define MOSCOM_BAUD_115200 1
-
+#define MOSCOM_BAUD_REF 115200
struct moscom_softc {
USBBASEDEVICE sc_dev;
@@ -367,22 +355,13 @@ moscom_param(void *vsc, int portno, struct termios *t)
struct moscom_softc *sc = (struct moscom_softc *)vsc;
int data;
- switch (t->c_ospeed) {
- case 150: data = MOSCOM_BAUD_150; break;
- case 300: data = MOSCOM_BAUD_300; break;
- case 600: data = MOSCOM_BAUD_600; break;
- case 1200: data = MOSCOM_BAUD_1200; break;
- case 1800: data = MOSCOM_BAUD_1800; break;
- case 2400: data = MOSCOM_BAUD_2400; break;
- case 4800: data = MOSCOM_BAUD_4800; break;
- case 9600: data = MOSCOM_BAUD_9600; break;
- case 19200: data = MOSCOM_BAUD_19200; break;
- case 38400: data = MOSCOM_BAUD_38400; break;
- case 57600: data = MOSCOM_BAUD_57600; break;
- case 115200: data = MOSCOM_BAUD_115200; break;
- default:
+ if (t->c_ospeed <= 0 || t->c_ospeed > 115200)
+ return (EINVAL);
+
+ data = MOSCOM_BAUD_REF / t->c_ospeed;
+
+ if (data == 0 || data > 0xffff)
return (EINVAL);
- }
moscom_cmd(sc, MOSCOM_LCR, MOSCOM_LCR_DIVLATCH_EN);
moscom_cmd(sc, MOSCOM_BAUDLO, data & 0xFF);