1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
Index: linux-2.6.20.7/drivers/char/ts0710_mux.c
===================================================================
--- linux-2.6.20.7.orig/drivers/char/ts0710_mux.c 2007-04-22 10:51:31.000000000 +0200
+++ linux-2.6.20.7/drivers/char/ts0710_mux.c 2007-04-22 10:53:05.000000000 +0200
@@ -241,7 +241,8 @@
static volatile __u8 mux_recv_info_flags[NR_MUXS];
static mux_recv_struct *mux_recv_queue = NULL;
-static struct tty_driver mux_driver;
+// Local for 2.6?
+static struct tty_driver *mux_driver;
#ifdef USB_FOR_MUX
#define COMM_FOR_MUX_DRIVER usb_for_mux_driver
@@ -3007,6 +3008,7 @@
#else
mux_tty[line]++;
dlci = tty2dlci[line];
+ mux_table[line] = tty;
/* if( dlci == 1 ) { */
/* Open server channel 0 first */
@@ -3087,6 +3089,7 @@
}
}
+
retval = 0;
#endif
out:
@@ -3894,43 +3897,50 @@
INIT_WORK(&receive_tqueue, receive_worker, NULL);
INIT_WORK(&post_recv_tqueue, post_recv_worker, NULL);
- memset(&mux_driver, 0, sizeof(struct tty_driver));
- memset(&mux_tty, 0, sizeof(mux_tty));
- mux_driver.magic = TTY_DRIVER_MAGIC;
- mux_driver.driver_name = "ts0710mux";
- mux_driver.name = "ts0710mux";
- mux_driver.major = TS0710MUX_MAJOR;
- mux_driver.minor_start = TS0710MUX_MINOR_START;
- mux_driver.num = NR_MUXS;
- mux_driver.type = TTY_DRIVER_TYPE_SERIAL;
- mux_driver.subtype = SERIAL_TYPE_NORMAL;
- mux_driver.init_termios = tty_std_termios;
- mux_driver.init_termios.c_iflag = 0;
- mux_driver.init_termios.c_oflag = 0;
- mux_driver.init_termios.c_cflag = B38400 | CS8 | CREAD;
- mux_driver.init_termios.c_lflag = 0;
- mux_driver.flags = TTY_DRIVER_RESET_TERMIOS | TTY_DRIVER_REAL_RAW;
-
- mux_driver.ttys = mux_table;
- mux_driver.termios = mux_termios;
- mux_driver.termios_locked = mux_termios_locked;
+ mux_driver = alloc_tty_driver(NR_MUXS);
+ if (!mux_driver)
+ return -ENOMEM;
+
+ mux_driver->owner = THIS_MODULE;
+ mux_driver->driver_name = "ts0710mux";
+ mux_driver->name = "mux";
+ mux_driver->devfs_name = "mux";
+ mux_driver->major = TS0710MUX_MAJOR;
+ mux_driver->minor_start = TS0710MUX_MINOR_START;
+ mux_driver->type = TTY_DRIVER_TYPE_SERIAL;
+ mux_driver->subtype = SERIAL_TYPE_NORMAL;
+ mux_driver->flags = TTY_DRIVER_RESET_TERMIOS | TTY_DRIVER_REAL_RAW;
+
+ mux_driver->init_termios = tty_std_termios;
+ mux_driver->init_termios.c_iflag = 0;
+ mux_driver->init_termios.c_oflag = 0;
+ mux_driver->init_termios.c_cflag = B38400 | CS8 | CREAD;
+ mux_driver->init_termios.c_lflag = 0;
+
+// mux_driver.ttys = mux_table;
+ mux_driver->termios = mux_termios;
+ mux_driver->termios_locked = mux_termios_locked;
// mux_driver.driver_state = mux_state;
- mux_driver.other = NULL;
+ mux_driver->other = NULL;
- mux_driver.open = mux_open;
- mux_driver.close = mux_close;
- mux_driver.write = mux_write;
- mux_driver.write_room = mux_write_room;
- mux_driver.flush_buffer = mux_flush_buffer;
- mux_driver.chars_in_buffer = mux_chars_in_buffer;
- mux_driver.throttle = mux_throttle;
- mux_driver.unthrottle = mux_unthrottle;
- mux_driver.ioctl = mux_ioctl;
- mux_driver.owner = THIS_MODULE;
+ mux_driver->open = mux_open;
+ mux_driver->close = mux_close;
+ mux_driver->write = mux_write;
+ mux_driver->write_room = mux_write_room;
+ mux_driver->flush_buffer = mux_flush_buffer;
+ mux_driver->chars_in_buffer = mux_chars_in_buffer;
+ mux_driver->throttle = mux_throttle;
+ mux_driver->unthrottle = mux_unthrottle;
+ mux_driver->ioctl = mux_ioctl;
- if (tty_register_driver(&mux_driver))
+ // FIXME: No panic() here
+ if (tty_register_driver(mux_driver))
panic("Couldn't register mux driver");
+ for (j=0; j<NR_MUXS; j++)
+ tty_register_device(mux_driver, j, NULL);
+
+
COMM_MUX_DISPATCHER = mux_dispatcher;
COMM_MUX_SENDER = mux_sender;
@@ -3964,7 +3974,10 @@
mux_recv_info[j] = 0;
}
- if (tty_unregister_driver(&mux_driver))
+ for (j=0; j<NR_MUXS; j++)
+ tty_unregister_device(mux_driver, j);
+
+ if (tty_unregister_driver(mux_driver))
panic("Couldn't unregister mux driver");
}
|