Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

at v2.6.19-rc1 3166 lines 85 kB view raw
1/*****************************************************************************/ 2/* 3 * moxa.c -- MOXA Intellio family multiport serial driver. 4 * 5 * Copyright (C) 1999-2000 Moxa Technologies (support@moxa.com.tw). 6 * 7 * This code is loosely based on the Linux serial driver, written by 8 * Linus Torvalds, Theodore T'so and others. 9 * 10 * This program is free software; you can redistribute it and/or modify 11 * it under the terms of the GNU General Public License as published by 12 * the Free Software Foundation; either version 2 of the License, or 13 * (at your option) any later version. 14 * 15 * This program is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU General Public License for more details. 19 * 20 * You should have received a copy of the GNU General Public License 21 * along with this program; if not, write to the Free Software 22 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 23 */ 24 25/* 26 * MOXA Intellio Series Driver 27 * for : LINUX 28 * date : 1999/1/7 29 * version : 5.1 30 */ 31 32#include <linux/module.h> 33#include <linux/types.h> 34#include <linux/mm.h> 35#include <linux/ioport.h> 36#include <linux/errno.h> 37#include <linux/signal.h> 38#include <linux/sched.h> 39#include <linux/timer.h> 40#include <linux/interrupt.h> 41#include <linux/tty.h> 42#include <linux/tty_flip.h> 43#include <linux/major.h> 44#include <linux/string.h> 45#include <linux/fcntl.h> 46#include <linux/ptrace.h> 47#include <linux/serial.h> 48#include <linux/tty_driver.h> 49#include <linux/delay.h> 50#include <linux/pci.h> 51#include <linux/init.h> 52#include <linux/bitops.h> 53 54#include <asm/system.h> 55#include <asm/io.h> 56#include <asm/uaccess.h> 57 58#define MOXA_VERSION "5.1k" 59 60#define MOXAMAJOR 172 61#define MOXACUMAJOR 173 62 63#define put_to_user(arg1, arg2) put_user(arg1, (unsigned long *)arg2) 64#define get_from_user(arg1, arg2) get_user(arg1, (unsigned int *)arg2) 65 66#define MAX_BOARDS 4 /* Don't change this value */ 67#define MAX_PORTS_PER_BOARD 32 /* Don't change this value */ 68#define MAX_PORTS 128 /* Don't change this value */ 69 70/* 71 * Define the Moxa PCI vendor and device IDs. 72 */ 73#define MOXA_BUS_TYPE_ISA 0 74#define MOXA_BUS_TYPE_PCI 1 75 76#ifndef PCI_VENDOR_ID_MOXA 77#define PCI_VENDOR_ID_MOXA 0x1393 78#endif 79#ifndef PCI_DEVICE_ID_CP204J 80#define PCI_DEVICE_ID_CP204J 0x2040 81#endif 82#ifndef PCI_DEVICE_ID_C218 83#define PCI_DEVICE_ID_C218 0x2180 84#endif 85#ifndef PCI_DEVICE_ID_C320 86#define PCI_DEVICE_ID_C320 0x3200 87#endif 88 89enum { 90 MOXA_BOARD_C218_PCI = 1, 91 MOXA_BOARD_C218_ISA, 92 MOXA_BOARD_C320_PCI, 93 MOXA_BOARD_C320_ISA, 94 MOXA_BOARD_CP204J, 95}; 96 97static char *moxa_brdname[] = 98{ 99 "C218 Turbo PCI series", 100 "C218 Turbo ISA series", 101 "C320 Turbo PCI series", 102 "C320 Turbo ISA series", 103 "CP-204J series", 104}; 105 106#ifdef CONFIG_PCI 107static struct pci_device_id moxa_pcibrds[] = { 108 { PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_C218, PCI_ANY_ID, PCI_ANY_ID, 109 0, 0, MOXA_BOARD_C218_PCI }, 110 { PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_C320, PCI_ANY_ID, PCI_ANY_ID, 111 0, 0, MOXA_BOARD_C320_PCI }, 112 { PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_CP204J, PCI_ANY_ID, PCI_ANY_ID, 113 0, 0, MOXA_BOARD_CP204J }, 114 { 0 } 115}; 116MODULE_DEVICE_TABLE(pci, moxa_pcibrds); 117#endif /* CONFIG_PCI */ 118 119typedef struct _moxa_isa_board_conf { 120 int boardType; 121 int numPorts; 122 unsigned long baseAddr; 123} moxa_isa_board_conf; 124 125static moxa_isa_board_conf moxa_isa_boards[] = 126{ 127/* {MOXA_BOARD_C218_ISA,8,0xDC000}, */ 128}; 129 130typedef struct _moxa_pci_devinfo { 131 ushort busNum; 132 ushort devNum; 133} moxa_pci_devinfo; 134 135typedef struct _moxa_board_conf { 136 int boardType; 137 int numPorts; 138 unsigned long baseAddr; 139 int busType; 140 moxa_pci_devinfo pciInfo; 141} moxa_board_conf; 142 143static moxa_board_conf moxa_boards[MAX_BOARDS]; 144static void __iomem *moxaBaseAddr[MAX_BOARDS]; 145static int loadstat[MAX_BOARDS]; 146 147struct moxa_str { 148 int type; 149 int port; 150 int close_delay; 151 unsigned short closing_wait; 152 int count; 153 int blocked_open; 154 long event; /* long req'd for set_bit --RR */ 155 int asyncflags; 156 unsigned long statusflags; 157 struct tty_struct *tty; 158 int cflag; 159 wait_queue_head_t open_wait; 160 wait_queue_head_t close_wait; 161 struct work_struct tqueue; 162}; 163 164struct mxser_mstatus { 165 tcflag_t cflag; 166 int cts; 167 int dsr; 168 int ri; 169 int dcd; 170}; 171 172static struct mxser_mstatus GMStatus[MAX_PORTS]; 173 174/* statusflags */ 175#define TXSTOPPED 0x1 176#define LOWWAIT 0x2 177#define EMPTYWAIT 0x4 178#define THROTTLE 0x8 179 180/* event */ 181#define MOXA_EVENT_HANGUP 1 182 183#define SERIAL_DO_RESTART 184 185 186#define SERIAL_TYPE_NORMAL 1 187 188#define WAKEUP_CHARS 256 189 190#define PORTNO(x) ((x)->index) 191 192static int verbose = 0; 193static int ttymajor = MOXAMAJOR; 194/* Variables for insmod */ 195#ifdef MODULE 196static int baseaddr[] = {0, 0, 0, 0}; 197static int type[] = {0, 0, 0, 0}; 198static int numports[] = {0, 0, 0, 0}; 199#endif 200 201MODULE_AUTHOR("William Chen"); 202MODULE_DESCRIPTION("MOXA Intellio Family Multiport Board Device Driver"); 203MODULE_LICENSE("GPL"); 204#ifdef MODULE 205module_param_array(type, int, NULL, 0); 206module_param_array(baseaddr, int, NULL, 0); 207module_param_array(numports, int, NULL, 0); 208#endif 209module_param(ttymajor, int, 0); 210module_param(verbose, bool, 0644); 211 212static struct tty_driver *moxaDriver; 213static struct moxa_str moxaChannels[MAX_PORTS]; 214static unsigned char *moxaXmitBuff; 215static int moxaTimer_on; 216static struct timer_list moxaTimer; 217static int moxaEmptyTimer_on[MAX_PORTS]; 218static struct timer_list moxaEmptyTimer[MAX_PORTS]; 219static struct semaphore moxaBuffSem; 220 221/* 222 * static functions: 223 */ 224static void do_moxa_softint(void *); 225static int moxa_open(struct tty_struct *, struct file *); 226static void moxa_close(struct tty_struct *, struct file *); 227static int moxa_write(struct tty_struct *, const unsigned char *, int); 228static int moxa_write_room(struct tty_struct *); 229static void moxa_flush_buffer(struct tty_struct *); 230static int moxa_chars_in_buffer(struct tty_struct *); 231static void moxa_flush_chars(struct tty_struct *); 232static void moxa_put_char(struct tty_struct *, unsigned char); 233static int moxa_ioctl(struct tty_struct *, struct file *, unsigned int, unsigned long); 234static void moxa_throttle(struct tty_struct *); 235static void moxa_unthrottle(struct tty_struct *); 236static void moxa_set_termios(struct tty_struct *, struct termios *); 237static void moxa_stop(struct tty_struct *); 238static void moxa_start(struct tty_struct *); 239static void moxa_hangup(struct tty_struct *); 240static int moxa_tiocmget(struct tty_struct *tty, struct file *file); 241static int moxa_tiocmset(struct tty_struct *tty, struct file *file, 242 unsigned int set, unsigned int clear); 243static void moxa_poll(unsigned long); 244static void set_tty_param(struct tty_struct *); 245static int block_till_ready(struct tty_struct *, struct file *, 246 struct moxa_str *); 247static void setup_empty_event(struct tty_struct *); 248static void check_xmit_empty(unsigned long); 249static void shut_down(struct moxa_str *); 250static void receive_data(struct moxa_str *); 251/* 252 * moxa board interface functions: 253 */ 254static void MoxaDriverInit(void); 255static int MoxaDriverIoctl(unsigned int, unsigned long, int); 256static int MoxaDriverPoll(void); 257static int MoxaPortsOfCard(int); 258static int MoxaPortIsValid(int); 259static void MoxaPortEnable(int); 260static void MoxaPortDisable(int); 261static long MoxaPortGetMaxBaud(int); 262static long MoxaPortSetBaud(int, long); 263static int MoxaPortSetTermio(int, struct termios *, speed_t); 264static int MoxaPortGetLineOut(int, int *, int *); 265static void MoxaPortLineCtrl(int, int, int); 266static void MoxaPortFlowCtrl(int, int, int, int, int, int); 267static int MoxaPortLineStatus(int); 268static int MoxaPortDCDChange(int); 269static int MoxaPortDCDON(int); 270static void MoxaPortFlushData(int, int); 271static int MoxaPortWriteData(int, unsigned char *, int); 272static int MoxaPortReadData(int, struct tty_struct *tty); 273static int MoxaPortTxQueue(int); 274static int MoxaPortRxQueue(int); 275static int MoxaPortTxFree(int); 276static void MoxaPortTxDisable(int); 277static void MoxaPortTxEnable(int); 278static int MoxaPortResetBrkCnt(int); 279static void MoxaPortSendBreak(int, int); 280static int moxa_get_serial_info(struct moxa_str *, struct serial_struct __user *); 281static int moxa_set_serial_info(struct moxa_str *, struct serial_struct __user *); 282static void MoxaSetFifo(int port, int enable); 283 284static const struct tty_operations moxa_ops = { 285 .open = moxa_open, 286 .close = moxa_close, 287 .write = moxa_write, 288 .write_room = moxa_write_room, 289 .flush_buffer = moxa_flush_buffer, 290 .chars_in_buffer = moxa_chars_in_buffer, 291 .flush_chars = moxa_flush_chars, 292 .put_char = moxa_put_char, 293 .ioctl = moxa_ioctl, 294 .throttle = moxa_throttle, 295 .unthrottle = moxa_unthrottle, 296 .set_termios = moxa_set_termios, 297 .stop = moxa_stop, 298 .start = moxa_start, 299 .hangup = moxa_hangup, 300 .tiocmget = moxa_tiocmget, 301 .tiocmset = moxa_tiocmset, 302}; 303 304static DEFINE_SPINLOCK(moxa_lock); 305 306#ifdef CONFIG_PCI 307static int moxa_get_PCI_conf(struct pci_dev *p, int board_type, moxa_board_conf * board) 308{ 309 board->baseAddr = pci_resource_start (p, 2); 310 board->boardType = board_type; 311 switch (board_type) { 312 case MOXA_BOARD_C218_ISA: 313 case MOXA_BOARD_C218_PCI: 314 board->numPorts = 8; 315 break; 316 317 case MOXA_BOARD_CP204J: 318 board->numPorts = 4; 319 break; 320 default: 321 board->numPorts = 0; 322 break; 323 } 324 board->busType = MOXA_BUS_TYPE_PCI; 325 board->pciInfo.busNum = p->bus->number; 326 board->pciInfo.devNum = p->devfn >> 3; 327 328 return (0); 329} 330#endif /* CONFIG_PCI */ 331 332static int __init moxa_init(void) 333{ 334 int i, numBoards; 335 struct moxa_str *ch; 336 337 printk(KERN_INFO "MOXA Intellio family driver version %s\n", MOXA_VERSION); 338 moxaDriver = alloc_tty_driver(MAX_PORTS + 1); 339 if (!moxaDriver) 340 return -ENOMEM; 341 342 init_MUTEX(&moxaBuffSem); 343 moxaDriver->owner = THIS_MODULE; 344 moxaDriver->name = "ttyMX"; 345 moxaDriver->major = ttymajor; 346 moxaDriver->minor_start = 0; 347 moxaDriver->type = TTY_DRIVER_TYPE_SERIAL; 348 moxaDriver->subtype = SERIAL_TYPE_NORMAL; 349 moxaDriver->init_termios = tty_std_termios; 350 moxaDriver->init_termios.c_iflag = 0; 351 moxaDriver->init_termios.c_oflag = 0; 352 moxaDriver->init_termios.c_cflag = B9600 | CS8 | CREAD | CLOCAL | HUPCL; 353 moxaDriver->init_termios.c_lflag = 0; 354 moxaDriver->flags = TTY_DRIVER_REAL_RAW; 355 tty_set_operations(moxaDriver, &moxa_ops); 356 357 moxaXmitBuff = NULL; 358 359 for (i = 0, ch = moxaChannels; i < MAX_PORTS; i++, ch++) { 360 ch->type = PORT_16550A; 361 ch->port = i; 362 INIT_WORK(&ch->tqueue, do_moxa_softint, ch); 363 ch->tty = NULL; 364 ch->close_delay = 5 * HZ / 10; 365 ch->closing_wait = 30 * HZ; 366 ch->count = 0; 367 ch->blocked_open = 0; 368 ch->cflag = B9600 | CS8 | CREAD | CLOCAL | HUPCL; 369 init_waitqueue_head(&ch->open_wait); 370 init_waitqueue_head(&ch->close_wait); 371 } 372 373 for (i = 0; i < MAX_BOARDS; i++) { 374 moxa_boards[i].boardType = 0; 375 moxa_boards[i].numPorts = 0; 376 moxa_boards[i].baseAddr = 0; 377 moxa_boards[i].busType = 0; 378 moxa_boards[i].pciInfo.busNum = 0; 379 moxa_boards[i].pciInfo.devNum = 0; 380 } 381 MoxaDriverInit(); 382 printk("Tty devices major number = %d\n", ttymajor); 383 384 if (tty_register_driver(moxaDriver)) { 385 printk(KERN_ERR "Couldn't install MOXA Smartio family driver !\n"); 386 put_tty_driver(moxaDriver); 387 return -1; 388 } 389 for (i = 0; i < MAX_PORTS; i++) { 390 init_timer(&moxaEmptyTimer[i]); 391 moxaEmptyTimer[i].function = check_xmit_empty; 392 moxaEmptyTimer[i].data = (unsigned long) & moxaChannels[i]; 393 moxaEmptyTimer_on[i] = 0; 394 } 395 396 init_timer(&moxaTimer); 397 moxaTimer.function = moxa_poll; 398 moxaTimer.expires = jiffies + (HZ / 50); 399 moxaTimer_on = 1; 400 add_timer(&moxaTimer); 401 402 /* Find the boards defined in source code */ 403 numBoards = 0; 404 for (i = 0; i < MAX_BOARDS; i++) { 405 if ((moxa_isa_boards[i].boardType == MOXA_BOARD_C218_ISA) || 406 (moxa_isa_boards[i].boardType == MOXA_BOARD_C320_ISA)) { 407 moxa_boards[numBoards].boardType = moxa_isa_boards[i].boardType; 408 if (moxa_isa_boards[i].boardType == MOXA_BOARD_C218_ISA) 409 moxa_boards[numBoards].numPorts = 8; 410 else 411 moxa_boards[numBoards].numPorts = moxa_isa_boards[i].numPorts; 412 moxa_boards[numBoards].busType = MOXA_BUS_TYPE_ISA; 413 moxa_boards[numBoards].baseAddr = moxa_isa_boards[i].baseAddr; 414 if (verbose) 415 printk("Board %2d: %s board(baseAddr=%lx)\n", 416 numBoards + 1, 417 moxa_brdname[moxa_boards[numBoards].boardType - 1], 418 moxa_boards[numBoards].baseAddr); 419 numBoards++; 420 } 421 } 422 /* Find the boards defined form module args. */ 423#ifdef MODULE 424 for (i = 0; i < MAX_BOARDS; i++) { 425 if ((type[i] == MOXA_BOARD_C218_ISA) || 426 (type[i] == MOXA_BOARD_C320_ISA)) { 427 if (verbose) 428 printk("Board %2d: %s board(baseAddr=%lx)\n", 429 numBoards + 1, 430 moxa_brdname[type[i] - 1], 431 (unsigned long) baseaddr[i]); 432 if (numBoards >= MAX_BOARDS) { 433 if (verbose) 434 printk("More than %d MOXA Intellio family boards found. Board is ignored.", MAX_BOARDS); 435 continue; 436 } 437 moxa_boards[numBoards].boardType = type[i]; 438 if (moxa_isa_boards[i].boardType == MOXA_BOARD_C218_ISA) 439 moxa_boards[numBoards].numPorts = 8; 440 else 441 moxa_boards[numBoards].numPorts = numports[i]; 442 moxa_boards[numBoards].busType = MOXA_BUS_TYPE_ISA; 443 moxa_boards[numBoards].baseAddr = baseaddr[i]; 444 numBoards++; 445 } 446 } 447#endif 448 /* Find PCI boards here */ 449#ifdef CONFIG_PCI 450 { 451 struct pci_dev *p = NULL; 452 int n = ARRAY_SIZE(moxa_pcibrds) - 1; 453 i = 0; 454 while (i < n) { 455 while ((p = pci_get_device(moxa_pcibrds[i].vendor, moxa_pcibrds[i].device, p))!=NULL) 456 { 457 if (pci_enable_device(p)) 458 continue; 459 if (numBoards >= MAX_BOARDS) { 460 if (verbose) 461 printk("More than %d MOXA Intellio family boards found. Board is ignored.", MAX_BOARDS); 462 } else { 463 moxa_get_PCI_conf(p, moxa_pcibrds[i].driver_data, 464 &moxa_boards[numBoards]); 465 numBoards++; 466 } 467 } 468 i++; 469 } 470 } 471#endif 472 for (i = 0; i < numBoards; i++) { 473 moxaBaseAddr[i] = ioremap((unsigned long) moxa_boards[i].baseAddr, 0x4000); 474 } 475 476 return (0); 477} 478 479static void __exit moxa_exit(void) 480{ 481 int i; 482 483 if (verbose) 484 printk("Unloading module moxa ...\n"); 485 486 if (moxaTimer_on) 487 del_timer(&moxaTimer); 488 489 for (i = 0; i < MAX_PORTS; i++) 490 if (moxaEmptyTimer_on[i]) 491 del_timer(&moxaEmptyTimer[i]); 492 493 if (tty_unregister_driver(moxaDriver)) 494 printk("Couldn't unregister MOXA Intellio family serial driver\n"); 495 put_tty_driver(moxaDriver); 496 if (verbose) 497 printk("Done\n"); 498} 499 500module_init(moxa_init); 501module_exit(moxa_exit); 502 503static void do_moxa_softint(void *private_) 504{ 505 struct moxa_str *ch = (struct moxa_str *) private_; 506 struct tty_struct *tty; 507 508 if (ch && (tty = ch->tty)) { 509 if (test_and_clear_bit(MOXA_EVENT_HANGUP, &ch->event)) { 510 tty_hangup(tty); /* FIXME: module removal race here - AKPM */ 511 wake_up_interruptible(&ch->open_wait); 512 ch->asyncflags &= ~ASYNC_NORMAL_ACTIVE; 513 } 514 } 515} 516 517static int moxa_open(struct tty_struct *tty, struct file *filp) 518{ 519 struct moxa_str *ch; 520 int port; 521 int retval; 522 unsigned long page; 523 524 port = PORTNO(tty); 525 if (port == MAX_PORTS) { 526 return (0); 527 } 528 if (!MoxaPortIsValid(port)) { 529 tty->driver_data = NULL; 530 return (-ENODEV); 531 } 532 down(&moxaBuffSem); 533 if (!moxaXmitBuff) { 534 page = get_zeroed_page(GFP_KERNEL); 535 if (!page) { 536 up(&moxaBuffSem); 537 return (-ENOMEM); 538 } 539 /* This test is guarded by the BuffSem so no longer needed 540 delete me in 2.5 */ 541 if (moxaXmitBuff) 542 free_page(page); 543 else 544 moxaXmitBuff = (unsigned char *) page; 545 } 546 up(&moxaBuffSem); 547 548 ch = &moxaChannels[port]; 549 ch->count++; 550 tty->driver_data = ch; 551 ch->tty = tty; 552 if (!(ch->asyncflags & ASYNC_INITIALIZED)) { 553 ch->statusflags = 0; 554 set_tty_param(tty); 555 MoxaPortLineCtrl(ch->port, 1, 1); 556 MoxaPortEnable(ch->port); 557 ch->asyncflags |= ASYNC_INITIALIZED; 558 } 559 retval = block_till_ready(tty, filp, ch); 560 561 moxa_unthrottle(tty); 562 563 if (ch->type == PORT_16550A) { 564 MoxaSetFifo(ch->port, 1); 565 } else { 566 MoxaSetFifo(ch->port, 0); 567 } 568 569 return (retval); 570} 571 572static void moxa_close(struct tty_struct *tty, struct file *filp) 573{ 574 struct moxa_str *ch; 575 int port; 576 577 port = PORTNO(tty); 578 if (port == MAX_PORTS) { 579 return; 580 } 581 if (!MoxaPortIsValid(port)) { 582#ifdef SERIAL_DEBUG_CLOSE 583 printk("Invalid portno in moxa_close\n"); 584#endif 585 tty->driver_data = NULL; 586 return; 587 } 588 if (tty->driver_data == NULL) { 589 return; 590 } 591 if (tty_hung_up_p(filp)) { 592 return; 593 } 594 ch = (struct moxa_str *) tty->driver_data; 595 596 if ((tty->count == 1) && (ch->count != 1)) { 597 printk("moxa_close: bad serial port count; tty->count is 1, " 598 "ch->count is %d\n", ch->count); 599 ch->count = 1; 600 } 601 if (--ch->count < 0) { 602 printk("moxa_close: bad serial port count, device=%s\n", 603 tty->name); 604 ch->count = 0; 605 } 606 if (ch->count) { 607 return; 608 } 609 ch->asyncflags |= ASYNC_CLOSING; 610 611 ch->cflag = tty->termios->c_cflag; 612 if (ch->asyncflags & ASYNC_INITIALIZED) { 613 setup_empty_event(tty); 614 tty_wait_until_sent(tty, 30 * HZ); /* 30 seconds timeout */ 615 moxaEmptyTimer_on[ch->port] = 0; 616 del_timer(&moxaEmptyTimer[ch->port]); 617 } 618 shut_down(ch); 619 MoxaPortFlushData(port, 2); 620 621 if (tty->driver->flush_buffer) 622 tty->driver->flush_buffer(tty); 623 tty_ldisc_flush(tty); 624 625 tty->closing = 0; 626 ch->event = 0; 627 ch->tty = NULL; 628 if (ch->blocked_open) { 629 if (ch->close_delay) { 630 msleep_interruptible(jiffies_to_msecs(ch->close_delay)); 631 } 632 wake_up_interruptible(&ch->open_wait); 633 } 634 ch->asyncflags &= ~(ASYNC_NORMAL_ACTIVE | ASYNC_CLOSING); 635 wake_up_interruptible(&ch->close_wait); 636} 637 638static int moxa_write(struct tty_struct *tty, 639 const unsigned char *buf, int count) 640{ 641 struct moxa_str *ch; 642 int len, port; 643 unsigned long flags; 644 645 ch = (struct moxa_str *) tty->driver_data; 646 if (ch == NULL) 647 return (0); 648 port = ch->port; 649 650 spin_lock_irqsave(&moxa_lock, flags); 651 len = MoxaPortWriteData(port, (unsigned char *) buf, count); 652 spin_unlock_irqrestore(&moxa_lock, flags); 653 654 /********************************************* 655 if ( !(ch->statusflags & LOWWAIT) && 656 ((len != count) || (MoxaPortTxFree(port) <= 100)) ) 657 ************************************************/ 658 ch->statusflags |= LOWWAIT; 659 return (len); 660} 661 662static int moxa_write_room(struct tty_struct *tty) 663{ 664 struct moxa_str *ch; 665 666 if (tty->stopped) 667 return (0); 668 ch = (struct moxa_str *) tty->driver_data; 669 if (ch == NULL) 670 return (0); 671 return (MoxaPortTxFree(ch->port)); 672} 673 674static void moxa_flush_buffer(struct tty_struct *tty) 675{ 676 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 677 678 if (ch == NULL) 679 return; 680 MoxaPortFlushData(ch->port, 1); 681 tty_wakeup(tty); 682} 683 684static int moxa_chars_in_buffer(struct tty_struct *tty) 685{ 686 int chars; 687 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 688 689 /* 690 * Sigh...I have to check if driver_data is NULL here, because 691 * if an open() fails, the TTY subsystem eventually calls 692 * tty_wait_until_sent(), which calls the driver's chars_in_buffer() 693 * routine. And since the open() failed, we return 0 here. TDJ 694 */ 695 if (ch == NULL) 696 return (0); 697 chars = MoxaPortTxQueue(ch->port); 698 if (chars) { 699 /* 700 * Make it possible to wakeup anything waiting for output 701 * in tty_ioctl.c, etc. 702 */ 703 if (!(ch->statusflags & EMPTYWAIT)) 704 setup_empty_event(tty); 705 } 706 return (chars); 707} 708 709static void moxa_flush_chars(struct tty_struct *tty) 710{ 711 /* 712 * Don't think I need this, because this is called to empty the TX 713 * buffer for the 16450, 16550, etc. 714 */ 715} 716 717static void moxa_put_char(struct tty_struct *tty, unsigned char c) 718{ 719 struct moxa_str *ch; 720 int port; 721 unsigned long flags; 722 723 ch = (struct moxa_str *) tty->driver_data; 724 if (ch == NULL) 725 return; 726 port = ch->port; 727 spin_lock_irqsave(&moxa_lock, flags); 728 moxaXmitBuff[0] = c; 729 MoxaPortWriteData(port, moxaXmitBuff, 1); 730 spin_unlock_irqrestore(&moxa_lock, flags); 731 /************************************************ 732 if ( !(ch->statusflags & LOWWAIT) && (MoxaPortTxFree(port) <= 100) ) 733 *************************************************/ 734 ch->statusflags |= LOWWAIT; 735} 736 737static int moxa_tiocmget(struct tty_struct *tty, struct file *file) 738{ 739 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 740 int port; 741 int flag = 0, dtr, rts; 742 743 port = PORTNO(tty); 744 if ((port != MAX_PORTS) && (!ch)) 745 return (-EINVAL); 746 747 MoxaPortGetLineOut(ch->port, &dtr, &rts); 748 if (dtr) 749 flag |= TIOCM_DTR; 750 if (rts) 751 flag |= TIOCM_RTS; 752 dtr = MoxaPortLineStatus(ch->port); 753 if (dtr & 1) 754 flag |= TIOCM_CTS; 755 if (dtr & 2) 756 flag |= TIOCM_DSR; 757 if (dtr & 4) 758 flag |= TIOCM_CD; 759 return flag; 760} 761 762static int moxa_tiocmset(struct tty_struct *tty, struct file *file, 763 unsigned int set, unsigned int clear) 764{ 765 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 766 int port; 767 int dtr, rts; 768 769 port = PORTNO(tty); 770 if ((port != MAX_PORTS) && (!ch)) 771 return (-EINVAL); 772 773 MoxaPortGetLineOut(ch->port, &dtr, &rts); 774 if (set & TIOCM_RTS) 775 rts = 1; 776 if (set & TIOCM_DTR) 777 dtr = 1; 778 if (clear & TIOCM_RTS) 779 rts = 0; 780 if (clear & TIOCM_DTR) 781 dtr = 0; 782 MoxaPortLineCtrl(ch->port, dtr, rts); 783 return 0; 784} 785 786static int moxa_ioctl(struct tty_struct *tty, struct file *file, 787 unsigned int cmd, unsigned long arg) 788{ 789 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 790 register int port; 791 void __user *argp = (void __user *)arg; 792 int retval; 793 794 port = PORTNO(tty); 795 if ((port != MAX_PORTS) && (!ch)) 796 return (-EINVAL); 797 798 switch (cmd) { 799 case TCSBRK: /* SVID version: non-zero arg --> no break */ 800 retval = tty_check_change(tty); 801 if (retval) 802 return (retval); 803 setup_empty_event(tty); 804 tty_wait_until_sent(tty, 0); 805 if (!arg) 806 MoxaPortSendBreak(ch->port, 0); 807 return (0); 808 case TCSBRKP: /* support for POSIX tcsendbreak() */ 809 retval = tty_check_change(tty); 810 if (retval) 811 return (retval); 812 setup_empty_event(tty); 813 tty_wait_until_sent(tty, 0); 814 MoxaPortSendBreak(ch->port, arg); 815 return (0); 816 case TIOCGSOFTCAR: 817 return put_user(C_CLOCAL(tty) ? 1 : 0, (unsigned long __user *) argp); 818 case TIOCSSOFTCAR: 819 if(get_user(retval, (unsigned long __user *) argp)) 820 return -EFAULT; 821 arg = retval; 822 tty->termios->c_cflag = ((tty->termios->c_cflag & ~CLOCAL) | 823 (arg ? CLOCAL : 0)); 824 if (C_CLOCAL(tty)) 825 ch->asyncflags &= ~ASYNC_CHECK_CD; 826 else 827 ch->asyncflags |= ASYNC_CHECK_CD; 828 return (0); 829 case TIOCGSERIAL: 830 return moxa_get_serial_info(ch, argp); 831 832 case TIOCSSERIAL: 833 return moxa_set_serial_info(ch, argp); 834 default: 835 retval = MoxaDriverIoctl(cmd, arg, port); 836 } 837 return (retval); 838} 839 840static void moxa_throttle(struct tty_struct *tty) 841{ 842 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 843 844 ch->statusflags |= THROTTLE; 845} 846 847static void moxa_unthrottle(struct tty_struct *tty) 848{ 849 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 850 851 ch->statusflags &= ~THROTTLE; 852} 853 854static void moxa_set_termios(struct tty_struct *tty, 855 struct termios *old_termios) 856{ 857 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 858 859 if (ch == NULL) 860 return; 861 set_tty_param(tty); 862 if (!(old_termios->c_cflag & CLOCAL) && 863 (tty->termios->c_cflag & CLOCAL)) 864 wake_up_interruptible(&ch->open_wait); 865} 866 867static void moxa_stop(struct tty_struct *tty) 868{ 869 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 870 871 if (ch == NULL) 872 return; 873 MoxaPortTxDisable(ch->port); 874 ch->statusflags |= TXSTOPPED; 875} 876 877 878static void moxa_start(struct tty_struct *tty) 879{ 880 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 881 882 if (ch == NULL) 883 return; 884 885 if (!(ch->statusflags & TXSTOPPED)) 886 return; 887 888 MoxaPortTxEnable(ch->port); 889 ch->statusflags &= ~TXSTOPPED; 890} 891 892static void moxa_hangup(struct tty_struct *tty) 893{ 894 struct moxa_str *ch = (struct moxa_str *) tty->driver_data; 895 896 moxa_flush_buffer(tty); 897 shut_down(ch); 898 ch->event = 0; 899 ch->count = 0; 900 ch->asyncflags &= ~ASYNC_NORMAL_ACTIVE; 901 ch->tty = NULL; 902 wake_up_interruptible(&ch->open_wait); 903} 904 905static void moxa_poll(unsigned long ignored) 906{ 907 register int card; 908 struct moxa_str *ch; 909 struct tty_struct *tp; 910 int i, ports; 911 912 moxaTimer_on = 0; 913 del_timer(&moxaTimer); 914 915 if (MoxaDriverPoll() < 0) { 916 moxaTimer.function = moxa_poll; 917 moxaTimer.expires = jiffies + (HZ / 50); 918 moxaTimer_on = 1; 919 add_timer(&moxaTimer); 920 return; 921 } 922 for (card = 0; card < MAX_BOARDS; card++) { 923 if ((ports = MoxaPortsOfCard(card)) <= 0) 924 continue; 925 ch = &moxaChannels[card * MAX_PORTS_PER_BOARD]; 926 for (i = 0; i < ports; i++, ch++) { 927 if ((ch->asyncflags & ASYNC_INITIALIZED) == 0) 928 continue; 929 if (!(ch->statusflags & THROTTLE) && 930 (MoxaPortRxQueue(ch->port) > 0)) 931 receive_data(ch); 932 if ((tp = ch->tty) == 0) 933 continue; 934 if (ch->statusflags & LOWWAIT) { 935 if (MoxaPortTxQueue(ch->port) <= WAKEUP_CHARS) { 936 if (!tp->stopped) { 937 ch->statusflags &= ~LOWWAIT; 938 tty_wakeup(tp); 939 } 940 } 941 } 942 if (!I_IGNBRK(tp) && (MoxaPortResetBrkCnt(ch->port) > 0)) { 943 tty_insert_flip_char(tp, 0, TTY_BREAK); 944 tty_schedule_flip(tp); 945 } 946 if (MoxaPortDCDChange(ch->port)) { 947 if (ch->asyncflags & ASYNC_CHECK_CD) { 948 if (MoxaPortDCDON(ch->port)) 949 wake_up_interruptible(&ch->open_wait); 950 else { 951 set_bit(MOXA_EVENT_HANGUP, &ch->event); 952 schedule_work(&ch->tqueue); 953 } 954 } 955 } 956 } 957 } 958 959 moxaTimer.function = moxa_poll; 960 moxaTimer.expires = jiffies + (HZ / 50); 961 moxaTimer_on = 1; 962 add_timer(&moxaTimer); 963} 964 965/******************************************************************************/ 966 967static void set_tty_param(struct tty_struct *tty) 968{ 969 register struct termios *ts; 970 struct moxa_str *ch; 971 int rts, cts, txflow, rxflow, xany; 972 973 ch = (struct moxa_str *) tty->driver_data; 974 ts = tty->termios; 975 if (ts->c_cflag & CLOCAL) 976 ch->asyncflags &= ~ASYNC_CHECK_CD; 977 else 978 ch->asyncflags |= ASYNC_CHECK_CD; 979 rts = cts = txflow = rxflow = xany = 0; 980 if (ts->c_cflag & CRTSCTS) 981 rts = cts = 1; 982 if (ts->c_iflag & IXON) 983 txflow = 1; 984 if (ts->c_iflag & IXOFF) 985 rxflow = 1; 986 if (ts->c_iflag & IXANY) 987 xany = 1; 988 MoxaPortFlowCtrl(ch->port, rts, cts, txflow, rxflow, xany); 989 MoxaPortSetTermio(ch->port, ts, tty_get_baud_rate(tty)); 990} 991 992static int block_till_ready(struct tty_struct *tty, struct file *filp, 993 struct moxa_str *ch) 994{ 995 DECLARE_WAITQUEUE(wait,current); 996 unsigned long flags; 997 int retval; 998 int do_clocal = C_CLOCAL(tty); 999 1000 /* 1001 * If the device is in the middle of being closed, then block 1002 * until it's done, and then try again. 1003 */ 1004 if (tty_hung_up_p(filp) || (ch->asyncflags & ASYNC_CLOSING)) { 1005 if (ch->asyncflags & ASYNC_CLOSING) 1006 interruptible_sleep_on(&ch->close_wait); 1007#ifdef SERIAL_DO_RESTART 1008 if (ch->asyncflags & ASYNC_HUP_NOTIFY) 1009 return (-EAGAIN); 1010 else 1011 return (-ERESTARTSYS); 1012#else 1013 return (-EAGAIN); 1014#endif 1015 } 1016 /* 1017 * If non-blocking mode is set, then make the check up front 1018 * and then exit. 1019 */ 1020 if (filp->f_flags & O_NONBLOCK) { 1021 ch->asyncflags |= ASYNC_NORMAL_ACTIVE; 1022 return (0); 1023 } 1024 /* 1025 * Block waiting for the carrier detect and the line to become free 1026 */ 1027 retval = 0; 1028 add_wait_queue(&ch->open_wait, &wait); 1029#ifdef SERIAL_DEBUG_OPEN 1030 printk("block_til_ready before block: ttys%d, count = %d\n", 1031 ch->line, ch->count); 1032#endif 1033 spin_lock_irqsave(&moxa_lock, flags); 1034 if (!tty_hung_up_p(filp)) 1035 ch->count--; 1036 ch->blocked_open++; 1037 spin_unlock_irqrestore(&moxa_lock, flags); 1038 1039 while (1) { 1040 set_current_state(TASK_INTERRUPTIBLE); 1041 if (tty_hung_up_p(filp) || 1042 !(ch->asyncflags & ASYNC_INITIALIZED)) { 1043#ifdef SERIAL_DO_RESTART 1044 if (ch->asyncflags & ASYNC_HUP_NOTIFY) 1045 retval = -EAGAIN; 1046 else 1047 retval = -ERESTARTSYS; 1048#else 1049 retval = -EAGAIN; 1050#endif 1051 break; 1052 } 1053 if (!(ch->asyncflags & ASYNC_CLOSING) && (do_clocal || 1054 MoxaPortDCDON(ch->port))) 1055 break; 1056 1057 if (signal_pending(current)) { 1058 retval = -ERESTARTSYS; 1059 break; 1060 } 1061 schedule(); 1062 } 1063 set_current_state(TASK_RUNNING); 1064 remove_wait_queue(&ch->open_wait, &wait); 1065 1066 spin_lock_irqsave(&moxa_lock, flags); 1067 if (!tty_hung_up_p(filp)) 1068 ch->count++; 1069 ch->blocked_open--; 1070 spin_unlock_irqrestore(&moxa_lock, flags); 1071#ifdef SERIAL_DEBUG_OPEN 1072 printk("block_til_ready after blocking: ttys%d, count = %d\n", 1073 ch->line, ch->count); 1074#endif 1075 if (retval) 1076 return (retval); 1077 /* FIXME: review to see if we need to use set_bit on these */ 1078 ch->asyncflags |= ASYNC_NORMAL_ACTIVE; 1079 return 0; 1080} 1081 1082static void setup_empty_event(struct tty_struct *tty) 1083{ 1084 struct moxa_str *ch = tty->driver_data; 1085 unsigned long flags; 1086 1087 spin_lock_irqsave(&moxa_lock, flags); 1088 ch->statusflags |= EMPTYWAIT; 1089 moxaEmptyTimer_on[ch->port] = 0; 1090 del_timer(&moxaEmptyTimer[ch->port]); 1091 moxaEmptyTimer[ch->port].expires = jiffies + HZ; 1092 moxaEmptyTimer_on[ch->port] = 1; 1093 add_timer(&moxaEmptyTimer[ch->port]); 1094 spin_unlock_irqrestore(&moxa_lock, flags); 1095} 1096 1097static void check_xmit_empty(unsigned long data) 1098{ 1099 struct moxa_str *ch; 1100 1101 ch = (struct moxa_str *) data; 1102 moxaEmptyTimer_on[ch->port] = 0; 1103 del_timer(&moxaEmptyTimer[ch->port]); 1104 if (ch->tty && (ch->statusflags & EMPTYWAIT)) { 1105 if (MoxaPortTxQueue(ch->port) == 0) { 1106 ch->statusflags &= ~EMPTYWAIT; 1107 tty_wakeup(ch->tty); 1108 return; 1109 } 1110 moxaEmptyTimer[ch->port].expires = jiffies + HZ; 1111 moxaEmptyTimer_on[ch->port] = 1; 1112 add_timer(&moxaEmptyTimer[ch->port]); 1113 } else 1114 ch->statusflags &= ~EMPTYWAIT; 1115} 1116 1117static void shut_down(struct moxa_str *ch) 1118{ 1119 struct tty_struct *tp; 1120 1121 if (!(ch->asyncflags & ASYNC_INITIALIZED)) 1122 return; 1123 1124 tp = ch->tty; 1125 1126 MoxaPortDisable(ch->port); 1127 1128 /* 1129 * If we're a modem control device and HUPCL is on, drop RTS & DTR. 1130 */ 1131 if (tp->termios->c_cflag & HUPCL) 1132 MoxaPortLineCtrl(ch->port, 0, 0); 1133 1134 ch->asyncflags &= ~ASYNC_INITIALIZED; 1135} 1136 1137static void receive_data(struct moxa_str *ch) 1138{ 1139 struct tty_struct *tp; 1140 struct termios *ts; 1141 unsigned long flags; 1142 1143 ts = NULL; 1144 tp = ch->tty; 1145 if (tp) 1146 ts = tp->termios; 1147 /************************************************** 1148 if ( !tp || !ts || !(ts->c_cflag & CREAD) ) { 1149 *****************************************************/ 1150 if (!tp || !ts) { 1151 MoxaPortFlushData(ch->port, 0); 1152 return; 1153 } 1154 spin_lock_irqsave(&moxa_lock, flags); 1155 MoxaPortReadData(ch->port, tp); 1156 spin_unlock_irqrestore(&moxa_lock, flags); 1157 tty_schedule_flip(tp); 1158} 1159 1160#define Magic_code 0x404 1161 1162/* 1163 * System Configuration 1164 */ 1165/* 1166 * for C218 BIOS initialization 1167 */ 1168#define C218_ConfBase 0x800 1169#define C218_status (C218_ConfBase + 0) /* BIOS running status */ 1170#define C218_diag (C218_ConfBase + 2) /* diagnostic status */ 1171#define C218_key (C218_ConfBase + 4) /* WORD (0x218 for C218) */ 1172#define C218DLoad_len (C218_ConfBase + 6) /* WORD */ 1173#define C218check_sum (C218_ConfBase + 8) /* BYTE */ 1174#define C218chksum_ok (C218_ConfBase + 0x0a) /* BYTE (1:ok) */ 1175#define C218_TestRx (C218_ConfBase + 0x10) /* 8 bytes for 8 ports */ 1176#define C218_TestTx (C218_ConfBase + 0x18) /* 8 bytes for 8 ports */ 1177#define C218_RXerr (C218_ConfBase + 0x20) /* 8 bytes for 8 ports */ 1178#define C218_ErrFlag (C218_ConfBase + 0x28) /* 8 bytes for 8 ports */ 1179 1180#define C218_LoadBuf 0x0F00 1181#define C218_KeyCode 0x218 1182#define CP204J_KeyCode 0x204 1183 1184/* 1185 * for C320 BIOS initialization 1186 */ 1187#define C320_ConfBase 0x800 1188#define C320_LoadBuf 0x0f00 1189#define STS_init 0x05 /* for C320_status */ 1190 1191#define C320_status C320_ConfBase + 0 /* BIOS running status */ 1192#define C320_diag C320_ConfBase + 2 /* diagnostic status */ 1193#define C320_key C320_ConfBase + 4 /* WORD (0320H for C320) */ 1194#define C320DLoad_len C320_ConfBase + 6 /* WORD */ 1195#define C320check_sum C320_ConfBase + 8 /* WORD */ 1196#define C320chksum_ok C320_ConfBase + 0x0a /* WORD (1:ok) */ 1197#define C320bapi_len C320_ConfBase + 0x0c /* WORD */ 1198#define C320UART_no C320_ConfBase + 0x0e /* WORD */ 1199 1200#define C320_KeyCode 0x320 1201 1202#define FixPage_addr 0x0000 /* starting addr of static page */ 1203#define DynPage_addr 0x2000 /* starting addr of dynamic page */ 1204#define C218_start 0x3000 /* starting addr of C218 BIOS prg */ 1205#define Control_reg 0x1ff0 /* select page and reset control */ 1206#define HW_reset 0x80 1207 1208/* 1209 * Function Codes 1210 */ 1211#define FC_CardReset 0x80 1212#define FC_ChannelReset 1 /* C320 firmware not supported */ 1213#define FC_EnableCH 2 1214#define FC_DisableCH 3 1215#define FC_SetParam 4 1216#define FC_SetMode 5 1217#define FC_SetRate 6 1218#define FC_LineControl 7 1219#define FC_LineStatus 8 1220#define FC_XmitControl 9 1221#define FC_FlushQueue 10 1222#define FC_SendBreak 11 1223#define FC_StopBreak 12 1224#define FC_LoopbackON 13 1225#define FC_LoopbackOFF 14 1226#define FC_ClrIrqTable 15 1227#define FC_SendXon 16 1228#define FC_SetTermIrq 17 /* C320 firmware not supported */ 1229#define FC_SetCntIrq 18 /* C320 firmware not supported */ 1230#define FC_SetBreakIrq 19 1231#define FC_SetLineIrq 20 1232#define FC_SetFlowCtl 21 1233#define FC_GenIrq 22 1234#define FC_InCD180 23 1235#define FC_OutCD180 24 1236#define FC_InUARTreg 23 1237#define FC_OutUARTreg 24 1238#define FC_SetXonXoff 25 1239#define FC_OutCD180CCR 26 1240#define FC_ExtIQueue 27 1241#define FC_ExtOQueue 28 1242#define FC_ClrLineIrq 29 1243#define FC_HWFlowCtl 30 1244#define FC_GetClockRate 35 1245#define FC_SetBaud 36 1246#define FC_SetDataMode 41 1247#define FC_GetCCSR 43 1248#define FC_GetDataError 45 1249#define FC_RxControl 50 1250#define FC_ImmSend 51 1251#define FC_SetXonState 52 1252#define FC_SetXoffState 53 1253#define FC_SetRxFIFOTrig 54 1254#define FC_SetTxFIFOCnt 55 1255#define FC_UnixRate 56 1256#define FC_UnixResetTimer 57 1257 1258#define RxFIFOTrig1 0 1259#define RxFIFOTrig4 1 1260#define RxFIFOTrig8 2 1261#define RxFIFOTrig14 3 1262 1263/* 1264 * Dual-Ported RAM 1265 */ 1266#define DRAM_global 0 1267#define INT_data (DRAM_global + 0) 1268#define Config_base (DRAM_global + 0x108) 1269 1270#define IRQindex (INT_data + 0) 1271#define IRQpending (INT_data + 4) 1272#define IRQtable (INT_data + 8) 1273 1274/* 1275 * Interrupt Status 1276 */ 1277#define IntrRx 0x01 /* receiver data O.K. */ 1278#define IntrTx 0x02 /* transmit buffer empty */ 1279#define IntrFunc 0x04 /* function complete */ 1280#define IntrBreak 0x08 /* received break */ 1281#define IntrLine 0x10 /* line status change 1282 for transmitter */ 1283#define IntrIntr 0x20 /* received INTR code */ 1284#define IntrQuit 0x40 /* received QUIT code */ 1285#define IntrEOF 0x80 /* received EOF code */ 1286 1287#define IntrRxTrigger 0x100 /* rx data count reach tigger value */ 1288#define IntrTxTrigger 0x200 /* tx data count below trigger value */ 1289 1290#define Magic_no (Config_base + 0) 1291#define Card_model_no (Config_base + 2) 1292#define Total_ports (Config_base + 4) 1293#define Module_cnt (Config_base + 8) 1294#define Module_no (Config_base + 10) 1295#define Timer_10ms (Config_base + 14) 1296#define Disable_IRQ (Config_base + 20) 1297#define TMS320_PORT1 (Config_base + 22) 1298#define TMS320_PORT2 (Config_base + 24) 1299#define TMS320_CLOCK (Config_base + 26) 1300 1301/* 1302 * DATA BUFFER in DRAM 1303 */ 1304#define Extern_table 0x400 /* Base address of the external table 1305 (24 words * 64) total 3K bytes 1306 (24 words * 128) total 6K bytes */ 1307#define Extern_size 0x60 /* 96 bytes */ 1308#define RXrptr 0x00 /* read pointer for RX buffer */ 1309#define RXwptr 0x02 /* write pointer for RX buffer */ 1310#define TXrptr 0x04 /* read pointer for TX buffer */ 1311#define TXwptr 0x06 /* write pointer for TX buffer */ 1312#define HostStat 0x08 /* IRQ flag and general flag */ 1313#define FlagStat 0x0A 1314#define FlowControl 0x0C /* B7 B6 B5 B4 B3 B2 B1 B0 */ 1315 /* x x x x | | | | */ 1316 /* | | | + CTS flow */ 1317 /* | | +--- RTS flow */ 1318 /* | +------ TX Xon/Xoff */ 1319 /* +--------- RX Xon/Xoff */ 1320#define Break_cnt 0x0E /* received break count */ 1321#define CD180TXirq 0x10 /* if non-0: enable TX irq */ 1322#define RX_mask 0x12 1323#define TX_mask 0x14 1324#define Ofs_rxb 0x16 1325#define Ofs_txb 0x18 1326#define Page_rxb 0x1A 1327#define Page_txb 0x1C 1328#define EndPage_rxb 0x1E 1329#define EndPage_txb 0x20 1330#define Data_error 0x22 1331#define RxTrigger 0x28 1332#define TxTrigger 0x2a 1333 1334#define rRXwptr 0x34 1335#define Low_water 0x36 1336 1337#define FuncCode 0x40 1338#define FuncArg 0x42 1339#define FuncArg1 0x44 1340 1341#define C218rx_size 0x2000 /* 8K bytes */ 1342#define C218tx_size 0x8000 /* 32K bytes */ 1343 1344#define C218rx_mask (C218rx_size - 1) 1345#define C218tx_mask (C218tx_size - 1) 1346 1347#define C320p8rx_size 0x2000 1348#define C320p8tx_size 0x8000 1349#define C320p8rx_mask (C320p8rx_size - 1) 1350#define C320p8tx_mask (C320p8tx_size - 1) 1351 1352#define C320p16rx_size 0x2000 1353#define C320p16tx_size 0x4000 1354#define C320p16rx_mask (C320p16rx_size - 1) 1355#define C320p16tx_mask (C320p16tx_size - 1) 1356 1357#define C320p24rx_size 0x2000 1358#define C320p24tx_size 0x2000 1359#define C320p24rx_mask (C320p24rx_size - 1) 1360#define C320p24tx_mask (C320p24tx_size - 1) 1361 1362#define C320p32rx_size 0x1000 1363#define C320p32tx_size 0x1000 1364#define C320p32rx_mask (C320p32rx_size - 1) 1365#define C320p32tx_mask (C320p32tx_size - 1) 1366 1367#define Page_size 0x2000 1368#define Page_mask (Page_size - 1) 1369#define C218rx_spage 3 1370#define C218tx_spage 4 1371#define C218rx_pageno 1 1372#define C218tx_pageno 4 1373#define C218buf_pageno 5 1374 1375#define C320p8rx_spage 3 1376#define C320p8tx_spage 4 1377#define C320p8rx_pgno 1 1378#define C320p8tx_pgno 4 1379#define C320p8buf_pgno 5 1380 1381#define C320p16rx_spage 3 1382#define C320p16tx_spage 4 1383#define C320p16rx_pgno 1 1384#define C320p16tx_pgno 2 1385#define C320p16buf_pgno 3 1386 1387#define C320p24rx_spage 3 1388#define C320p24tx_spage 4 1389#define C320p24rx_pgno 1 1390#define C320p24tx_pgno 1 1391#define C320p24buf_pgno 2 1392 1393#define C320p32rx_spage 3 1394#define C320p32tx_ofs C320p32rx_size 1395#define C320p32tx_spage 3 1396#define C320p32buf_pgno 1 1397 1398/* 1399 * Host Status 1400 */ 1401#define WakeupRx 0x01 1402#define WakeupTx 0x02 1403#define WakeupBreak 0x08 1404#define WakeupLine 0x10 1405#define WakeupIntr 0x20 1406#define WakeupQuit 0x40 1407#define WakeupEOF 0x80 /* used in VTIME control */ 1408#define WakeupRxTrigger 0x100 1409#define WakeupTxTrigger 0x200 1410/* 1411 * Flag status 1412 */ 1413#define Rx_over 0x01 1414#define Xoff_state 0x02 1415#define Tx_flowOff 0x04 1416#define Tx_enable 0x08 1417#define CTS_state 0x10 1418#define DSR_state 0x20 1419#define DCD_state 0x80 1420/* 1421 * FlowControl 1422 */ 1423#define CTS_FlowCtl 1 1424#define RTS_FlowCtl 2 1425#define Tx_FlowCtl 4 1426#define Rx_FlowCtl 8 1427#define IXM_IXANY 0x10 1428 1429#define LowWater 128 1430 1431#define DTR_ON 1 1432#define RTS_ON 2 1433#define CTS_ON 1 1434#define DSR_ON 2 1435#define DCD_ON 8 1436 1437/* mode definition */ 1438#define MX_CS8 0x03 1439#define MX_CS7 0x02 1440#define MX_CS6 0x01 1441#define MX_CS5 0x00 1442 1443#define MX_STOP1 0x00 1444#define MX_STOP15 0x04 1445#define MX_STOP2 0x08 1446 1447#define MX_PARNONE 0x00 1448#define MX_PAREVEN 0x40 1449#define MX_PARODD 0xC0 1450 1451/* 1452 * Query 1453 */ 1454#define QueryPort MAX_PORTS 1455 1456 1457 1458struct mon_str { 1459 int tick; 1460 int rxcnt[MAX_PORTS]; 1461 int txcnt[MAX_PORTS]; 1462}; 1463typedef struct mon_str mon_st; 1464 1465#define DCD_changed 0x01 1466#define DCD_oldstate 0x80 1467 1468static unsigned char moxaBuff[10240]; 1469static void __iomem *moxaIntNdx[MAX_BOARDS]; 1470static void __iomem *moxaIntPend[MAX_BOARDS]; 1471static void __iomem *moxaIntTable[MAX_BOARDS]; 1472static char moxaChkPort[MAX_PORTS]; 1473static char moxaLineCtrl[MAX_PORTS]; 1474static void __iomem *moxaTableAddr[MAX_PORTS]; 1475static long moxaCurBaud[MAX_PORTS]; 1476static char moxaDCDState[MAX_PORTS]; 1477static char moxaLowChkFlag[MAX_PORTS]; 1478static int moxaLowWaterChk; 1479static int moxaCard; 1480static mon_st moxaLog; 1481static int moxaFuncTout; 1482static ushort moxaBreakCnt[MAX_PORTS]; 1483 1484static void moxadelay(int); 1485static void moxafunc(void __iomem *, int, ushort); 1486static void wait_finish(void __iomem *); 1487static void low_water_check(void __iomem *); 1488static int moxaloadbios(int, unsigned char __user *, int); 1489static int moxafindcard(int); 1490static int moxaload320b(int, unsigned char __user *, int); 1491static int moxaloadcode(int, unsigned char __user *, int); 1492static int moxaloadc218(int, void __iomem *, int); 1493static int moxaloadc320(int, void __iomem *, int, int *); 1494 1495/***************************************************************************** 1496 * Driver level functions: * 1497 * 1. MoxaDriverInit(void); * 1498 * 2. MoxaDriverIoctl(unsigned int cmd, unsigned long arg, int port); * 1499 * 3. MoxaDriverPoll(void); * 1500 *****************************************************************************/ 1501void MoxaDriverInit(void) 1502{ 1503 int i; 1504 1505 moxaFuncTout = HZ / 2; /* 500 mini-seconds */ 1506 moxaCard = 0; 1507 moxaLog.tick = 0; 1508 moxaLowWaterChk = 0; 1509 for (i = 0; i < MAX_PORTS; i++) { 1510 moxaChkPort[i] = 0; 1511 moxaLowChkFlag[i] = 0; 1512 moxaLineCtrl[i] = 0; 1513 moxaLog.rxcnt[i] = 0; 1514 moxaLog.txcnt[i] = 0; 1515 } 1516} 1517 1518#define MOXA 0x400 1519#define MOXA_GET_IQUEUE (MOXA + 1) /* get input buffered count */ 1520#define MOXA_GET_OQUEUE (MOXA + 2) /* get output buffered count */ 1521#define MOXA_INIT_DRIVER (MOXA + 6) /* moxaCard=0 */ 1522#define MOXA_LOAD_BIOS (MOXA + 9) /* download BIOS */ 1523#define MOXA_FIND_BOARD (MOXA + 10) /* Check if MOXA card exist? */ 1524#define MOXA_LOAD_C320B (MOXA + 11) /* download 320B firmware */ 1525#define MOXA_LOAD_CODE (MOXA + 12) /* download firmware */ 1526#define MOXA_GETDATACOUNT (MOXA + 23) 1527#define MOXA_GET_IOQUEUE (MOXA + 27) 1528#define MOXA_FLUSH_QUEUE (MOXA + 28) 1529#define MOXA_GET_CONF (MOXA + 35) /* configuration */ 1530#define MOXA_GET_MAJOR (MOXA + 63) 1531#define MOXA_GET_CUMAJOR (MOXA + 64) 1532#define MOXA_GETMSTATUS (MOXA + 65) 1533 1534 1535struct moxaq_str { 1536 int inq; 1537 int outq; 1538}; 1539 1540struct dl_str { 1541 char __user *buf; 1542 int len; 1543 int cardno; 1544}; 1545 1546static struct moxaq_str temp_queue[MAX_PORTS]; 1547static struct dl_str dltmp; 1548 1549void MoxaPortFlushData(int port, int mode) 1550{ 1551 void __iomem *ofsAddr; 1552 if ((mode < 0) || (mode > 2)) 1553 return; 1554 ofsAddr = moxaTableAddr[port]; 1555 moxafunc(ofsAddr, FC_FlushQueue, mode); 1556 if (mode != 1) { 1557 moxaLowChkFlag[port] = 0; 1558 low_water_check(ofsAddr); 1559 } 1560} 1561 1562int MoxaDriverIoctl(unsigned int cmd, unsigned long arg, int port) 1563{ 1564 int i; 1565 int status; 1566 int MoxaPortTxQueue(int), MoxaPortRxQueue(int); 1567 void __user *argp = (void __user *)arg; 1568 1569 if (port == QueryPort) { 1570 if ((cmd != MOXA_GET_CONF) && (cmd != MOXA_INIT_DRIVER) && 1571 (cmd != MOXA_LOAD_BIOS) && (cmd != MOXA_FIND_BOARD) && (cmd != MOXA_LOAD_C320B) && 1572 (cmd != MOXA_LOAD_CODE) && (cmd != MOXA_GETDATACOUNT) && 1573 (cmd != MOXA_GET_IOQUEUE) && (cmd != MOXA_GET_MAJOR) && 1574 (cmd != MOXA_GET_CUMAJOR) && (cmd != MOXA_GETMSTATUS)) 1575 return (-EINVAL); 1576 } 1577 switch (cmd) { 1578 case MOXA_GET_CONF: 1579 if(copy_to_user(argp, &moxa_boards, MAX_BOARDS * sizeof(moxa_board_conf))) 1580 return -EFAULT; 1581 return (0); 1582 case MOXA_INIT_DRIVER: 1583 if ((int) arg == 0x404) 1584 MoxaDriverInit(); 1585 return (0); 1586 case MOXA_GETDATACOUNT: 1587 moxaLog.tick = jiffies; 1588 if(copy_to_user(argp, &moxaLog, sizeof(mon_st))) 1589 return -EFAULT; 1590 return (0); 1591 case MOXA_FLUSH_QUEUE: 1592 MoxaPortFlushData(port, arg); 1593 return (0); 1594 case MOXA_GET_IOQUEUE: 1595 for (i = 0; i < MAX_PORTS; i++) { 1596 if (moxaChkPort[i]) { 1597 temp_queue[i].inq = MoxaPortRxQueue(i); 1598 temp_queue[i].outq = MoxaPortTxQueue(i); 1599 } 1600 } 1601 if(copy_to_user(argp, temp_queue, sizeof(struct moxaq_str) * MAX_PORTS)) 1602 return -EFAULT; 1603 return (0); 1604 case MOXA_GET_OQUEUE: 1605 i = MoxaPortTxQueue(port); 1606 return put_user(i, (unsigned long __user *)argp); 1607 case MOXA_GET_IQUEUE: 1608 i = MoxaPortRxQueue(port); 1609 return put_user(i, (unsigned long __user *)argp); 1610 case MOXA_GET_MAJOR: 1611 if(copy_to_user(argp, &ttymajor, sizeof(int))) 1612 return -EFAULT; 1613 return 0; 1614 case MOXA_GET_CUMAJOR: 1615 i = 0; 1616 if(copy_to_user(argp, &i, sizeof(int))) 1617 return -EFAULT; 1618 return 0; 1619 case MOXA_GETMSTATUS: 1620 for (i = 0; i < MAX_PORTS; i++) { 1621 GMStatus[i].ri = 0; 1622 GMStatus[i].dcd = 0; 1623 GMStatus[i].dsr = 0; 1624 GMStatus[i].cts = 0; 1625 if (!moxaChkPort[i]) { 1626 continue; 1627 } else { 1628 status = MoxaPortLineStatus(moxaChannels[i].port); 1629 if (status & 1) 1630 GMStatus[i].cts = 1; 1631 if (status & 2) 1632 GMStatus[i].dsr = 1; 1633 if (status & 4) 1634 GMStatus[i].dcd = 1; 1635 } 1636 1637 if (!moxaChannels[i].tty || !moxaChannels[i].tty->termios) 1638 GMStatus[i].cflag = moxaChannels[i].cflag; 1639 else 1640 GMStatus[i].cflag = moxaChannels[i].tty->termios->c_cflag; 1641 } 1642 if(copy_to_user(argp, GMStatus, sizeof(struct mxser_mstatus) * MAX_PORTS)) 1643 return -EFAULT; 1644 return 0; 1645 default: 1646 return (-ENOIOCTLCMD); 1647 case MOXA_LOAD_BIOS: 1648 case MOXA_FIND_BOARD: 1649 case MOXA_LOAD_C320B: 1650 case MOXA_LOAD_CODE: 1651 if (!capable(CAP_SYS_RAWIO)) 1652 return -EPERM; 1653 break; 1654 } 1655 1656 if(copy_from_user(&dltmp, argp, sizeof(struct dl_str))) 1657 return -EFAULT; 1658 if(dltmp.cardno < 0 || dltmp.cardno >= MAX_BOARDS) 1659 return -EINVAL; 1660 1661 switch(cmd) 1662 { 1663 case MOXA_LOAD_BIOS: 1664 i = moxaloadbios(dltmp.cardno, dltmp.buf, dltmp.len); 1665 return (i); 1666 case MOXA_FIND_BOARD: 1667 return moxafindcard(dltmp.cardno); 1668 case MOXA_LOAD_C320B: 1669 moxaload320b(dltmp.cardno, dltmp.buf, dltmp.len); 1670 default: /* to keep gcc happy */ 1671 return (0); 1672 case MOXA_LOAD_CODE: 1673 i = moxaloadcode(dltmp.cardno, dltmp.buf, dltmp.len); 1674 if (i == -1) 1675 return (-EFAULT); 1676 return (i); 1677 1678 } 1679} 1680 1681int MoxaDriverPoll(void) 1682{ 1683 register ushort temp; 1684 register int card; 1685 void __iomem *ofsAddr; 1686 void __iomem *ip; 1687 int port, p, ports; 1688 1689 if (moxaCard == 0) 1690 return (-1); 1691 for (card = 0; card < MAX_BOARDS; card++) { 1692 if (loadstat[card] == 0) 1693 continue; 1694 if ((ports = moxa_boards[card].numPorts) == 0) 1695 continue; 1696 if (readb(moxaIntPend[card]) == 0xff) { 1697 ip = moxaIntTable[card] + readb(moxaIntNdx[card]); 1698 p = card * MAX_PORTS_PER_BOARD; 1699 ports <<= 1; 1700 for (port = 0; port < ports; port += 2, p++) { 1701 if ((temp = readw(ip + port)) != 0) { 1702 writew(0, ip + port); 1703 ofsAddr = moxaTableAddr[p]; 1704 if (temp & IntrTx) 1705 writew(readw(ofsAddr + HostStat) & ~WakeupTx, ofsAddr + HostStat); 1706 if (temp & IntrBreak) { 1707 moxaBreakCnt[p]++; 1708 } 1709 if (temp & IntrLine) { 1710 if (readb(ofsAddr + FlagStat) & DCD_state) { 1711 if ((moxaDCDState[p] & DCD_oldstate) == 0) 1712 moxaDCDState[p] = (DCD_oldstate | 1713 DCD_changed); 1714 } else { 1715 if (moxaDCDState[p] & DCD_oldstate) 1716 moxaDCDState[p] = DCD_changed; 1717 } 1718 } 1719 } 1720 } 1721 writeb(0, moxaIntPend[card]); 1722 } 1723 if (moxaLowWaterChk) { 1724 p = card * MAX_PORTS_PER_BOARD; 1725 for (port = 0; port < ports; port++, p++) { 1726 if (moxaLowChkFlag[p]) { 1727 moxaLowChkFlag[p] = 0; 1728 ofsAddr = moxaTableAddr[p]; 1729 low_water_check(ofsAddr); 1730 } 1731 } 1732 } 1733 } 1734 moxaLowWaterChk = 0; 1735 return (0); 1736} 1737 1738/***************************************************************************** 1739 * Card level function: * 1740 * 1. MoxaPortsOfCard(int cardno); * 1741 *****************************************************************************/ 1742int MoxaPortsOfCard(int cardno) 1743{ 1744 1745 if (moxa_boards[cardno].boardType == 0) 1746 return (0); 1747 return (moxa_boards[cardno].numPorts); 1748} 1749 1750/***************************************************************************** 1751 * Port level functions: * 1752 * 1. MoxaPortIsValid(int port); * 1753 * 2. MoxaPortEnable(int port); * 1754 * 3. MoxaPortDisable(int port); * 1755 * 4. MoxaPortGetMaxBaud(int port); * 1756 * 5. MoxaPortGetCurBaud(int port); * 1757 * 6. MoxaPortSetBaud(int port, long baud); * 1758 * 7. MoxaPortSetMode(int port, int databit, int stopbit, int parity); * 1759 * 8. MoxaPortSetTermio(int port, unsigned char *termio); * 1760 * 9. MoxaPortGetLineOut(int port, int *dtrState, int *rtsState); * 1761 * 10. MoxaPortLineCtrl(int port, int dtrState, int rtsState); * 1762 * 11. MoxaPortFlowCtrl(int port, int rts, int cts, int rx, int tx,int xany); * 1763 * 12. MoxaPortLineStatus(int port); * 1764 * 13. MoxaPortDCDChange(int port); * 1765 * 14. MoxaPortDCDON(int port); * 1766 * 15. MoxaPortFlushData(int port, int mode); * 1767 * 16. MoxaPortWriteData(int port, unsigned char * buffer, int length); * 1768 * 17. MoxaPortReadData(int port, struct tty_struct *tty); * 1769 * 18. MoxaPortTxBufSize(int port); * 1770 * 19. MoxaPortRxBufSize(int port); * 1771 * 20. MoxaPortTxQueue(int port); * 1772 * 21. MoxaPortTxFree(int port); * 1773 * 22. MoxaPortRxQueue(int port); * 1774 * 23. MoxaPortRxFree(int port); * 1775 * 24. MoxaPortTxDisable(int port); * 1776 * 25. MoxaPortTxEnable(int port); * 1777 * 26. MoxaPortGetBrkCnt(int port); * 1778 * 27. MoxaPortResetBrkCnt(int port); * 1779 * 28. MoxaPortSetXonXoff(int port, int xonValue, int xoffValue); * 1780 * 29. MoxaPortIsTxHold(int port); * 1781 * 30. MoxaPortSendBreak(int port, int ticks); * 1782 *****************************************************************************/ 1783/* 1784 * Moxa Port Number Description: 1785 * 1786 * MOXA serial driver supports up to 4 MOXA-C218/C320 boards. And, 1787 * the port number using in MOXA driver functions will be 0 to 31 for 1788 * first MOXA board, 32 to 63 for second, 64 to 95 for third and 96 1789 * to 127 for fourth. For example, if you setup three MOXA boards, 1790 * first board is C218, second board is C320-16 and third board is 1791 * C320-32. The port number of first board (C218 - 8 ports) is from 1792 * 0 to 7. The port number of second board (C320 - 16 ports) is form 1793 * 32 to 47. The port number of third board (C320 - 32 ports) is from 1794 * 64 to 95. And those port numbers form 8 to 31, 48 to 63 and 96 to 1795 * 127 will be invalid. 1796 * 1797 * 1798 * Moxa Functions Description: 1799 * 1800 * Function 1: Driver initialization routine, this routine must be 1801 * called when initialized driver. 1802 * Syntax: 1803 * void MoxaDriverInit(); 1804 * 1805 * 1806 * Function 2: Moxa driver private IOCTL command processing. 1807 * Syntax: 1808 * int MoxaDriverIoctl(unsigned int cmd, unsigned long arg, int port); 1809 * 1810 * unsigned int cmd : IOCTL command 1811 * unsigned long arg : IOCTL argument 1812 * int port : port number (0 - 127) 1813 * 1814 * return: 0 (OK) 1815 * -EINVAL 1816 * -ENOIOCTLCMD 1817 * 1818 * 1819 * Function 3: Moxa driver polling process routine. 1820 * Syntax: 1821 * int MoxaDriverPoll(void); 1822 * 1823 * return: 0 ; polling O.K. 1824 * -1 : no any Moxa card. 1825 * 1826 * 1827 * Function 4: Get the ports of this card. 1828 * Syntax: 1829 * int MoxaPortsOfCard(int cardno); 1830 * 1831 * int cardno : card number (0 - 3) 1832 * 1833 * return: 0 : this card is invalid 1834 * 8/16/24/32 1835 * 1836 * 1837 * Function 5: Check this port is valid or invalid 1838 * Syntax: 1839 * int MoxaPortIsValid(int port); 1840 * int port : port number (0 - 127, ref port description) 1841 * 1842 * return: 0 : this port is invalid 1843 * 1 : this port is valid 1844 * 1845 * 1846 * Function 6: Enable this port to start Tx/Rx data. 1847 * Syntax: 1848 * void MoxaPortEnable(int port); 1849 * int port : port number (0 - 127) 1850 * 1851 * 1852 * Function 7: Disable this port 1853 * Syntax: 1854 * void MoxaPortDisable(int port); 1855 * int port : port number (0 - 127) 1856 * 1857 * 1858 * Function 8: Get the maximun available baud rate of this port. 1859 * Syntax: 1860 * long MoxaPortGetMaxBaud(int port); 1861 * int port : port number (0 - 127) 1862 * 1863 * return: 0 : this port is invalid 1864 * 38400/57600/115200 bps 1865 * 1866 * 1867 * Function 9: Get the current baud rate of this port. 1868 * Syntax: 1869 * long MoxaPortGetCurBaud(int port); 1870 * int port : port number (0 - 127) 1871 * 1872 * return: 0 : this port is invalid 1873 * 50 - 115200 bps 1874 * 1875 * 1876 * Function 10: Setting baud rate of this port. 1877 * Syntax: 1878 * long MoxaPortSetBaud(int port, long baud); 1879 * int port : port number (0 - 127) 1880 * long baud : baud rate (50 - 115200) 1881 * 1882 * return: 0 : this port is invalid or baud < 50 1883 * 50 - 115200 : the real baud rate set to the port, if 1884 * the argument baud is large than maximun 1885 * available baud rate, the real setting 1886 * baud rate will be the maximun baud rate. 1887 * 1888 * 1889 * Function 11: Setting the data-bits/stop-bits/parity of this port 1890 * Syntax: 1891 * int MoxaPortSetMode(int port, int databits, int stopbits, int parity); 1892 * int port : port number (0 - 127) 1893 * int databits : data bits (8/7/6/5) 1894 * int stopbits : stop bits (2/1/0, 0 show 1.5 stop bits) 1895 int parity : parity (0:None,1:Odd,2:Even,3:Mark,4:Space) 1896 * 1897 * return: -1 : invalid parameter 1898 * 0 : setting O.K. 1899 * 1900 * 1901 * Function 12: Configure the port. 1902 * Syntax: 1903 * int MoxaPortSetTermio(int port, struct termios *termio, speed_t baud); 1904 * int port : port number (0 - 127) 1905 * struct termios * termio : termio structure pointer 1906 * speed_t baud : baud rate 1907 * 1908 * return: -1 : this port is invalid or termio == NULL 1909 * 0 : setting O.K. 1910 * 1911 * 1912 * Function 13: Get the DTR/RTS state of this port. 1913 * Syntax: 1914 * int MoxaPortGetLineOut(int port, int *dtrState, int *rtsState); 1915 * int port : port number (0 - 127) 1916 * int * dtrState : pointer to INT to receive the current DTR 1917 * state. (if NULL, this function will not 1918 * write to this address) 1919 * int * rtsState : pointer to INT to receive the current RTS 1920 * state. (if NULL, this function will not 1921 * write to this address) 1922 * 1923 * return: -1 : this port is invalid 1924 * 0 : O.K. 1925 * 1926 * 1927 * Function 14: Setting the DTR/RTS output state of this port. 1928 * Syntax: 1929 * void MoxaPortLineCtrl(int port, int dtrState, int rtsState); 1930 * int port : port number (0 - 127) 1931 * int dtrState : DTR output state (0: off, 1: on) 1932 * int rtsState : RTS output state (0: off, 1: on) 1933 * 1934 * 1935 * Function 15: Setting the flow control of this port. 1936 * Syntax: 1937 * void MoxaPortFlowCtrl(int port, int rtsFlow, int ctsFlow, int rxFlow, 1938 * int txFlow,int xany); 1939 * int port : port number (0 - 127) 1940 * int rtsFlow : H/W RTS flow control (0: no, 1: yes) 1941 * int ctsFlow : H/W CTS flow control (0: no, 1: yes) 1942 * int rxFlow : S/W Rx XON/XOFF flow control (0: no, 1: yes) 1943 * int txFlow : S/W Tx XON/XOFF flow control (0: no, 1: yes) 1944 * int xany : S/W XANY flow control (0: no, 1: yes) 1945 * 1946 * 1947 * Function 16: Get ths line status of this port 1948 * Syntax: 1949 * int MoxaPortLineStatus(int port); 1950 * int port : port number (0 - 127) 1951 * 1952 * return: Bit 0 - CTS state (0: off, 1: on) 1953 * Bit 1 - DSR state (0: off, 1: on) 1954 * Bit 2 - DCD state (0: off, 1: on) 1955 * 1956 * 1957 * Function 17: Check the DCD state has changed since the last read 1958 * of this function. 1959 * Syntax: 1960 * int MoxaPortDCDChange(int port); 1961 * int port : port number (0 - 127) 1962 * 1963 * return: 0 : no changed 1964 * 1 : DCD has changed 1965 * 1966 * 1967 * Function 18: Check ths current DCD state is ON or not. 1968 * Syntax: 1969 * int MoxaPortDCDON(int port); 1970 * int port : port number (0 - 127) 1971 * 1972 * return: 0 : DCD off 1973 * 1 : DCD on 1974 * 1975 * 1976 * Function 19: Flush the Rx/Tx buffer data of this port. 1977 * Syntax: 1978 * void MoxaPortFlushData(int port, int mode); 1979 * int port : port number (0 - 127) 1980 * int mode 1981 * 0 : flush the Rx buffer 1982 * 1 : flush the Tx buffer 1983 * 2 : flush the Rx and Tx buffer 1984 * 1985 * 1986 * Function 20: Write data. 1987 * Syntax: 1988 * int MoxaPortWriteData(int port, unsigned char * buffer, int length); 1989 * int port : port number (0 - 127) 1990 * unsigned char * buffer : pointer to write data buffer. 1991 * int length : write data length 1992 * 1993 * return: 0 - length : real write data length 1994 * 1995 * 1996 * Function 21: Read data. 1997 * Syntax: 1998 * int MoxaPortReadData(int port, struct tty_struct *tty); 1999 * int port : port number (0 - 127) 2000 * struct tty_struct *tty : tty for data 2001 * 2002 * return: 0 - length : real read data length 2003 * 2004 * 2005 * Function 22: Get the Tx buffer size of this port 2006 * Syntax: 2007 * int MoxaPortTxBufSize(int port); 2008 * int port : port number (0 - 127) 2009 * 2010 * return: .. : Tx buffer size 2011 * 2012 * 2013 * Function 23: Get the Rx buffer size of this port 2014 * Syntax: 2015 * int MoxaPortRxBufSize(int port); 2016 * int port : port number (0 - 127) 2017 * 2018 * return: .. : Rx buffer size 2019 * 2020 * 2021 * Function 24: Get the Tx buffer current queued data bytes 2022 * Syntax: 2023 * int MoxaPortTxQueue(int port); 2024 * int port : port number (0 - 127) 2025 * 2026 * return: .. : Tx buffer current queued data bytes 2027 * 2028 * 2029 * Function 25: Get the Tx buffer current free space 2030 * Syntax: 2031 * int MoxaPortTxFree(int port); 2032 * int port : port number (0 - 127) 2033 * 2034 * return: .. : Tx buffer current free space 2035 * 2036 * 2037 * Function 26: Get the Rx buffer current queued data bytes 2038 * Syntax: 2039 * int MoxaPortRxQueue(int port); 2040 * int port : port number (0 - 127) 2041 * 2042 * return: .. : Rx buffer current queued data bytes 2043 * 2044 * 2045 * Function 27: Get the Rx buffer current free space 2046 * Syntax: 2047 * int MoxaPortRxFree(int port); 2048 * int port : port number (0 - 127) 2049 * 2050 * return: .. : Rx buffer current free space 2051 * 2052 * 2053 * Function 28: Disable port data transmission. 2054 * Syntax: 2055 * void MoxaPortTxDisable(int port); 2056 * int port : port number (0 - 127) 2057 * 2058 * 2059 * Function 29: Enable port data transmission. 2060 * Syntax: 2061 * void MoxaPortTxEnable(int port); 2062 * int port : port number (0 - 127) 2063 * 2064 * 2065 * Function 30: Get the received BREAK signal count. 2066 * Syntax: 2067 * int MoxaPortGetBrkCnt(int port); 2068 * int port : port number (0 - 127) 2069 * 2070 * return: 0 - .. : BREAK signal count 2071 * 2072 * 2073 * Function 31: Get the received BREAK signal count and reset it. 2074 * Syntax: 2075 * int MoxaPortResetBrkCnt(int port); 2076 * int port : port number (0 - 127) 2077 * 2078 * return: 0 - .. : BREAK signal count 2079 * 2080 * 2081 * Function 32: Set the S/W flow control new XON/XOFF value, default 2082 * XON is 0x11 & XOFF is 0x13. 2083 * Syntax: 2084 * void MoxaPortSetXonXoff(int port, int xonValue, int xoffValue); 2085 * int port : port number (0 - 127) 2086 * int xonValue : new XON value (0 - 255) 2087 * int xoffValue : new XOFF value (0 - 255) 2088 * 2089 * 2090 * Function 33: Check this port's transmission is hold by remote site 2091 * because the flow control. 2092 * Syntax: 2093 * int MoxaPortIsTxHold(int port); 2094 * int port : port number (0 - 127) 2095 * 2096 * return: 0 : normal 2097 * 1 : hold by remote site 2098 * 2099 * 2100 * Function 34: Send out a BREAK signal. 2101 * Syntax: 2102 * void MoxaPortSendBreak(int port, int ms100); 2103 * int port : port number (0 - 127) 2104 * int ms100 : break signal time interval. 2105 * unit: 100 mini-second. if ms100 == 0, it will 2106 * send out a about 250 ms BREAK signal. 2107 * 2108 */ 2109int MoxaPortIsValid(int port) 2110{ 2111 2112 if (moxaCard == 0) 2113 return (0); 2114 if (moxaChkPort[port] == 0) 2115 return (0); 2116 return (1); 2117} 2118 2119void MoxaPortEnable(int port) 2120{ 2121 void __iomem *ofsAddr; 2122 int MoxaPortLineStatus(int); 2123 short lowwater = 512; 2124 2125 ofsAddr = moxaTableAddr[port]; 2126 writew(lowwater, ofsAddr + Low_water); 2127 moxaBreakCnt[port] = 0; 2128 if ((moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_ISA) || 2129 (moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_PCI)) { 2130 moxafunc(ofsAddr, FC_SetBreakIrq, 0); 2131 } else { 2132 writew(readw(ofsAddr + HostStat) | WakeupBreak, ofsAddr + HostStat); 2133 } 2134 2135 moxafunc(ofsAddr, FC_SetLineIrq, Magic_code); 2136 moxafunc(ofsAddr, FC_FlushQueue, 2); 2137 2138 moxafunc(ofsAddr, FC_EnableCH, Magic_code); 2139 MoxaPortLineStatus(port); 2140} 2141 2142void MoxaPortDisable(int port) 2143{ 2144 void __iomem *ofsAddr = moxaTableAddr[port]; 2145 2146 moxafunc(ofsAddr, FC_SetFlowCtl, 0); /* disable flow control */ 2147 moxafunc(ofsAddr, FC_ClrLineIrq, Magic_code); 2148 writew(0, ofsAddr + HostStat); 2149 moxafunc(ofsAddr, FC_DisableCH, Magic_code); 2150} 2151 2152long MoxaPortGetMaxBaud(int port) 2153{ 2154 if ((moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_ISA) || 2155 (moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_PCI)) 2156 return (460800L); 2157 else 2158 return (921600L); 2159} 2160 2161 2162long MoxaPortSetBaud(int port, long baud) 2163{ 2164 void __iomem *ofsAddr; 2165 long max, clock; 2166 unsigned int val; 2167 2168 if ((baud < 50L) || ((max = MoxaPortGetMaxBaud(port)) == 0)) 2169 return (0); 2170 ofsAddr = moxaTableAddr[port]; 2171 if (baud > max) 2172 baud = max; 2173 if (max == 38400L) 2174 clock = 614400L; /* for 9.8304 Mhz : max. 38400 bps */ 2175 else if (max == 57600L) 2176 clock = 691200L; /* for 11.0592 Mhz : max. 57600 bps */ 2177 else 2178 clock = 921600L; /* for 14.7456 Mhz : max. 115200 bps */ 2179 val = clock / baud; 2180 moxafunc(ofsAddr, FC_SetBaud, val); 2181 baud = clock / val; 2182 moxaCurBaud[port] = baud; 2183 return (baud); 2184} 2185 2186int MoxaPortSetTermio(int port, struct termios *termio, speed_t baud) 2187{ 2188 void __iomem *ofsAddr; 2189 tcflag_t cflag; 2190 tcflag_t mode = 0; 2191 2192 if (moxaChkPort[port] == 0 || termio == 0) 2193 return (-1); 2194 ofsAddr = moxaTableAddr[port]; 2195 cflag = termio->c_cflag; /* termio->c_cflag */ 2196 2197 mode = termio->c_cflag & CSIZE; 2198 if (mode == CS5) 2199 mode = MX_CS5; 2200 else if (mode == CS6) 2201 mode = MX_CS6; 2202 else if (mode == CS7) 2203 mode = MX_CS7; 2204 else if (mode == CS8) 2205 mode = MX_CS8; 2206 2207 if (termio->c_cflag & CSTOPB) { 2208 if (mode == MX_CS5) 2209 mode |= MX_STOP15; 2210 else 2211 mode |= MX_STOP2; 2212 } else 2213 mode |= MX_STOP1; 2214 2215 if (termio->c_cflag & PARENB) { 2216 if (termio->c_cflag & PARODD) 2217 mode |= MX_PARODD; 2218 else 2219 mode |= MX_PAREVEN; 2220 } else 2221 mode |= MX_PARNONE; 2222 2223 moxafunc(ofsAddr, FC_SetDataMode, (ushort) mode); 2224 2225 if ((moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_ISA) || 2226 (moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_PCI)) { 2227 if (baud >= 921600L) 2228 return (-1); 2229 } 2230 MoxaPortSetBaud(port, baud); 2231 2232 if (termio->c_iflag & (IXON | IXOFF | IXANY)) { 2233 writeb(termio->c_cc[VSTART], ofsAddr + FuncArg); 2234 writeb(termio->c_cc[VSTOP], ofsAddr + FuncArg1); 2235 writeb(FC_SetXonXoff, ofsAddr + FuncCode); 2236 wait_finish(ofsAddr); 2237 2238 } 2239 return (0); 2240} 2241 2242int MoxaPortGetLineOut(int port, int *dtrState, int *rtsState) 2243{ 2244 2245 if (!MoxaPortIsValid(port)) 2246 return (-1); 2247 if (dtrState) { 2248 if (moxaLineCtrl[port] & DTR_ON) 2249 *dtrState = 1; 2250 else 2251 *dtrState = 0; 2252 } 2253 if (rtsState) { 2254 if (moxaLineCtrl[port] & RTS_ON) 2255 *rtsState = 1; 2256 else 2257 *rtsState = 0; 2258 } 2259 return (0); 2260} 2261 2262void MoxaPortLineCtrl(int port, int dtr, int rts) 2263{ 2264 void __iomem *ofsAddr; 2265 int mode; 2266 2267 ofsAddr = moxaTableAddr[port]; 2268 mode = 0; 2269 if (dtr) 2270 mode |= DTR_ON; 2271 if (rts) 2272 mode |= RTS_ON; 2273 moxaLineCtrl[port] = mode; 2274 moxafunc(ofsAddr, FC_LineControl, mode); 2275} 2276 2277void MoxaPortFlowCtrl(int port, int rts, int cts, int txflow, int rxflow, int txany) 2278{ 2279 void __iomem *ofsAddr; 2280 int mode; 2281 2282 ofsAddr = moxaTableAddr[port]; 2283 mode = 0; 2284 if (rts) 2285 mode |= RTS_FlowCtl; 2286 if (cts) 2287 mode |= CTS_FlowCtl; 2288 if (txflow) 2289 mode |= Tx_FlowCtl; 2290 if (rxflow) 2291 mode |= Rx_FlowCtl; 2292 if (txany) 2293 mode |= IXM_IXANY; 2294 moxafunc(ofsAddr, FC_SetFlowCtl, mode); 2295} 2296 2297int MoxaPortLineStatus(int port) 2298{ 2299 void __iomem *ofsAddr; 2300 int val; 2301 2302 ofsAddr = moxaTableAddr[port]; 2303 if ((moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_ISA) || 2304 (moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_PCI)) { 2305 moxafunc(ofsAddr, FC_LineStatus, 0); 2306 val = readw(ofsAddr + FuncArg); 2307 } else { 2308 val = readw(ofsAddr + FlagStat) >> 4; 2309 } 2310 val &= 0x0B; 2311 if (val & 8) { 2312 val |= 4; 2313 if ((moxaDCDState[port] & DCD_oldstate) == 0) 2314 moxaDCDState[port] = (DCD_oldstate | DCD_changed); 2315 } else { 2316 if (moxaDCDState[port] & DCD_oldstate) 2317 moxaDCDState[port] = DCD_changed; 2318 } 2319 val &= 7; 2320 return (val); 2321} 2322 2323int MoxaPortDCDChange(int port) 2324{ 2325 int n; 2326 2327 if (moxaChkPort[port] == 0) 2328 return (0); 2329 n = moxaDCDState[port]; 2330 moxaDCDState[port] &= ~DCD_changed; 2331 n &= DCD_changed; 2332 return (n); 2333} 2334 2335int MoxaPortDCDON(int port) 2336{ 2337 int n; 2338 2339 if (moxaChkPort[port] == 0) 2340 return (0); 2341 if (moxaDCDState[port] & DCD_oldstate) 2342 n = 1; 2343 else 2344 n = 0; 2345 return (n); 2346} 2347 2348 2349/* 2350 int MoxaDumpMem(int port, unsigned char * buffer, int len) 2351 { 2352 int i; 2353 unsigned long baseAddr,ofsAddr,ofs; 2354 2355 baseAddr = moxaBaseAddr[port / MAX_PORTS_PER_BOARD]; 2356 ofs = baseAddr + DynPage_addr + pageofs; 2357 if (len > 0x2000L) 2358 len = 0x2000L; 2359 for (i = 0; i < len; i++) 2360 buffer[i] = readb(ofs+i); 2361 } 2362 */ 2363 2364 2365int MoxaPortWriteData(int port, unsigned char * buffer, int len) 2366{ 2367 int c, total, i; 2368 ushort tail; 2369 int cnt; 2370 ushort head, tx_mask, spage, epage; 2371 ushort pageno, pageofs, bufhead; 2372 void __iomem *baseAddr, *ofsAddr, *ofs; 2373 2374 ofsAddr = moxaTableAddr[port]; 2375 baseAddr = moxaBaseAddr[port / MAX_PORTS_PER_BOARD]; 2376 tx_mask = readw(ofsAddr + TX_mask); 2377 spage = readw(ofsAddr + Page_txb); 2378 epage = readw(ofsAddr + EndPage_txb); 2379 tail = readw(ofsAddr + TXwptr); 2380 head = readw(ofsAddr + TXrptr); 2381 c = (head > tail) ? (head - tail - 1) 2382 : (head - tail + tx_mask); 2383 if (c > len) 2384 c = len; 2385 moxaLog.txcnt[port] += c; 2386 total = c; 2387 if (spage == epage) { 2388 bufhead = readw(ofsAddr + Ofs_txb); 2389 writew(spage, baseAddr + Control_reg); 2390 while (c > 0) { 2391 if (head > tail) 2392 len = head - tail - 1; 2393 else 2394 len = tx_mask + 1 - tail; 2395 len = (c > len) ? len : c; 2396 ofs = baseAddr + DynPage_addr + bufhead + tail; 2397 for (i = 0; i < len; i++) 2398 writeb(*buffer++, ofs + i); 2399 tail = (tail + len) & tx_mask; 2400 c -= len; 2401 } 2402 writew(tail, ofsAddr + TXwptr); 2403 } else { 2404 len = c; 2405 pageno = spage + (tail >> 13); 2406 pageofs = tail & Page_mask; 2407 do { 2408 cnt = Page_size - pageofs; 2409 if (cnt > c) 2410 cnt = c; 2411 c -= cnt; 2412 writeb(pageno, baseAddr + Control_reg); 2413 ofs = baseAddr + DynPage_addr + pageofs; 2414 for (i = 0; i < cnt; i++) 2415 writeb(*buffer++, ofs + i); 2416 if (c == 0) { 2417 writew((tail + len) & tx_mask, ofsAddr + TXwptr); 2418 break; 2419 } 2420 if (++pageno == epage) 2421 pageno = spage; 2422 pageofs = 0; 2423 } while (1); 2424 } 2425 writeb(1, ofsAddr + CD180TXirq); /* start to send */ 2426 return (total); 2427} 2428 2429int MoxaPortReadData(int port, struct tty_struct *tty) 2430{ 2431 register ushort head, pageofs; 2432 int i, count, cnt, len, total, remain; 2433 ushort tail, rx_mask, spage, epage; 2434 ushort pageno, bufhead; 2435 void __iomem *baseAddr, *ofsAddr, *ofs; 2436 2437 ofsAddr = moxaTableAddr[port]; 2438 baseAddr = moxaBaseAddr[port / MAX_PORTS_PER_BOARD]; 2439 head = readw(ofsAddr + RXrptr); 2440 tail = readw(ofsAddr + RXwptr); 2441 rx_mask = readw(ofsAddr + RX_mask); 2442 spage = readw(ofsAddr + Page_rxb); 2443 epage = readw(ofsAddr + EndPage_rxb); 2444 count = (tail >= head) ? (tail - head) 2445 : (tail - head + rx_mask + 1); 2446 if (count == 0) 2447 return 0; 2448 2449 total = count; 2450 remain = count - total; 2451 moxaLog.rxcnt[port] += total; 2452 count = total; 2453 if (spage == epage) { 2454 bufhead = readw(ofsAddr + Ofs_rxb); 2455 writew(spage, baseAddr + Control_reg); 2456 while (count > 0) { 2457 if (tail >= head) 2458 len = tail - head; 2459 else 2460 len = rx_mask + 1 - head; 2461 len = (count > len) ? len : count; 2462 ofs = baseAddr + DynPage_addr + bufhead + head; 2463 for (i = 0; i < len; i++) 2464 tty_insert_flip_char(tty, readb(ofs + i), TTY_NORMAL); 2465 head = (head + len) & rx_mask; 2466 count -= len; 2467 } 2468 writew(head, ofsAddr + RXrptr); 2469 } else { 2470 len = count; 2471 pageno = spage + (head >> 13); 2472 pageofs = head & Page_mask; 2473 do { 2474 cnt = Page_size - pageofs; 2475 if (cnt > count) 2476 cnt = count; 2477 count -= cnt; 2478 writew(pageno, baseAddr + Control_reg); 2479 ofs = baseAddr + DynPage_addr + pageofs; 2480 for (i = 0; i < cnt; i++) 2481 tty_insert_flip_char(tty, readb(ofs + i), TTY_NORMAL); 2482 if (count == 0) { 2483 writew((head + len) & rx_mask, ofsAddr + RXrptr); 2484 break; 2485 } 2486 if (++pageno == epage) 2487 pageno = spage; 2488 pageofs = 0; 2489 } while (1); 2490 } 2491 if ((readb(ofsAddr + FlagStat) & Xoff_state) && (remain < LowWater)) { 2492 moxaLowWaterChk = 1; 2493 moxaLowChkFlag[port] = 1; 2494 } 2495 return (total); 2496} 2497 2498 2499int MoxaPortTxQueue(int port) 2500{ 2501 void __iomem *ofsAddr; 2502 ushort rptr, wptr, mask; 2503 int len; 2504 2505 ofsAddr = moxaTableAddr[port]; 2506 rptr = readw(ofsAddr + TXrptr); 2507 wptr = readw(ofsAddr + TXwptr); 2508 mask = readw(ofsAddr + TX_mask); 2509 len = (wptr - rptr) & mask; 2510 return (len); 2511} 2512 2513int MoxaPortTxFree(int port) 2514{ 2515 void __iomem *ofsAddr; 2516 ushort rptr, wptr, mask; 2517 int len; 2518 2519 ofsAddr = moxaTableAddr[port]; 2520 rptr = readw(ofsAddr + TXrptr); 2521 wptr = readw(ofsAddr + TXwptr); 2522 mask = readw(ofsAddr + TX_mask); 2523 len = mask - ((wptr - rptr) & mask); 2524 return (len); 2525} 2526 2527int MoxaPortRxQueue(int port) 2528{ 2529 void __iomem *ofsAddr; 2530 ushort rptr, wptr, mask; 2531 int len; 2532 2533 ofsAddr = moxaTableAddr[port]; 2534 rptr = readw(ofsAddr + RXrptr); 2535 wptr = readw(ofsAddr + RXwptr); 2536 mask = readw(ofsAddr + RX_mask); 2537 len = (wptr - rptr) & mask; 2538 return (len); 2539} 2540 2541 2542void MoxaPortTxDisable(int port) 2543{ 2544 void __iomem *ofsAddr; 2545 2546 ofsAddr = moxaTableAddr[port]; 2547 moxafunc(ofsAddr, FC_SetXoffState, Magic_code); 2548} 2549 2550void MoxaPortTxEnable(int port) 2551{ 2552 void __iomem *ofsAddr; 2553 2554 ofsAddr = moxaTableAddr[port]; 2555 moxafunc(ofsAddr, FC_SetXonState, Magic_code); 2556} 2557 2558 2559int MoxaPortResetBrkCnt(int port) 2560{ 2561 ushort cnt; 2562 cnt = moxaBreakCnt[port]; 2563 moxaBreakCnt[port] = 0; 2564 return (cnt); 2565} 2566 2567 2568void MoxaPortSendBreak(int port, int ms100) 2569{ 2570 void __iomem *ofsAddr; 2571 2572 ofsAddr = moxaTableAddr[port]; 2573 if (ms100) { 2574 moxafunc(ofsAddr, FC_SendBreak, Magic_code); 2575 moxadelay(ms100 * (HZ / 10)); 2576 } else { 2577 moxafunc(ofsAddr, FC_SendBreak, Magic_code); 2578 moxadelay(HZ / 4); /* 250 ms */ 2579 } 2580 moxafunc(ofsAddr, FC_StopBreak, Magic_code); 2581} 2582 2583static int moxa_get_serial_info(struct moxa_str *info, 2584 struct serial_struct __user *retinfo) 2585{ 2586 struct serial_struct tmp; 2587 2588 memset(&tmp, 0, sizeof(tmp)); 2589 tmp.type = info->type; 2590 tmp.line = info->port; 2591 tmp.port = 0; 2592 tmp.irq = 0; 2593 tmp.flags = info->asyncflags; 2594 tmp.baud_base = 921600; 2595 tmp.close_delay = info->close_delay; 2596 tmp.closing_wait = info->closing_wait; 2597 tmp.custom_divisor = 0; 2598 tmp.hub6 = 0; 2599 if(copy_to_user(retinfo, &tmp, sizeof(*retinfo))) 2600 return -EFAULT; 2601 return (0); 2602} 2603 2604 2605static int moxa_set_serial_info(struct moxa_str *info, 2606 struct serial_struct __user *new_info) 2607{ 2608 struct serial_struct new_serial; 2609 2610 if(copy_from_user(&new_serial, new_info, sizeof(new_serial))) 2611 return -EFAULT; 2612 2613 if ((new_serial.irq != 0) || 2614 (new_serial.port != 0) || 2615// (new_serial.type != info->type) || 2616 (new_serial.custom_divisor != 0) || 2617 (new_serial.baud_base != 921600)) 2618 return (-EPERM); 2619 2620 if (!capable(CAP_SYS_ADMIN)) { 2621 if (((new_serial.flags & ~ASYNC_USR_MASK) != 2622 (info->asyncflags & ~ASYNC_USR_MASK))) 2623 return (-EPERM); 2624 } else { 2625 info->close_delay = new_serial.close_delay * HZ / 100; 2626 info->closing_wait = new_serial.closing_wait * HZ / 100; 2627 } 2628 2629 new_serial.flags = (new_serial.flags & ~ASYNC_FLAGS); 2630 new_serial.flags |= (info->asyncflags & ASYNC_FLAGS); 2631 2632 if (new_serial.type == PORT_16550A) { 2633 MoxaSetFifo(info->port, 1); 2634 } else { 2635 MoxaSetFifo(info->port, 0); 2636 } 2637 2638 info->type = new_serial.type; 2639 return (0); 2640} 2641 2642 2643 2644/***************************************************************************** 2645 * Static local functions: * 2646 *****************************************************************************/ 2647/* 2648 * moxadelay - delays a specified number ticks 2649 */ 2650static void moxadelay(int tick) 2651{ 2652 unsigned long st, et; 2653 2654 st = jiffies; 2655 et = st + tick; 2656 while (time_before(jiffies, et)); 2657} 2658 2659static void moxafunc(void __iomem *ofsAddr, int cmd, ushort arg) 2660{ 2661 2662 writew(arg, ofsAddr + FuncArg); 2663 writew(cmd, ofsAddr + FuncCode); 2664 wait_finish(ofsAddr); 2665} 2666 2667static void wait_finish(void __iomem *ofsAddr) 2668{ 2669 unsigned long i, j; 2670 2671 i = jiffies; 2672 while (readw(ofsAddr + FuncCode) != 0) { 2673 j = jiffies; 2674 if ((j - i) > moxaFuncTout) { 2675 return; 2676 } 2677 } 2678} 2679 2680static void low_water_check(void __iomem *ofsAddr) 2681{ 2682 int len; 2683 ushort rptr, wptr, mask; 2684 2685 if (readb(ofsAddr + FlagStat) & Xoff_state) { 2686 rptr = readw(ofsAddr + RXrptr); 2687 wptr = readw(ofsAddr + RXwptr); 2688 mask = readw(ofsAddr + RX_mask); 2689 len = (wptr - rptr) & mask; 2690 if (len <= Low_water) 2691 moxafunc(ofsAddr, FC_SendXon, 0); 2692 } 2693} 2694 2695static int moxaloadbios(int cardno, unsigned char __user *tmp, int len) 2696{ 2697 void __iomem *baseAddr; 2698 int i; 2699 2700 if(copy_from_user(moxaBuff, tmp, len)) 2701 return -EFAULT; 2702 baseAddr = moxaBaseAddr[cardno]; 2703 writeb(HW_reset, baseAddr + Control_reg); /* reset */ 2704 moxadelay(1); /* delay 10 ms */ 2705 for (i = 0; i < 4096; i++) 2706 writeb(0, baseAddr + i); /* clear fix page */ 2707 for (i = 0; i < len; i++) 2708 writeb(moxaBuff[i], baseAddr + i); /* download BIOS */ 2709 writeb(0, baseAddr + Control_reg); /* restart */ 2710 return (0); 2711} 2712 2713static int moxafindcard(int cardno) 2714{ 2715 void __iomem *baseAddr; 2716 ushort tmp; 2717 2718 baseAddr = moxaBaseAddr[cardno]; 2719 switch (moxa_boards[cardno].boardType) { 2720 case MOXA_BOARD_C218_ISA: 2721 case MOXA_BOARD_C218_PCI: 2722 if ((tmp = readw(baseAddr + C218_key)) != C218_KeyCode) { 2723 return (-1); 2724 } 2725 break; 2726 case MOXA_BOARD_CP204J: 2727 if ((tmp = readw(baseAddr + C218_key)) != CP204J_KeyCode) { 2728 return (-1); 2729 } 2730 break; 2731 default: 2732 if ((tmp = readw(baseAddr + C320_key)) != C320_KeyCode) { 2733 return (-1); 2734 } 2735 if ((tmp = readw(baseAddr + C320_status)) != STS_init) { 2736 return (-2); 2737 } 2738 } 2739 return (0); 2740} 2741 2742static int moxaload320b(int cardno, unsigned char __user *tmp, int len) 2743{ 2744 void __iomem *baseAddr; 2745 int i; 2746 2747 if(len > sizeof(moxaBuff)) 2748 return -EINVAL; 2749 if(copy_from_user(moxaBuff, tmp, len)) 2750 return -EFAULT; 2751 baseAddr = moxaBaseAddr[cardno]; 2752 writew(len - 7168 - 2, baseAddr + C320bapi_len); 2753 writeb(1, baseAddr + Control_reg); /* Select Page 1 */ 2754 for (i = 0; i < 7168; i++) 2755 writeb(moxaBuff[i], baseAddr + DynPage_addr + i); 2756 writeb(2, baseAddr + Control_reg); /* Select Page 2 */ 2757 for (i = 0; i < (len - 7168); i++) 2758 writeb(moxaBuff[i + 7168], baseAddr + DynPage_addr + i); 2759 return (0); 2760} 2761 2762static int moxaloadcode(int cardno, unsigned char __user *tmp, int len) 2763{ 2764 void __iomem *baseAddr, *ofsAddr; 2765 int retval, port, i; 2766 2767 if(copy_from_user(moxaBuff, tmp, len)) 2768 return -EFAULT; 2769 baseAddr = moxaBaseAddr[cardno]; 2770 switch (moxa_boards[cardno].boardType) { 2771 case MOXA_BOARD_C218_ISA: 2772 case MOXA_BOARD_C218_PCI: 2773 case MOXA_BOARD_CP204J: 2774 retval = moxaloadc218(cardno, baseAddr, len); 2775 if (retval) 2776 return (retval); 2777 port = cardno * MAX_PORTS_PER_BOARD; 2778 for (i = 0; i < moxa_boards[cardno].numPorts; i++, port++) { 2779 moxaChkPort[port] = 1; 2780 moxaCurBaud[port] = 9600L; 2781 moxaDCDState[port] = 0; 2782 moxaTableAddr[port] = baseAddr + Extern_table + Extern_size * i; 2783 ofsAddr = moxaTableAddr[port]; 2784 writew(C218rx_mask, ofsAddr + RX_mask); 2785 writew(C218tx_mask, ofsAddr + TX_mask); 2786 writew(C218rx_spage + i * C218buf_pageno, ofsAddr + Page_rxb); 2787 writew(readw(ofsAddr + Page_rxb) + C218rx_pageno, ofsAddr + EndPage_rxb); 2788 2789 writew(C218tx_spage + i * C218buf_pageno, ofsAddr + Page_txb); 2790 writew(readw(ofsAddr + Page_txb) + C218tx_pageno, ofsAddr + EndPage_txb); 2791 2792 } 2793 break; 2794 default: 2795 retval = moxaloadc320(cardno, baseAddr, len, 2796 &moxa_boards[cardno].numPorts); 2797 if (retval) 2798 return (retval); 2799 port = cardno * MAX_PORTS_PER_BOARD; 2800 for (i = 0; i < moxa_boards[cardno].numPorts; i++, port++) { 2801 moxaChkPort[port] = 1; 2802 moxaCurBaud[port] = 9600L; 2803 moxaDCDState[port] = 0; 2804 moxaTableAddr[port] = baseAddr + Extern_table + Extern_size * i; 2805 ofsAddr = moxaTableAddr[port]; 2806 if (moxa_boards[cardno].numPorts == 8) { 2807 writew(C320p8rx_mask, ofsAddr + RX_mask); 2808 writew(C320p8tx_mask, ofsAddr + TX_mask); 2809 writew(C320p8rx_spage + i * C320p8buf_pgno, ofsAddr + Page_rxb); 2810 writew(readw(ofsAddr + Page_rxb) + C320p8rx_pgno, ofsAddr + EndPage_rxb); 2811 writew(C320p8tx_spage + i * C320p8buf_pgno, ofsAddr + Page_txb); 2812 writew(readw(ofsAddr + Page_txb) + C320p8tx_pgno, ofsAddr + EndPage_txb); 2813 2814 } else if (moxa_boards[cardno].numPorts == 16) { 2815 writew(C320p16rx_mask, ofsAddr + RX_mask); 2816 writew(C320p16tx_mask, ofsAddr + TX_mask); 2817 writew(C320p16rx_spage + i * C320p16buf_pgno, ofsAddr + Page_rxb); 2818 writew(readw(ofsAddr + Page_rxb) + C320p16rx_pgno, ofsAddr + EndPage_rxb); 2819 writew(C320p16tx_spage + i * C320p16buf_pgno, ofsAddr + Page_txb); 2820 writew(readw(ofsAddr + Page_txb) + C320p16tx_pgno, ofsAddr + EndPage_txb); 2821 2822 } else if (moxa_boards[cardno].numPorts == 24) { 2823 writew(C320p24rx_mask, ofsAddr + RX_mask); 2824 writew(C320p24tx_mask, ofsAddr + TX_mask); 2825 writew(C320p24rx_spage + i * C320p24buf_pgno, ofsAddr + Page_rxb); 2826 writew(readw(ofsAddr + Page_rxb) + C320p24rx_pgno, ofsAddr + EndPage_rxb); 2827 writew(C320p24tx_spage + i * C320p24buf_pgno, ofsAddr + Page_txb); 2828 writew(readw(ofsAddr + Page_txb), ofsAddr + EndPage_txb); 2829 } else if (moxa_boards[cardno].numPorts == 32) { 2830 writew(C320p32rx_mask, ofsAddr + RX_mask); 2831 writew(C320p32tx_mask, ofsAddr + TX_mask); 2832 writew(C320p32tx_ofs, ofsAddr + Ofs_txb); 2833 writew(C320p32rx_spage + i * C320p32buf_pgno, ofsAddr + Page_rxb); 2834 writew(readb(ofsAddr + Page_rxb), ofsAddr + EndPage_rxb); 2835 writew(C320p32tx_spage + i * C320p32buf_pgno, ofsAddr + Page_txb); 2836 writew(readw(ofsAddr + Page_txb), ofsAddr + EndPage_txb); 2837 } 2838 } 2839 break; 2840 } 2841 loadstat[cardno] = 1; 2842 return (0); 2843} 2844 2845static int moxaloadc218(int cardno, void __iomem *baseAddr, int len) 2846{ 2847 char retry; 2848 int i, j, len1, len2; 2849 ushort usum, *ptr, keycode; 2850 2851 if (moxa_boards[cardno].boardType == MOXA_BOARD_CP204J) 2852 keycode = CP204J_KeyCode; 2853 else 2854 keycode = C218_KeyCode; 2855 usum = 0; 2856 len1 = len >> 1; 2857 ptr = (ushort *) moxaBuff; 2858 for (i = 0; i < len1; i++) 2859 usum += le16_to_cpu(*(ptr + i)); 2860 retry = 0; 2861 do { 2862 len1 = len >> 1; 2863 j = 0; 2864 while (len1) { 2865 len2 = (len1 > 2048) ? 2048 : len1; 2866 len1 -= len2; 2867 for (i = 0; i < len2 << 1; i++) 2868 writeb(moxaBuff[i + j], baseAddr + C218_LoadBuf + i); 2869 j += i; 2870 2871 writew(len2, baseAddr + C218DLoad_len); 2872 writew(0, baseAddr + C218_key); 2873 for (i = 0; i < 100; i++) { 2874 if (readw(baseAddr + C218_key) == keycode) 2875 break; 2876 moxadelay(1); /* delay 10 ms */ 2877 } 2878 if (readw(baseAddr + C218_key) != keycode) { 2879 return (-1); 2880 } 2881 } 2882 writew(0, baseAddr + C218DLoad_len); 2883 writew(usum, baseAddr + C218check_sum); 2884 writew(0, baseAddr + C218_key); 2885 for (i = 0; i < 100; i++) { 2886 if (readw(baseAddr + C218_key) == keycode) 2887 break; 2888 moxadelay(1); /* delay 10 ms */ 2889 } 2890 retry++; 2891 } while ((readb(baseAddr + C218chksum_ok) != 1) && (retry < 3)); 2892 if (readb(baseAddr + C218chksum_ok) != 1) { 2893 return (-1); 2894 } 2895 writew(0, baseAddr + C218_key); 2896 for (i = 0; i < 100; i++) { 2897 if (readw(baseAddr + Magic_no) == Magic_code) 2898 break; 2899 moxadelay(1); /* delay 10 ms */ 2900 } 2901 if (readw(baseAddr + Magic_no) != Magic_code) { 2902 return (-1); 2903 } 2904 writew(1, baseAddr + Disable_IRQ); 2905 writew(0, baseAddr + Magic_no); 2906 for (i = 0; i < 100; i++) { 2907 if (readw(baseAddr + Magic_no) == Magic_code) 2908 break; 2909 moxadelay(1); /* delay 10 ms */ 2910 } 2911 if (readw(baseAddr + Magic_no) != Magic_code) { 2912 return (-1); 2913 } 2914 moxaCard = 1; 2915 moxaIntNdx[cardno] = baseAddr + IRQindex; 2916 moxaIntPend[cardno] = baseAddr + IRQpending; 2917 moxaIntTable[cardno] = baseAddr + IRQtable; 2918 return (0); 2919} 2920 2921static int moxaloadc320(int cardno, void __iomem *baseAddr, int len, int *numPorts) 2922{ 2923 ushort usum; 2924 int i, j, wlen, len2, retry; 2925 ushort *uptr; 2926 2927 usum = 0; 2928 wlen = len >> 1; 2929 uptr = (ushort *) moxaBuff; 2930 for (i = 0; i < wlen; i++) 2931 usum += le16_to_cpu(uptr[i]); 2932 retry = 0; 2933 j = 0; 2934 do { 2935 while (wlen) { 2936 if (wlen > 2048) 2937 len2 = 2048; 2938 else 2939 len2 = wlen; 2940 wlen -= len2; 2941 len2 <<= 1; 2942 for (i = 0; i < len2; i++) 2943 writeb(moxaBuff[j + i], baseAddr + C320_LoadBuf + i); 2944 len2 >>= 1; 2945 j += i; 2946 writew(len2, baseAddr + C320DLoad_len); 2947 writew(0, baseAddr + C320_key); 2948 for (i = 0; i < 10; i++) { 2949 if (readw(baseAddr + C320_key) == C320_KeyCode) 2950 break; 2951 moxadelay(1); 2952 } 2953 if (readw(baseAddr + C320_key) != C320_KeyCode) 2954 return (-1); 2955 } 2956 writew(0, baseAddr + C320DLoad_len); 2957 writew(usum, baseAddr + C320check_sum); 2958 writew(0, baseAddr + C320_key); 2959 for (i = 0; i < 10; i++) { 2960 if (readw(baseAddr + C320_key) == C320_KeyCode) 2961 break; 2962 moxadelay(1); 2963 } 2964 retry++; 2965 } while ((readb(baseAddr + C320chksum_ok) != 1) && (retry < 3)); 2966 if (readb(baseAddr + C320chksum_ok) != 1) 2967 return (-1); 2968 writew(0, baseAddr + C320_key); 2969 for (i = 0; i < 600; i++) { 2970 if (readw(baseAddr + Magic_no) == Magic_code) 2971 break; 2972 moxadelay(1); 2973 } 2974 if (readw(baseAddr + Magic_no) != Magic_code) 2975 return (-100); 2976 2977 if (moxa_boards[cardno].busType == MOXA_BUS_TYPE_PCI) { /* ASIC board */ 2978 writew(0x3800, baseAddr + TMS320_PORT1); 2979 writew(0x3900, baseAddr + TMS320_PORT2); 2980 writew(28499, baseAddr + TMS320_CLOCK); 2981 } else { 2982 writew(0x3200, baseAddr + TMS320_PORT1); 2983 writew(0x3400, baseAddr + TMS320_PORT2); 2984 writew(19999, baseAddr + TMS320_CLOCK); 2985 } 2986 writew(1, baseAddr + Disable_IRQ); 2987 writew(0, baseAddr + Magic_no); 2988 for (i = 0; i < 500; i++) { 2989 if (readw(baseAddr + Magic_no) == Magic_code) 2990 break; 2991 moxadelay(1); 2992 } 2993 if (readw(baseAddr + Magic_no) != Magic_code) 2994 return (-102); 2995 2996 j = readw(baseAddr + Module_cnt); 2997 if (j <= 0) 2998 return (-101); 2999 *numPorts = j * 8; 3000 writew(j, baseAddr + Module_no); 3001 writew(0, baseAddr + Magic_no); 3002 for (i = 0; i < 600; i++) { 3003 if (readw(baseAddr + Magic_no) == Magic_code) 3004 break; 3005 moxadelay(1); 3006 } 3007 if (readw(baseAddr + Magic_no) != Magic_code) 3008 return (-102); 3009 moxaCard = 1; 3010 moxaIntNdx[cardno] = baseAddr + IRQindex; 3011 moxaIntPend[cardno] = baseAddr + IRQpending; 3012 moxaIntTable[cardno] = baseAddr + IRQtable; 3013 return (0); 3014} 3015 3016#if 0 3017long MoxaPortGetCurBaud(int port) 3018{ 3019 3020 if (moxaChkPort[port] == 0) 3021 return (0); 3022 return (moxaCurBaud[port]); 3023} 3024#endif /* 0 */ 3025 3026static void MoxaSetFifo(int port, int enable) 3027{ 3028 void __iomem *ofsAddr = moxaTableAddr[port]; 3029 3030 if (!enable) { 3031 moxafunc(ofsAddr, FC_SetRxFIFOTrig, 0); 3032 moxafunc(ofsAddr, FC_SetTxFIFOCnt, 1); 3033 } else { 3034 moxafunc(ofsAddr, FC_SetRxFIFOTrig, 3); 3035 moxafunc(ofsAddr, FC_SetTxFIFOCnt, 16); 3036 } 3037} 3038 3039#if 0 3040int MoxaPortSetMode(int port, int databits, int stopbits, int parity) 3041{ 3042 void __iomem *ofsAddr; 3043 int val; 3044 3045 val = 0; 3046 switch (databits) { 3047 case 5: 3048 val |= 0; 3049 break; 3050 case 6: 3051 val |= 1; 3052 break; 3053 case 7: 3054 val |= 2; 3055 break; 3056 case 8: 3057 val |= 3; 3058 break; 3059 default: 3060 return (-1); 3061 } 3062 switch (stopbits) { 3063 case 0: 3064 val |= 0; 3065 break; /* stop bits 1.5 */ 3066 case 1: 3067 val |= 0; 3068 break; 3069 case 2: 3070 val |= 4; 3071 break; 3072 default: 3073 return (-1); 3074 } 3075 switch (parity) { 3076 case 0: 3077 val |= 0x00; 3078 break; /* None */ 3079 case 1: 3080 val |= 0x08; 3081 break; /* Odd */ 3082 case 2: 3083 val |= 0x18; 3084 break; /* Even */ 3085 case 3: 3086 val |= 0x28; 3087 break; /* Mark */ 3088 case 4: 3089 val |= 0x38; 3090 break; /* Space */ 3091 default: 3092 return (-1); 3093 } 3094 ofsAddr = moxaTableAddr[port]; 3095 moxafunc(ofsAddr, FC_SetMode, val); 3096 return (0); 3097} 3098 3099int MoxaPortTxBufSize(int port) 3100{ 3101 void __iomem *ofsAddr; 3102 int size; 3103 3104 ofsAddr = moxaTableAddr[port]; 3105 size = readw(ofsAddr + TX_mask); 3106 return (size); 3107} 3108 3109int MoxaPortRxBufSize(int port) 3110{ 3111 void __iomem *ofsAddr; 3112 int size; 3113 3114 ofsAddr = moxaTableAddr[port]; 3115 size = readw(ofsAddr + RX_mask); 3116 return (size); 3117} 3118 3119int MoxaPortRxFree(int port) 3120{ 3121 void __iomem *ofsAddr; 3122 ushort rptr, wptr, mask; 3123 int len; 3124 3125 ofsAddr = moxaTableAddr[port]; 3126 rptr = readw(ofsAddr + RXrptr); 3127 wptr = readw(ofsAddr + RXwptr); 3128 mask = readw(ofsAddr + RX_mask); 3129 len = mask - ((wptr - rptr) & mask); 3130 return (len); 3131} 3132int MoxaPortGetBrkCnt(int port) 3133{ 3134 return (moxaBreakCnt[port]); 3135} 3136 3137void MoxaPortSetXonXoff(int port, int xonValue, int xoffValue) 3138{ 3139 void __iomem *ofsAddr; 3140 3141 ofsAddr = moxaTableAddr[port]; 3142 writew(xonValue, ofsAddr + FuncArg); 3143 writew(xoffValue, ofsAddr + FuncArg1); 3144 writew(FC_SetXonXoff, ofsAddr + FuncCode); 3145 wait_finish(ofsAddr); 3146} 3147 3148int MoxaPortIsTxHold(int port) 3149{ 3150 void __iomem *ofsAddr; 3151 int val; 3152 3153 ofsAddr = moxaTableAddr[port]; 3154 if ((moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_ISA) || 3155 (moxa_boards[port / MAX_PORTS_PER_BOARD].boardType == MOXA_BOARD_C320_PCI)) { 3156 moxafunc(ofsAddr, FC_GetCCSR, 0); 3157 val = readw(ofsAddr + FuncArg); 3158 if (val & 0x04) 3159 return (1); 3160 } else { 3161 if (readw(ofsAddr + FlagStat) & Tx_flowOff) 3162 return (1); 3163 } 3164 return (0); 3165} 3166#endif