aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char/moxa.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/char/moxa.c')
-rw-r--r--drivers/char/moxa.c73
1 files changed, 31 insertions, 42 deletions
diff --git a/drivers/char/moxa.c b/drivers/char/moxa.c
index 5000b3bd091e..3bc8c6826cd4 100644
--- a/drivers/char/moxa.c
+++ b/drivers/char/moxa.c
@@ -166,7 +166,6 @@ struct moxa_port {
166 166
167#define WAKEUP_CHARS 256 167#define WAKEUP_CHARS 256
168 168
169static int verbose = 0;
170static int ttymajor = MOXAMAJOR; 169static int ttymajor = MOXAMAJOR;
171/* Variables for insmod */ 170/* Variables for insmod */
172#ifdef MODULE 171#ifdef MODULE
@@ -184,7 +183,6 @@ module_param_array(baseaddr, int, NULL, 0);
184module_param_array(numports, int, NULL, 0); 183module_param_array(numports, int, NULL, 0);
185#endif 184#endif
186module_param(ttymajor, int, 0); 185module_param(ttymajor, int, 0);
187module_param(verbose, bool, 0644);
188 186
189/* 187/*
190 * static functions: 188 * static functions:
@@ -283,8 +281,10 @@ static int __devinit moxa_pci_probe(struct pci_dev *pdev,
283 int retval; 281 int retval;
284 282
285 retval = pci_enable_device(pdev); 283 retval = pci_enable_device(pdev);
286 if (retval) 284 if (retval) {
285 dev_err(&pdev->dev, "can't enable pci device\n");
287 goto err; 286 goto err;
287 }
288 288
289 for (i = 0; i < MAX_BOARDS; i++) 289 for (i = 0; i < MAX_BOARDS; i++)
290 if (moxa_boards[i].basemem == NULL) 290 if (moxa_boards[i].basemem == NULL)
@@ -292,16 +292,17 @@ static int __devinit moxa_pci_probe(struct pci_dev *pdev,
292 292
293 retval = -ENODEV; 293 retval = -ENODEV;
294 if (i >= MAX_BOARDS) { 294 if (i >= MAX_BOARDS) {
295 if (verbose) 295 dev_warn(&pdev->dev, "more than %u MOXA Intellio family boards "
296 printk("More than %d MOXA Intellio family boards "
297 "found. Board is ignored.\n", MAX_BOARDS); 296 "found. Board is ignored.\n", MAX_BOARDS);
298 goto err; 297 goto err;
299 } 298 }
300 299
301 board = &moxa_boards[i]; 300 board = &moxa_boards[i];
302 board->basemem = pci_iomap(pdev, 2, 0x4000); 301 board->basemem = pci_iomap(pdev, 2, 0x4000);
303 if (board->basemem == NULL) 302 if (board->basemem == NULL) {
303 dev_err(&pdev->dev, "can't remap io space 2\n");
304 goto err; 304 goto err;
305 }
305 306
306 board->boardType = board_type; 307 board->boardType = board_type;
307 switch (board_type) { 308 switch (board_type) {
@@ -347,7 +348,8 @@ static int __init moxa_init(void)
347 int i, numBoards, retval = 0; 348 int i, numBoards, retval = 0;
348 struct moxa_port *ch; 349 struct moxa_port *ch;
349 350
350 printk(KERN_INFO "MOXA Intellio family driver version %s\n", MOXA_VERSION); 351 printk(KERN_INFO "MOXA Intellio family driver version %s\n",
352 MOXA_VERSION);
351 moxaDriver = alloc_tty_driver(MAX_PORTS + 1); 353 moxaDriver = alloc_tty_driver(MAX_PORTS + 1);
352 if (!moxaDriver) 354 if (!moxaDriver)
353 return -ENOMEM; 355 return -ENOMEM;
@@ -378,7 +380,7 @@ static int __init moxa_init(void)
378 (unsigned long)ch); 380 (unsigned long)ch);
379 } 381 }
380 382
381 printk("Tty devices major number = %d\n", ttymajor); 383 pr_debug("Moxa tty devices major number = %d\n", ttymajor);
382 384
383 if (tty_register_driver(moxaDriver)) { 385 if (tty_register_driver(moxaDriver)) {
384 printk(KERN_ERR "Couldn't install MOXA Smartio family driver !\n"); 386 printk(KERN_ERR "Couldn't install MOXA Smartio family driver !\n");
@@ -400,11 +402,10 @@ static int __init moxa_init(void)
400 moxa_boards[numBoards].numPorts = moxa_isa_boards[i].numPorts; 402 moxa_boards[numBoards].numPorts = moxa_isa_boards[i].numPorts;
401 moxa_boards[numBoards].busType = MOXA_BUS_TYPE_ISA; 403 moxa_boards[numBoards].busType = MOXA_BUS_TYPE_ISA;
402 moxa_boards[numBoards].baseAddr = moxa_isa_boards[i].baseAddr; 404 moxa_boards[numBoards].baseAddr = moxa_isa_boards[i].baseAddr;
403 if (verbose) 405 pr_debug("Moxa board %2d: %s board(baseAddr=%lx)\n",
404 printk("Board %2d: %s board(baseAddr=%lx)\n", 406 numBoards + 1,
405 numBoards + 1, 407 moxa_brdname[moxa_boards[numBoards].boardType-1],
406 moxa_brdname[moxa_boards[numBoards].boardType - 1], 408 moxa_boards[numBoards].baseAddr);
407 moxa_boards[numBoards].baseAddr);
408 numBoards++; 409 numBoards++;
409 } 410 }
410 } 411 }
@@ -413,14 +414,13 @@ static int __init moxa_init(void)
413 for (i = 0; i < MAX_BOARDS; i++) { 414 for (i = 0; i < MAX_BOARDS; i++) {
414 if ((type[i] == MOXA_BOARD_C218_ISA) || 415 if ((type[i] == MOXA_BOARD_C218_ISA) ||
415 (type[i] == MOXA_BOARD_C320_ISA)) { 416 (type[i] == MOXA_BOARD_C320_ISA)) {
416 if (verbose) 417 pr_debug("Moxa board %2d: %s board(baseAddr=%lx)\n",
417 printk("Board %2d: %s board(baseAddr=%lx)\n", 418 numBoards + 1, moxa_brdname[type[i] - 1],
418 numBoards + 1, 419 (unsigned long)baseaddr[i]);
419 moxa_brdname[type[i] - 1],
420 (unsigned long) baseaddr[i]);
421 if (numBoards >= MAX_BOARDS) { 420 if (numBoards >= MAX_BOARDS) {
422 if (verbose) 421 printk(KERN_WARNING "More than %d MOXA "
423 printk("More than %d MOXA Intellio family boards found. Board is ignored.", MAX_BOARDS); 422 "Intellio family boards found. Board "
423 "is ignored.\n", MAX_BOARDS);
424 continue; 424 continue;
425 } 425 }
426 moxa_boards[numBoards].boardType = type[i]; 426 moxa_boards[numBoards].boardType = type[i];
@@ -456,16 +456,14 @@ static void __exit moxa_exit(void)
456{ 456{
457 int i; 457 int i;
458 458
459 if (verbose)
460 printk("Unloading module moxa ...\n");
461
462 del_timer_sync(&moxaTimer); 459 del_timer_sync(&moxaTimer);
463 460
464 for (i = 0; i < MAX_PORTS; i++) 461 for (i = 0; i < MAX_PORTS; i++)
465 del_timer_sync(&moxa_ports[i].emptyTimer); 462 del_timer_sync(&moxa_ports[i].emptyTimer);
466 463
467 if (tty_unregister_driver(moxaDriver)) 464 if (tty_unregister_driver(moxaDriver))
468 printk("Couldn't unregister MOXA Intellio family serial driver\n"); 465 printk(KERN_ERR "Couldn't unregister MOXA Intellio family "
466 "serial driver\n");
469 put_tty_driver(moxaDriver); 467 put_tty_driver(moxaDriver);
470 468
471#ifdef CONFIG_PCI 469#ifdef CONFIG_PCI
@@ -475,9 +473,6 @@ static void __exit moxa_exit(void)
475 for (i = 0; i < MAX_BOARDS; i++) 473 for (i = 0; i < MAX_BOARDS; i++)
476 if (moxa_boards[i].basemem) 474 if (moxa_boards[i].basemem)
477 iounmap(moxa_boards[i].basemem); 475 iounmap(moxa_boards[i].basemem);
478
479 if (verbose)
480 printk("Done\n");
481} 476}
482 477
483module_init(moxa_init); 478module_init(moxa_init);
@@ -532,9 +527,7 @@ static void moxa_close(struct tty_struct *tty, struct file *filp)
532 return; 527 return;
533 } 528 }
534 if (!MoxaPortIsValid(port)) { 529 if (!MoxaPortIsValid(port)) {
535#ifdef SERIAL_DEBUG_CLOSE 530 pr_debug("Invalid portno in moxa_close\n");
536 printk("Invalid portno in moxa_close\n");
537#endif
538 tty->driver_data = NULL; 531 tty->driver_data = NULL;
539 return; 532 return;
540 } 533 }
@@ -547,13 +540,13 @@ static void moxa_close(struct tty_struct *tty, struct file *filp)
547 ch = (struct moxa_port *) tty->driver_data; 540 ch = (struct moxa_port *) tty->driver_data;
548 541
549 if ((tty->count == 1) && (ch->count != 1)) { 542 if ((tty->count == 1) && (ch->count != 1)) {
550 printk("moxa_close: bad serial port count; tty->count is 1, " 543 printk(KERN_WARNING "moxa_close: bad serial port count; "
551 "ch->count is %d\n", ch->count); 544 "tty->count is 1, ch->count is %d\n", ch->count);
552 ch->count = 1; 545 ch->count = 1;
553 } 546 }
554 if (--ch->count < 0) { 547 if (--ch->count < 0) {
555 printk("moxa_close: bad serial port count, device=%s\n", 548 printk(KERN_WARNING "moxa_close: bad serial port count, "
556 tty->name); 549 "device=%s\n", tty->name);
557 ch->count = 0; 550 ch->count = 0;
558 } 551 }
559 if (ch->count) { 552 if (ch->count) {
@@ -971,10 +964,8 @@ static int block_till_ready(struct tty_struct *tty, struct file *filp,
971 */ 964 */
972 retval = 0; 965 retval = 0;
973 add_wait_queue(&ch->open_wait, &wait); 966 add_wait_queue(&ch->open_wait, &wait);
974#ifdef SERIAL_DEBUG_OPEN 967 pr_debug("block_til_ready before block: ttys%d, count = %d\n",
975 printk("block_til_ready before block: ttys%d, count = %d\n", 968 ch->port, ch->count);
976 ch->line, ch->count);
977#endif
978 spin_lock_irqsave(&moxa_lock, flags); 969 spin_lock_irqsave(&moxa_lock, flags);
979 if (!tty_hung_up_p(filp)) 970 if (!tty_hung_up_p(filp))
980 ch->count--; 971 ch->count--;
@@ -1013,10 +1004,8 @@ static int block_till_ready(struct tty_struct *tty, struct file *filp,
1013 ch->count++; 1004 ch->count++;
1014 ch->blocked_open--; 1005 ch->blocked_open--;
1015 spin_unlock_irqrestore(&moxa_lock, flags); 1006 spin_unlock_irqrestore(&moxa_lock, flags);
1016#ifdef SERIAL_DEBUG_OPEN 1007 pr_debug("block_til_ready after blocking: ttys%d, count = %d\n",
1017 printk("block_til_ready after blocking: ttys%d, count = %d\n", 1008 ch->port, ch->count);
1018 ch->line, ch->count);
1019#endif
1020 if (retval) 1009 if (retval)
1021 return (retval); 1010 return (retval);
1022 /* FIXME: review to see if we need to use set_bit on these */ 1011 /* FIXME: review to see if we need to use set_bit on these */