aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/isdn
diff options
context:
space:
mode:
authorJiri Slaby <jslaby@suse.cz>2012-03-05 08:52:54 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2012-03-08 15:51:13 -0500
commitfc258f89405f63b379324d1f8388ae4810297997 (patch)
tree7027aadb38d74ff01e24c759339e75b16e0515dd /drivers/isdn
parent5dd5bc40f3b6e0ccdaad948dbadc94ad0906cb25 (diff)
TTY: isdn/gigaset, do not set tty->driver_data to NULL
Close the window in open where driver_data is reset to NULL on each open. It could cause other processes to get invalid retval from the tty->ops operations because of the checks all over the code. With this change we may do other cleanups. Now, the only valid check for tty->driver_data != NULL is in close. This can happen only if open fails at gigaset_get_cs_by_tty or try_module_get. The rest of checks in various tty->ops->* are invalid as driver_data cannot be NULL there. The same holds for cs->open_count. So remove them. Signed-off-by: Jiri Slaby <jslaby@suse.cz> Cc: Hansjoerg Lipp <hjlipp@web.de> Cc: Tilman Schmidt <tilman@imap.cc> Cc: gigaset307x-common@lists.sourceforge.net Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/isdn')
-rw-r--r--drivers/isdn/gigaset/interface.c105
1 files changed, 14 insertions, 91 deletions
diff --git a/drivers/isdn/gigaset/interface.c b/drivers/isdn/gigaset/interface.c
index 648260b07f1a..8ff50b056285 100644
--- a/drivers/isdn/gigaset/interface.c
+++ b/drivers/isdn/gigaset/interface.c
@@ -151,8 +151,6 @@ static int if_open(struct tty_struct *tty, struct file *filp)
151 gig_dbg(DEBUG_IF, "%d+%d: %s()", 151 gig_dbg(DEBUG_IF, "%d+%d: %s()",
152 tty->driver->minor_start, tty->index, __func__); 152 tty->driver->minor_start, tty->index, __func__);
153 153
154 tty->driver_data = NULL;
155
156 cs = gigaset_get_cs_by_tty(tty); 154 cs = gigaset_get_cs_by_tty(tty);
157 if (!cs || !try_module_get(cs->driver->owner)) 155 if (!cs || !try_module_get(cs->driver->owner))
158 return -ENODEV; 156 return -ENODEV;
@@ -178,12 +176,11 @@ static int if_open(struct tty_struct *tty, struct file *filp)
178 176
179static void if_close(struct tty_struct *tty, struct file *filp) 177static void if_close(struct tty_struct *tty, struct file *filp)
180{ 178{
181 struct cardstate *cs; 179 struct cardstate *cs = tty->driver_data;
182 unsigned long flags; 180 unsigned long flags;
183 181
184 cs = (struct cardstate *) tty->driver_data; 182 if (!cs) { /* happens if we didn't find cs in open */
185 if (!cs) { 183 printk(KERN_DEBUG "%s: no cardstate\n", __func__);
186 pr_err("%s: no cardstate\n", __func__);
187 return; 184 return;
188 } 185 }
189 186
@@ -211,18 +208,12 @@ static void if_close(struct tty_struct *tty, struct file *filp)
211static int if_ioctl(struct tty_struct *tty, 208static int if_ioctl(struct tty_struct *tty,
212 unsigned int cmd, unsigned long arg) 209 unsigned int cmd, unsigned long arg)
213{ 210{
214 struct cardstate *cs; 211 struct cardstate *cs = tty->driver_data;
215 int retval = -ENODEV; 212 int retval = -ENODEV;
216 int int_arg; 213 int int_arg;
217 unsigned char buf[6]; 214 unsigned char buf[6];
218 unsigned version[4]; 215 unsigned version[4];
219 216
220 cs = (struct cardstate *) tty->driver_data;
221 if (!cs) {
222 pr_err("%s: no cardstate\n", __func__);
223 return -ENODEV;
224 }
225
226 gig_dbg(DEBUG_IF, "%u: %s(0x%x)", cs->minor_index, __func__, cmd); 217 gig_dbg(DEBUG_IF, "%u: %s(0x%x)", cs->minor_index, __func__, cmd);
227 218
228 if (mutex_lock_interruptible(&cs->mutex)) 219 if (mutex_lock_interruptible(&cs->mutex))
@@ -231,9 +222,7 @@ static int if_ioctl(struct tty_struct *tty,
231 if (!cs->connected) { 222 if (!cs->connected) {
232 gig_dbg(DEBUG_IF, "not connected"); 223 gig_dbg(DEBUG_IF, "not connected");
233 retval = -ENODEV; 224 retval = -ENODEV;
234 } else if (!cs->open_count) 225 } else {
235 dev_warn(cs->dev, "%s: device not opened\n", __func__);
236 else {
237 retval = 0; 226 retval = 0;
238 switch (cmd) { 227 switch (cmd) {
239 case GIGASET_REDIR: 228 case GIGASET_REDIR:
@@ -285,15 +274,9 @@ static int if_ioctl(struct tty_struct *tty,
285 274
286static int if_tiocmget(struct tty_struct *tty) 275static int if_tiocmget(struct tty_struct *tty)
287{ 276{
288 struct cardstate *cs; 277 struct cardstate *cs = tty->driver_data;
289 int retval; 278 int retval;
290 279
291 cs = (struct cardstate *) tty->driver_data;
292 if (!cs) {
293 pr_err("%s: no cardstate\n", __func__);
294 return -ENODEV;
295 }
296
297 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 280 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
298 281
299 if (mutex_lock_interruptible(&cs->mutex)) 282 if (mutex_lock_interruptible(&cs->mutex))
@@ -309,16 +292,10 @@ static int if_tiocmget(struct tty_struct *tty)
309static int if_tiocmset(struct tty_struct *tty, 292static int if_tiocmset(struct tty_struct *tty,
310 unsigned int set, unsigned int clear) 293 unsigned int set, unsigned int clear)
311{ 294{
312 struct cardstate *cs; 295 struct cardstate *cs = tty->driver_data;
313 int retval; 296 int retval;
314 unsigned mc; 297 unsigned mc;
315 298
316 cs = (struct cardstate *) tty->driver_data;
317 if (!cs) {
318 pr_err("%s: no cardstate\n", __func__);
319 return -ENODEV;
320 }
321
322 gig_dbg(DEBUG_IF, "%u: %s(0x%x, 0x%x)", 299 gig_dbg(DEBUG_IF, "%u: %s(0x%x, 0x%x)",
323 cs->minor_index, __func__, set, clear); 300 cs->minor_index, __func__, set, clear);
324 301
@@ -341,16 +318,10 @@ static int if_tiocmset(struct tty_struct *tty,
341 318
342static int if_write(struct tty_struct *tty, const unsigned char *buf, int count) 319static int if_write(struct tty_struct *tty, const unsigned char *buf, int count)
343{ 320{
344 struct cardstate *cs; 321 struct cardstate *cs = tty->driver_data;
345 struct cmdbuf_t *cb; 322 struct cmdbuf_t *cb;
346 int retval; 323 int retval;
347 324
348 cs = (struct cardstate *) tty->driver_data;
349 if (!cs) {
350 pr_err("%s: no cardstate\n", __func__);
351 return -ENODEV;
352 }
353
354 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 325 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
355 326
356 if (mutex_lock_interruptible(&cs->mutex)) 327 if (mutex_lock_interruptible(&cs->mutex))
@@ -361,11 +332,6 @@ static int if_write(struct tty_struct *tty, const unsigned char *buf, int count)
361 retval = -ENODEV; 332 retval = -ENODEV;
362 goto done; 333 goto done;
363 } 334 }
364 if (!cs->open_count) {
365 dev_warn(cs->dev, "%s: device not opened\n", __func__);
366 retval = -ENODEV;
367 goto done;
368 }
369 if (cs->mstate != MS_LOCKED) { 335 if (cs->mstate != MS_LOCKED) {
370 dev_warn(cs->dev, "can't write to unlocked device\n"); 336 dev_warn(cs->dev, "can't write to unlocked device\n");
371 retval = -EBUSY; 337 retval = -EBUSY;
@@ -397,15 +363,9 @@ done:
397 363
398static int if_write_room(struct tty_struct *tty) 364static int if_write_room(struct tty_struct *tty)
399{ 365{
400 struct cardstate *cs; 366 struct cardstate *cs = tty->driver_data;
401 int retval = -ENODEV; 367 int retval = -ENODEV;
402 368
403 cs = (struct cardstate *) tty->driver_data;
404 if (!cs) {
405 pr_err("%s: no cardstate\n", __func__);
406 return -ENODEV;
407 }
408
409 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 369 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
410 370
411 if (mutex_lock_interruptible(&cs->mutex)) 371 if (mutex_lock_interruptible(&cs->mutex))
@@ -414,9 +374,7 @@ static int if_write_room(struct tty_struct *tty)
414 if (!cs->connected) { 374 if (!cs->connected) {
415 gig_dbg(DEBUG_IF, "not connected"); 375 gig_dbg(DEBUG_IF, "not connected");
416 retval = -ENODEV; 376 retval = -ENODEV;
417 } else if (!cs->open_count) 377 } else if (cs->mstate != MS_LOCKED) {
418 dev_warn(cs->dev, "%s: device not opened\n", __func__);
419 else if (cs->mstate != MS_LOCKED) {
420 dev_warn(cs->dev, "can't write to unlocked device\n"); 378 dev_warn(cs->dev, "can't write to unlocked device\n");
421 retval = -EBUSY; 379 retval = -EBUSY;
422 } else 380 } else
@@ -429,23 +387,15 @@ static int if_write_room(struct tty_struct *tty)
429 387
430static int if_chars_in_buffer(struct tty_struct *tty) 388static int if_chars_in_buffer(struct tty_struct *tty)
431{ 389{
432 struct cardstate *cs; 390 struct cardstate *cs = tty->driver_data;
433 int retval = 0; 391 int retval = 0;
434 392
435 cs = (struct cardstate *) tty->driver_data;
436 if (!cs) {
437 pr_err("%s: no cardstate\n", __func__);
438 return 0;
439 }
440
441 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 393 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
442 394
443 mutex_lock(&cs->mutex); 395 mutex_lock(&cs->mutex);
444 396
445 if (!cs->connected) 397 if (!cs->connected)
446 gig_dbg(DEBUG_IF, "not connected"); 398 gig_dbg(DEBUG_IF, "not connected");
447 else if (!cs->open_count)
448 dev_warn(cs->dev, "%s: device not opened\n", __func__);
449 else if (cs->mstate != MS_LOCKED) 399 else if (cs->mstate != MS_LOCKED)
450 dev_warn(cs->dev, "can't write to unlocked device\n"); 400 dev_warn(cs->dev, "can't write to unlocked device\n");
451 else 401 else
@@ -458,13 +408,7 @@ static int if_chars_in_buffer(struct tty_struct *tty)
458 408
459static void if_throttle(struct tty_struct *tty) 409static void if_throttle(struct tty_struct *tty)
460{ 410{
461 struct cardstate *cs; 411 struct cardstate *cs = tty->driver_data;
462
463 cs = (struct cardstate *) tty->driver_data;
464 if (!cs) {
465 pr_err("%s: no cardstate\n", __func__);
466 return;
467 }
468 412
469 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 413 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
470 414
@@ -472,8 +416,6 @@ static void if_throttle(struct tty_struct *tty)
472 416
473 if (!cs->connected) 417 if (!cs->connected)
474 gig_dbg(DEBUG_IF, "not connected"); /* nothing to do */ 418 gig_dbg(DEBUG_IF, "not connected"); /* nothing to do */
475 else if (!cs->open_count)
476 dev_warn(cs->dev, "%s: device not opened\n", __func__);
477 else 419 else
478 gig_dbg(DEBUG_IF, "%s: not implemented\n", __func__); 420 gig_dbg(DEBUG_IF, "%s: not implemented\n", __func__);
479 421
@@ -482,13 +424,7 @@ static void if_throttle(struct tty_struct *tty)
482 424
483static void if_unthrottle(struct tty_struct *tty) 425static void if_unthrottle(struct tty_struct *tty)
484{ 426{
485 struct cardstate *cs; 427 struct cardstate *cs = tty->driver_data;
486
487 cs = (struct cardstate *) tty->driver_data;
488 if (!cs) {
489 pr_err("%s: no cardstate\n", __func__);
490 return;
491 }
492 428
493 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 429 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
494 430
@@ -496,8 +432,6 @@ static void if_unthrottle(struct tty_struct *tty)
496 432
497 if (!cs->connected) 433 if (!cs->connected)
498 gig_dbg(DEBUG_IF, "not connected"); /* nothing to do */ 434 gig_dbg(DEBUG_IF, "not connected"); /* nothing to do */
499 else if (!cs->open_count)
500 dev_warn(cs->dev, "%s: device not opened\n", __func__);
501 else 435 else
502 gig_dbg(DEBUG_IF, "%s: not implemented\n", __func__); 436 gig_dbg(DEBUG_IF, "%s: not implemented\n", __func__);
503 437
@@ -506,18 +440,12 @@ static void if_unthrottle(struct tty_struct *tty)
506 440
507static void if_set_termios(struct tty_struct *tty, struct ktermios *old) 441static void if_set_termios(struct tty_struct *tty, struct ktermios *old)
508{ 442{
509 struct cardstate *cs; 443 struct cardstate *cs = tty->driver_data;
510 unsigned int iflag; 444 unsigned int iflag;
511 unsigned int cflag; 445 unsigned int cflag;
512 unsigned int old_cflag; 446 unsigned int old_cflag;
513 unsigned int control_state, new_state; 447 unsigned int control_state, new_state;
514 448
515 cs = (struct cardstate *) tty->driver_data;
516 if (!cs) {
517 pr_err("%s: no cardstate\n", __func__);
518 return;
519 }
520
521 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); 449 gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__);
522 450
523 mutex_lock(&cs->mutex); 451 mutex_lock(&cs->mutex);
@@ -527,11 +455,6 @@ static void if_set_termios(struct tty_struct *tty, struct ktermios *old)
527 goto out; 455 goto out;
528 } 456 }
529 457
530 if (!cs->open_count) {
531 dev_warn(cs->dev, "%s: device not opened\n", __func__);
532 goto out;
533 }
534
535 iflag = tty->termios->c_iflag; 458 iflag = tty->termios->c_iflag;
536 cflag = tty->termios->c_cflag; 459 cflag = tty->termios->c_cflag;
537 old_cflag = old ? old->c_cflag : cflag; 460 old_cflag = old ? old->c_cflag : cflag;