4 * Copyright (C) 2001 IBM Corporation. All rights reserved.
6 * Serial device driver.
8 * Based on code from serial.c
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.
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.
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 #define SERIAL_DO_RESTART
26 #include <linux/module.h>
27 #include <linux/kernel.h>
28 #include <linux/errno.h>
29 #include <linux/signal.h>
30 #include <linux/timer.h>
31 #include <linux/interrupt.h>
32 #include <linux/tty.h>
33 #include <linux/termios.h>
35 #include <linux/tty_flip.h>
36 #include <linux/serial.h>
37 #include <linux/serial_reg.h>
38 #include <linux/major.h>
39 #include <linux/string.h>
40 #include <linux/fcntl.h>
41 #include <linux/ptrace.h>
42 #include <linux/ioport.h>
44 #include <linux/slab.h>
45 #include <linux/init.h>
46 #include <linux/delay.h>
47 #include <linux/pci.h>
48 #include <linux/vmalloc.h>
49 #include <linux/smp.h>
50 #include <linux/spinlock.h>
51 #include <linux/kref.h>
52 #include <linux/firmware.h>
53 #include <linux/bitops.h>
57 #include <asm/uaccess.h>
61 /*#define ICOM_TRACE enable port trace capabilities */
63 #define ICOM_DRIVER_NAME "icom"
64 #define ICOM_VERSION_STR "1.3.1"
66 #define ICOM_PORT ((struct icom_port *)port)
67 #define to_icom_adapter(d) container_of(d, struct icom_adapter, kref)
69 static const struct pci_device_id icom_pci_table[] = {
71 .vendor = PCI_VENDOR_ID_IBM,
72 .device = PCI_DEVICE_ID_IBM_ICOM_DEV_ID_1,
73 .subvendor = PCI_ANY_ID,
74 .subdevice = PCI_ANY_ID,
75 .driver_data = ADAPTER_V1,
78 .vendor = PCI_VENDOR_ID_IBM,
79 .device = PCI_DEVICE_ID_IBM_ICOM_DEV_ID_2,
80 .subvendor = PCI_VENDOR_ID_IBM,
81 .subdevice = PCI_DEVICE_ID_IBM_ICOM_V2_TWO_PORTS_RVX,
82 .driver_data = ADAPTER_V2,
85 .vendor = PCI_VENDOR_ID_IBM,
86 .device = PCI_DEVICE_ID_IBM_ICOM_DEV_ID_2,
87 .subvendor = PCI_VENDOR_ID_IBM,
88 .subdevice = PCI_DEVICE_ID_IBM_ICOM_V2_ONE_PORT_RVX_ONE_PORT_MDM,
89 .driver_data = ADAPTER_V2,
92 .vendor = PCI_VENDOR_ID_IBM,
93 .device = PCI_DEVICE_ID_IBM_ICOM_DEV_ID_2,
94 .subvendor = PCI_VENDOR_ID_IBM,
95 .subdevice = PCI_DEVICE_ID_IBM_ICOM_FOUR_PORT_MODEL,
96 .driver_data = ADAPTER_V2,
99 .vendor = PCI_VENDOR_ID_IBM,
100 .device = PCI_DEVICE_ID_IBM_ICOM_DEV_ID_2,
101 .subvendor = PCI_VENDOR_ID_IBM,
102 .subdevice = PCI_DEVICE_ID_IBM_ICOM_V2_ONE_PORT_RVX_ONE_PORT_MDM_PCIE,
103 .driver_data = ADAPTER_V2,
108 static struct lookup_proc_table start_proc[4] = {
109 {NULL, ICOM_CONTROL_START_A},
110 {NULL, ICOM_CONTROL_START_B},
111 {NULL, ICOM_CONTROL_START_C},
112 {NULL, ICOM_CONTROL_START_D}
116 static struct lookup_proc_table stop_proc[4] = {
117 {NULL, ICOM_CONTROL_STOP_A},
118 {NULL, ICOM_CONTROL_STOP_B},
119 {NULL, ICOM_CONTROL_STOP_C},
120 {NULL, ICOM_CONTROL_STOP_D}
123 static struct lookup_int_table int_mask_tbl[4] = {
124 {NULL, ICOM_INT_MASK_PRC_A},
125 {NULL, ICOM_INT_MASK_PRC_B},
126 {NULL, ICOM_INT_MASK_PRC_C},
127 {NULL, ICOM_INT_MASK_PRC_D},
131 MODULE_DEVICE_TABLE(pci, icom_pci_table);
133 static LIST_HEAD(icom_adapter_head);
135 /* spinlock for adapter initialization and changing adapter operations */
136 static spinlock_t icom_lock;
139 static inline void trace(struct icom_port *icom_port, char *trace_pt,
140 unsigned long trace_data)
142 dev_info(&icom_port->adapter->pci_dev->dev, ":%d:%s - %lx\n",
143 icom_port->port, trace_pt, trace_data);
146 static inline void trace(struct icom_port *icom_port, char *trace_pt, unsigned long trace_data) {};
148 static void icom_kref_release(struct kref *kref);
150 static void free_port_memory(struct icom_port *icom_port)
152 struct pci_dev *dev = icom_port->adapter->pci_dev;
154 trace(icom_port, "RET_PORT_MEM", 0);
155 if (icom_port->recv_buf) {
156 pci_free_consistent(dev, 4096, icom_port->recv_buf,
157 icom_port->recv_buf_pci);
158 icom_port->recv_buf = NULL;
160 if (icom_port->xmit_buf) {
161 pci_free_consistent(dev, 4096, icom_port->xmit_buf,
162 icom_port->xmit_buf_pci);
163 icom_port->xmit_buf = NULL;
165 if (icom_port->statStg) {
166 pci_free_consistent(dev, 4096, icom_port->statStg,
167 icom_port->statStg_pci);
168 icom_port->statStg = NULL;
171 if (icom_port->xmitRestart) {
172 pci_free_consistent(dev, 4096, icom_port->xmitRestart,
173 icom_port->xmitRestart_pci);
174 icom_port->xmitRestart = NULL;
178 static int get_port_memory(struct icom_port *icom_port)
181 unsigned long stgAddr;
182 unsigned long startStgAddr;
183 unsigned long offset;
184 struct pci_dev *dev = icom_port->adapter->pci_dev;
186 icom_port->xmit_buf =
187 pci_alloc_consistent(dev, 4096, &icom_port->xmit_buf_pci);
188 if (!icom_port->xmit_buf) {
189 dev_err(&dev->dev, "Can not allocate Transmit buffer\n");
193 trace(icom_port, "GET_PORT_MEM",
194 (unsigned long) icom_port->xmit_buf);
196 icom_port->recv_buf =
197 pci_alloc_consistent(dev, 4096, &icom_port->recv_buf_pci);
198 if (!icom_port->recv_buf) {
199 dev_err(&dev->dev, "Can not allocate Receive buffer\n");
200 free_port_memory(icom_port);
203 trace(icom_port, "GET_PORT_MEM",
204 (unsigned long) icom_port->recv_buf);
207 pci_alloc_consistent(dev, 4096, &icom_port->statStg_pci);
208 if (!icom_port->statStg) {
209 dev_err(&dev->dev, "Can not allocate Status buffer\n");
210 free_port_memory(icom_port);
213 trace(icom_port, "GET_PORT_MEM",
214 (unsigned long) icom_port->statStg);
216 icom_port->xmitRestart =
217 pci_alloc_consistent(dev, 4096, &icom_port->xmitRestart_pci);
218 if (!icom_port->xmitRestart) {
220 "Can not allocate xmit Restart buffer\n");
221 free_port_memory(icom_port);
225 memset(icom_port->statStg, 0, 4096);
227 /* FODs: Frame Out Descriptor Queue, this is a FIFO queue that
228 indicates that frames are to be transmitted
231 stgAddr = (unsigned long) icom_port->statStg;
232 for (index = 0; index < NUM_XBUFFS; index++) {
233 trace(icom_port, "FOD_ADDR", stgAddr);
234 stgAddr = stgAddr + sizeof(icom_port->statStg->xmit[0]);
235 if (index < (NUM_XBUFFS - 1)) {
236 memset(&icom_port->statStg->xmit[index], 0, sizeof(struct xmit_status_area));
237 icom_port->statStg->xmit[index].leLengthASD =
238 (unsigned short int) cpu_to_le16(XMIT_BUFF_SZ);
239 trace(icom_port, "FOD_ADDR", stgAddr);
240 trace(icom_port, "FOD_XBUFF",
241 (unsigned long) icom_port->xmit_buf);
242 icom_port->statStg->xmit[index].leBuffer =
243 cpu_to_le32(icom_port->xmit_buf_pci);
244 } else if (index == (NUM_XBUFFS - 1)) {
245 memset(&icom_port->statStg->xmit[index], 0, sizeof(struct xmit_status_area));
246 icom_port->statStg->xmit[index].leLengthASD =
247 (unsigned short int) cpu_to_le16(XMIT_BUFF_SZ);
248 trace(icom_port, "FOD_XBUFF",
249 (unsigned long) icom_port->xmit_buf);
250 icom_port->statStg->xmit[index].leBuffer =
251 cpu_to_le32(icom_port->xmit_buf_pci);
253 memset(&icom_port->statStg->xmit[index], 0, sizeof(struct xmit_status_area));
257 startStgAddr = stgAddr;
259 /* fill in every entry, even if no buffer */
260 for (index = 0; index < NUM_RBUFFS; index++) {
261 trace(icom_port, "FID_ADDR", stgAddr);
262 stgAddr = stgAddr + sizeof(icom_port->statStg->rcv[0]);
263 icom_port->statStg->rcv[index].leLength = 0;
264 icom_port->statStg->rcv[index].WorkingLength =
265 (unsigned short int) cpu_to_le16(RCV_BUFF_SZ);
266 if (index < (NUM_RBUFFS - 1) ) {
267 offset = stgAddr - (unsigned long) icom_port->statStg;
268 icom_port->statStg->rcv[index].leNext =
269 cpu_to_le32(icom_port-> statStg_pci + offset);
270 trace(icom_port, "FID_RBUFF",
271 (unsigned long) icom_port->recv_buf);
272 icom_port->statStg->rcv[index].leBuffer =
273 cpu_to_le32(icom_port->recv_buf_pci);
274 } else if (index == (NUM_RBUFFS -1) ) {
275 offset = startStgAddr - (unsigned long) icom_port->statStg;
276 icom_port->statStg->rcv[index].leNext =
277 cpu_to_le32(icom_port-> statStg_pci + offset);
278 trace(icom_port, "FID_RBUFF",
279 (unsigned long) icom_port->recv_buf + 2048);
280 icom_port->statStg->rcv[index].leBuffer =
281 cpu_to_le32(icom_port->recv_buf_pci + 2048);
283 icom_port->statStg->rcv[index].leNext = 0;
284 icom_port->statStg->rcv[index].leBuffer = 0;
291 static void stop_processor(struct icom_port *icom_port)
297 spin_lock_irqsave(&icom_lock, flags);
299 port = icom_port->port;
300 if (port == 0 || port == 1)
301 stop_proc[port].global_control_reg = &icom_port->global_reg->control;
303 stop_proc[port].global_control_reg = &icom_port->global_reg->control_2;
307 temp = readl(stop_proc[port].global_control_reg);
309 (temp & ~start_proc[port].processor_id) | stop_proc[port].processor_id;
310 writel(temp, stop_proc[port].global_control_reg);
313 readl(stop_proc[port].global_control_reg);
315 dev_err(&icom_port->adapter->pci_dev->dev,
316 "Invalid port assignment\n");
319 spin_unlock_irqrestore(&icom_lock, flags);
322 static void start_processor(struct icom_port *icom_port)
328 spin_lock_irqsave(&icom_lock, flags);
330 port = icom_port->port;
331 if (port == 0 || port == 1)
332 start_proc[port].global_control_reg = &icom_port->global_reg->control;
334 start_proc[port].global_control_reg = &icom_port->global_reg->control_2;
336 temp = readl(start_proc[port].global_control_reg);
338 (temp & ~stop_proc[port].processor_id) | start_proc[port].processor_id;
339 writel(temp, start_proc[port].global_control_reg);
342 readl(start_proc[port].global_control_reg);
344 dev_err(&icom_port->adapter->pci_dev->dev,
345 "Invalid port assignment\n");
348 spin_unlock_irqrestore(&icom_lock, flags);
351 static void load_code(struct icom_port *icom_port)
353 const struct firmware *fw;
354 char __iomem *iram_ptr;
357 void __iomem *dram_ptr = icom_port->dram;
359 unsigned char *new_page = NULL;
360 unsigned char cable_id = NO_CABLE;
361 struct pci_dev *dev = icom_port->adapter->pci_dev;
363 /* Clear out any pending interrupts */
364 writew(0x3FFF, icom_port->int_reg);
366 trace(icom_port, "CLEAR_INTERRUPTS", 0);
369 stop_processor(icom_port);
372 memset_io(dram_ptr, 0, 512);
374 /* Load Call Setup into Adapter */
375 if (request_firmware(&fw, "icom_call_setup.bin", &dev->dev) < 0) {
376 dev_err(&dev->dev,"Unable to load icom_call_setup.bin firmware image\n");
381 if (fw->size > ICOM_DCE_IRAM_OFFSET) {
382 dev_err(&dev->dev, "Invalid firmware image for icom_call_setup.bin found.\n");
383 release_firmware(fw);
388 iram_ptr = (char __iomem *)icom_port->dram + ICOM_IRAM_OFFSET;
389 for (index = 0; index < fw->size; index++)
390 writeb(fw->data[index], &iram_ptr[index]);
392 release_firmware(fw);
394 /* Load Resident DCE portion of Adapter */
395 if (request_firmware(&fw, "icom_res_dce.bin", &dev->dev) < 0) {
396 dev_err(&dev->dev,"Unable to load icom_res_dce.bin firmware image\n");
401 if (fw->size > ICOM_IRAM_SIZE) {
402 dev_err(&dev->dev, "Invalid firmware image for icom_res_dce.bin found.\n");
403 release_firmware(fw);
408 iram_ptr = (char __iomem *) icom_port->dram + ICOM_IRAM_OFFSET;
409 for (index = ICOM_DCE_IRAM_OFFSET; index < fw->size; index++)
410 writeb(fw->data[index], &iram_ptr[index]);
412 release_firmware(fw);
414 /* Set Hardware level */
415 if (icom_port->adapter->version == ADAPTER_V2)
416 writeb(V2_HARDWARE, &(icom_port->dram->misc_flags));
418 /* Start the processor in Adapter */
419 start_processor(icom_port);
421 writeb((HDLC_PPP_PURE_ASYNC | HDLC_FF_FILL),
422 &(icom_port->dram->HDLCConfigReg));
423 writeb(0x04, &(icom_port->dram->FlagFillIdleTimer)); /* 0.5 seconds */
424 writeb(0x00, &(icom_port->dram->CmdReg));
425 writeb(0x10, &(icom_port->dram->async_config3));
426 writeb((ICOM_ACFG_DRIVE1 | ICOM_ACFG_NO_PARITY | ICOM_ACFG_8BPC |
427 ICOM_ACFG_1STOP_BIT), &(icom_port->dram->async_config2));
429 /*Set up data in icom DRAM to indicate where personality
430 *code is located and its length.
432 new_page = pci_alloc_consistent(dev, 4096, &temp_pci);
435 dev_err(&dev->dev, "Can not allocate DMA buffer\n");
440 if (request_firmware(&fw, "icom_asc.bin", &dev->dev) < 0) {
441 dev_err(&dev->dev,"Unable to load icom_asc.bin firmware image\n");
446 if (fw->size > ICOM_DCE_IRAM_OFFSET) {
447 dev_err(&dev->dev, "Invalid firmware image for icom_asc.bin found.\n");
448 release_firmware(fw);
453 for (index = 0; index < fw->size; index++)
454 new_page[index] = fw->data[index];
456 release_firmware(fw);
458 writeb((char) ((fw->size + 16)/16), &icom_port->dram->mac_length);
459 writel(temp_pci, &icom_port->dram->mac_load_addr);
461 /*Setting the syncReg to 0x80 causes adapter to start downloading
462 the personality code into adapter instruction RAM.
463 Once code is loaded, it will begin executing and, based on
464 information provided above, will start DMAing data from
465 shared memory to adapter DRAM.
467 /* the wait loop below verifies this write operation has been done
470 writeb(START_DOWNLOAD, &icom_port->dram->sync);
472 /* Wait max 1 Sec for data download and processor to start */
473 for (index = 0; index < 10; index++) {
475 if (readb(&icom_port->dram->misc_flags) & ICOM_HDW_ACTIVE)
485 cable_id = readb(&icom_port->dram->cable_id);
487 if (cable_id & ICOM_CABLE_ID_VALID) {
488 /* Get cable ID into the lower 4 bits (standard form) */
489 cable_id = (cable_id & ICOM_CABLE_ID_MASK) >> 4;
490 icom_port->cable_id = cable_id;
492 dev_err(&dev->dev,"Invalid or no cable attached\n");
493 icom_port->cable_id = NO_CABLE;
499 /* Clear out any pending interrupts */
500 writew(0x3FFF, icom_port->int_reg);
503 writeb(ICOM_DISABLE, &(icom_port->dram->disable));
506 stop_processor(icom_port);
508 dev_err(&icom_port->adapter->pci_dev->dev,"Port not operational\n");
511 if (new_page != NULL)
512 pci_free_consistent(dev, 4096, new_page, temp_pci);
515 static int startup(struct icom_port *icom_port)
518 unsigned char cable_id, raw_cable_id;
522 trace(icom_port, "STARTUP", 0);
524 if (!icom_port->dram) {
525 /* should NEVER be NULL */
526 dev_err(&icom_port->adapter->pci_dev->dev,
527 "Unusable Port, port configuration missing\n");
534 raw_cable_id = readb(&icom_port->dram->cable_id);
535 trace(icom_port, "CABLE_ID", raw_cable_id);
537 /* Get cable ID into the lower 4 bits (standard form) */
538 cable_id = (raw_cable_id & ICOM_CABLE_ID_MASK) >> 4;
540 /* Check for valid Cable ID */
541 if (!(raw_cable_id & ICOM_CABLE_ID_VALID) ||
542 (cable_id != icom_port->cable_id)) {
544 /* reload adapter code, pick up any potential changes in cable id */
545 load_code(icom_port);
547 /* still no sign of cable, error out */
548 raw_cable_id = readb(&icom_port->dram->cable_id);
549 cable_id = (raw_cable_id & ICOM_CABLE_ID_MASK) >> 4;
550 if (!(raw_cable_id & ICOM_CABLE_ID_VALID) ||
551 (icom_port->cable_id == NO_CABLE))
556 * Finally, clear and enable interrupts
558 spin_lock_irqsave(&icom_lock, flags);
559 port = icom_port->port;
560 if (port == 0 || port == 1)
561 int_mask_tbl[port].global_int_mask = &icom_port->global_reg->int_mask;
563 int_mask_tbl[port].global_int_mask = &icom_port->global_reg->int_mask_2;
565 if (port == 0 || port == 2)
566 writew(0x00FF, icom_port->int_reg);
568 writew(0x3F00, icom_port->int_reg);
570 temp = readl(int_mask_tbl[port].global_int_mask);
571 writel(temp & ~int_mask_tbl[port].processor_id, int_mask_tbl[port].global_int_mask);
574 readl(int_mask_tbl[port].global_int_mask);
576 dev_err(&icom_port->adapter->pci_dev->dev,
577 "Invalid port assignment\n");
580 spin_unlock_irqrestore(&icom_lock, flags);
584 static void shutdown(struct icom_port *icom_port)
587 unsigned char cmdReg;
591 spin_lock_irqsave(&icom_lock, flags);
592 trace(icom_port, "SHUTDOWN", 0);
595 * disable all interrupts
597 port = icom_port->port;
598 if (port == 0 || port == 1)
599 int_mask_tbl[port].global_int_mask = &icom_port->global_reg->int_mask;
601 int_mask_tbl[port].global_int_mask = &icom_port->global_reg->int_mask_2;
604 temp = readl(int_mask_tbl[port].global_int_mask);
605 writel(temp | int_mask_tbl[port].processor_id, int_mask_tbl[port].global_int_mask);
608 readl(int_mask_tbl[port].global_int_mask);
610 dev_err(&icom_port->adapter->pci_dev->dev,
611 "Invalid port assignment\n");
613 spin_unlock_irqrestore(&icom_lock, flags);
616 * disable break condition
618 cmdReg = readb(&icom_port->dram->CmdReg);
619 if (cmdReg & CMD_SND_BREAK) {
620 writeb(cmdReg & ~CMD_SND_BREAK, &icom_port->dram->CmdReg);
624 static int icom_write(struct uart_port *port)
626 unsigned long data_count;
627 unsigned char cmdReg;
628 unsigned long offset;
629 int temp_tail = port->state->xmit.tail;
631 trace(ICOM_PORT, "WRITE", 0);
633 if (cpu_to_le16(ICOM_PORT->statStg->xmit[0].flags) &
634 SA_FLAGS_READY_TO_XMIT) {
635 trace(ICOM_PORT, "WRITE_FULL", 0);
640 while ((port->state->xmit.head != temp_tail) &&
641 (data_count <= XMIT_BUFF_SZ)) {
643 ICOM_PORT->xmit_buf[data_count++] =
644 port->state->xmit.buf[temp_tail];
647 temp_tail &= (UART_XMIT_SIZE - 1);
651 ICOM_PORT->statStg->xmit[0].flags =
652 cpu_to_le16(SA_FLAGS_READY_TO_XMIT);
653 ICOM_PORT->statStg->xmit[0].leLength =
654 cpu_to_le16(data_count);
656 (unsigned long) &ICOM_PORT->statStg->xmit[0] -
657 (unsigned long) ICOM_PORT->statStg;
658 *ICOM_PORT->xmitRestart =
659 cpu_to_le32(ICOM_PORT->statStg_pci + offset);
660 cmdReg = readb(&ICOM_PORT->dram->CmdReg);
661 writeb(cmdReg | CMD_XMIT_RCV_ENABLE,
662 &ICOM_PORT->dram->CmdReg);
663 writeb(START_XMIT, &ICOM_PORT->dram->StartXmitCmd);
664 trace(ICOM_PORT, "WRITE_START", data_count);
666 readb(&ICOM_PORT->dram->StartXmitCmd);
672 static inline void check_modem_status(struct icom_port *icom_port)
674 static char old_status = 0;
676 unsigned char status;
678 spin_lock(&icom_port->uart_port.lock);
680 /*modem input register */
681 status = readb(&icom_port->dram->isr);
682 trace(icom_port, "CHECK_MODEM", status);
683 delta_status = status ^ old_status;
685 if (delta_status & ICOM_RI)
686 icom_port->uart_port.icount.rng++;
687 if (delta_status & ICOM_DSR)
688 icom_port->uart_port.icount.dsr++;
689 if (delta_status & ICOM_DCD)
690 uart_handle_dcd_change(&icom_port->uart_port,
691 delta_status & ICOM_DCD);
692 if (delta_status & ICOM_CTS)
693 uart_handle_cts_change(&icom_port->uart_port,
694 delta_status & ICOM_CTS);
696 wake_up_interruptible(&icom_port->uart_port.state->
697 port.delta_msr_wait);
700 spin_unlock(&icom_port->uart_port.lock);
703 static void xmit_interrupt(u16 port_int_reg, struct icom_port *icom_port)
705 unsigned short int count;
708 if (port_int_reg & (INT_XMIT_COMPLETED)) {
709 trace(icom_port, "XMIT_COMPLETE", 0);
711 /* clear buffer in use bit */
712 icom_port->statStg->xmit[0].flags &=
713 cpu_to_le16(~SA_FLAGS_READY_TO_XMIT);
715 count = (unsigned short int)
716 cpu_to_le16(icom_port->statStg->xmit[0].leLength);
717 icom_port->uart_port.icount.tx += count;
720 !uart_circ_empty(&icom_port->uart_port.state->xmit); i++) {
722 icom_port->uart_port.state->xmit.tail++;
723 icom_port->uart_port.state->xmit.tail &=
724 (UART_XMIT_SIZE - 1);
727 if (!icom_write(&icom_port->uart_port))
728 /* activate write queue */
729 uart_write_wakeup(&icom_port->uart_port);
731 trace(icom_port, "XMIT_DISABLED", 0);
734 static void recv_interrupt(u16 port_int_reg, struct icom_port *icom_port)
736 short int count, rcv_buff;
737 struct tty_port *port = &icom_port->uart_port.state->port;
738 unsigned short int status;
739 struct uart_icount *icount;
740 unsigned long offset;
743 trace(icom_port, "RCV_COMPLETE", 0);
744 rcv_buff = icom_port->next_rcv;
746 status = cpu_to_le16(icom_port->statStg->rcv[rcv_buff].flags);
747 while (status & SA_FL_RCV_DONE) {
750 trace(icom_port, "FID_STATUS", status);
751 count = cpu_to_le16(icom_port->statStg->rcv[rcv_buff].leLength);
753 trace(icom_port, "RCV_COUNT", count);
755 trace(icom_port, "REAL_COUNT", count);
758 cpu_to_le32(icom_port->statStg->rcv[rcv_buff].leBuffer) -
759 icom_port->recv_buf_pci;
761 /* Block copy all but the last byte as this may have status */
763 first = icom_port->recv_buf[offset];
764 tty_insert_flip_string(port, icom_port->recv_buf + offset, count - 1);
767 icount = &icom_port->uart_port.icount;
770 /* Break detect logic */
771 if ((status & SA_FLAGS_FRAME_ERROR)
773 status &= ~SA_FLAGS_FRAME_ERROR;
774 status |= SA_FLAGS_BREAK_DET;
775 trace(icom_port, "BREAK_DET", 0);
781 (SA_FLAGS_BREAK_DET | SA_FLAGS_PARITY_ERROR |
782 SA_FLAGS_FRAME_ERROR | SA_FLAGS_OVERRUN)) {
784 if (status & SA_FLAGS_BREAK_DET)
786 if (status & SA_FLAGS_PARITY_ERROR)
788 if (status & SA_FLAGS_FRAME_ERROR)
790 if (status & SA_FLAGS_OVERRUN)
794 * Now check to see if character should be
795 * ignored, and mask off conditions which
798 if (status & icom_port->ignore_status_mask) {
799 trace(icom_port, "IGNORE_CHAR", 0);
803 status &= icom_port->read_status_mask;
805 if (status & SA_FLAGS_BREAK_DET) {
807 } else if (status & SA_FLAGS_PARITY_ERROR) {
808 trace(icom_port, "PARITY_ERROR", 0);
810 } else if (status & SA_FLAGS_FRAME_ERROR)
815 tty_insert_flip_char(port, *(icom_port->recv_buf + offset + count - 1), flag);
817 if (status & SA_FLAGS_OVERRUN)
819 * Overrun is special, since it's
820 * reported immediately, and doesn't
821 * affect the current character
823 tty_insert_flip_char(port, 0, TTY_OVERRUN);
825 icom_port->statStg->rcv[rcv_buff].flags = 0;
826 icom_port->statStg->rcv[rcv_buff].leLength = 0;
827 icom_port->statStg->rcv[rcv_buff].WorkingLength =
828 (unsigned short int) cpu_to_le16(RCV_BUFF_SZ);
831 if (rcv_buff == NUM_RBUFFS)
834 status = cpu_to_le16(icom_port->statStg->rcv[rcv_buff].flags);
836 icom_port->next_rcv = rcv_buff;
838 spin_unlock(&icom_port->uart_port.lock);
839 tty_flip_buffer_push(port);
840 spin_lock(&icom_port->uart_port.lock);
843 static void process_interrupt(u16 port_int_reg,
844 struct icom_port *icom_port)
847 spin_lock(&icom_port->uart_port.lock);
848 trace(icom_port, "INTERRUPT", port_int_reg);
850 if (port_int_reg & (INT_XMIT_COMPLETED | INT_XMIT_DISABLED))
851 xmit_interrupt(port_int_reg, icom_port);
853 if (port_int_reg & INT_RCV_COMPLETED)
854 recv_interrupt(port_int_reg, icom_port);
856 spin_unlock(&icom_port->uart_port.lock);
859 static irqreturn_t icom_interrupt(int irq, void *dev_id)
861 void __iomem * int_reg;
862 u32 adapter_interrupts;
864 struct icom_adapter *icom_adapter;
865 struct icom_port *icom_port;
867 /* find icom_port for this interrupt */
868 icom_adapter = (struct icom_adapter *) dev_id;
870 if (icom_adapter->version == ADAPTER_V2) {
871 int_reg = icom_adapter->base_addr + 0x8024;
873 adapter_interrupts = readl(int_reg);
875 if (adapter_interrupts & 0x00003FFF) {
876 /* port 2 interrupt, NOTE: for all ADAPTER_V2, port 2 will be active */
877 icom_port = &icom_adapter->port_info[2];
878 port_int_reg = (u16) adapter_interrupts;
879 process_interrupt(port_int_reg, icom_port);
880 check_modem_status(icom_port);
882 if (adapter_interrupts & 0x3FFF0000) {
883 /* port 3 interrupt */
884 icom_port = &icom_adapter->port_info[3];
885 if (icom_port->status == ICOM_PORT_ACTIVE) {
887 (u16) (adapter_interrupts >> 16);
888 process_interrupt(port_int_reg, icom_port);
889 check_modem_status(icom_port);
893 /* Clear out any pending interrupts */
894 writel(adapter_interrupts, int_reg);
896 int_reg = icom_adapter->base_addr + 0x8004;
898 int_reg = icom_adapter->base_addr + 0x4004;
901 adapter_interrupts = readl(int_reg);
903 if (adapter_interrupts & 0x00003FFF) {
904 /* port 0 interrupt, NOTE: for all adapters, port 0 will be active */
905 icom_port = &icom_adapter->port_info[0];
906 port_int_reg = (u16) adapter_interrupts;
907 process_interrupt(port_int_reg, icom_port);
908 check_modem_status(icom_port);
910 if (adapter_interrupts & 0x3FFF0000) {
911 /* port 1 interrupt */
912 icom_port = &icom_adapter->port_info[1];
913 if (icom_port->status == ICOM_PORT_ACTIVE) {
914 port_int_reg = (u16) (adapter_interrupts >> 16);
915 process_interrupt(port_int_reg, icom_port);
916 check_modem_status(icom_port);
920 /* Clear out any pending interrupts */
921 writel(adapter_interrupts, int_reg);
923 /* flush the write */
924 adapter_interrupts = readl(int_reg);
930 * ------------------------------------------------------------------
931 * Begin serial-core API
932 * ------------------------------------------------------------------
934 static unsigned int icom_tx_empty(struct uart_port *port)
939 spin_lock_irqsave(&port->lock, flags);
940 if (cpu_to_le16(ICOM_PORT->statStg->xmit[0].flags) &
941 SA_FLAGS_READY_TO_XMIT)
946 spin_unlock_irqrestore(&port->lock, flags);
950 static void icom_set_mctrl(struct uart_port *port, unsigned int mctrl)
952 unsigned char local_osr;
954 trace(ICOM_PORT, "SET_MODEM", 0);
955 local_osr = readb(&ICOM_PORT->dram->osr);
957 if (mctrl & TIOCM_RTS) {
958 trace(ICOM_PORT, "RAISE_RTS", 0);
959 local_osr |= ICOM_RTS;
961 trace(ICOM_PORT, "LOWER_RTS", 0);
962 local_osr &= ~ICOM_RTS;
965 if (mctrl & TIOCM_DTR) {
966 trace(ICOM_PORT, "RAISE_DTR", 0);
967 local_osr |= ICOM_DTR;
969 trace(ICOM_PORT, "LOWER_DTR", 0);
970 local_osr &= ~ICOM_DTR;
973 writeb(local_osr, &ICOM_PORT->dram->osr);
976 static unsigned int icom_get_mctrl(struct uart_port *port)
978 unsigned char status;
981 trace(ICOM_PORT, "GET_MODEM", 0);
983 status = readb(&ICOM_PORT->dram->isr);
985 result = ((status & ICOM_DCD) ? TIOCM_CAR : 0)
986 | ((status & ICOM_RI) ? TIOCM_RNG : 0)
987 | ((status & ICOM_DSR) ? TIOCM_DSR : 0)
988 | ((status & ICOM_CTS) ? TIOCM_CTS : 0);
992 static void icom_stop_tx(struct uart_port *port)
994 unsigned char cmdReg;
996 trace(ICOM_PORT, "STOP", 0);
997 cmdReg = readb(&ICOM_PORT->dram->CmdReg);
998 writeb(cmdReg | CMD_HOLD_XMIT, &ICOM_PORT->dram->CmdReg);
1001 static void icom_start_tx(struct uart_port *port)
1003 unsigned char cmdReg;
1005 trace(ICOM_PORT, "START", 0);
1006 cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1007 if ((cmdReg & CMD_HOLD_XMIT) == CMD_HOLD_XMIT)
1008 writeb(cmdReg & ~CMD_HOLD_XMIT,
1009 &ICOM_PORT->dram->CmdReg);
1014 static void icom_send_xchar(struct uart_port *port, char ch)
1016 unsigned char xdata;
1018 unsigned long flags;
1020 trace(ICOM_PORT, "SEND_XCHAR", ch);
1022 /* wait .1 sec to send char */
1023 for (index = 0; index < 10; index++) {
1024 spin_lock_irqsave(&port->lock, flags);
1025 xdata = readb(&ICOM_PORT->dram->xchar);
1026 if (xdata == 0x00) {
1027 trace(ICOM_PORT, "QUICK_WRITE", 0);
1028 writeb(ch, &ICOM_PORT->dram->xchar);
1030 /* flush write operation */
1031 xdata = readb(&ICOM_PORT->dram->xchar);
1032 spin_unlock_irqrestore(&port->lock, flags);
1035 spin_unlock_irqrestore(&port->lock, flags);
1040 static void icom_stop_rx(struct uart_port *port)
1042 unsigned char cmdReg;
1044 cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1045 writeb(cmdReg & ~CMD_RCV_ENABLE, &ICOM_PORT->dram->CmdReg);
1048 static void icom_enable_ms(struct uart_port *port)
1053 static void icom_break(struct uart_port *port, int break_state)
1055 unsigned char cmdReg;
1056 unsigned long flags;
1058 spin_lock_irqsave(&port->lock, flags);
1059 trace(ICOM_PORT, "BREAK", 0);
1060 cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1061 if (break_state == -1) {
1062 writeb(cmdReg | CMD_SND_BREAK, &ICOM_PORT->dram->CmdReg);
1064 writeb(cmdReg & ~CMD_SND_BREAK, &ICOM_PORT->dram->CmdReg);
1066 spin_unlock_irqrestore(&port->lock, flags);
1069 static int icom_open(struct uart_port *port)
1073 kref_get(&ICOM_PORT->adapter->kref);
1074 retval = startup(ICOM_PORT);
1077 kref_put(&ICOM_PORT->adapter->kref, icom_kref_release);
1078 trace(ICOM_PORT, "STARTUP_ERROR", 0);
1085 static void icom_close(struct uart_port *port)
1087 unsigned char cmdReg;
1089 trace(ICOM_PORT, "CLOSE", 0);
1092 cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1093 writeb(cmdReg & ~CMD_RCV_ENABLE, &ICOM_PORT->dram->CmdReg);
1095 shutdown(ICOM_PORT);
1097 kref_put(&ICOM_PORT->adapter->kref, icom_kref_release);
1100 static void icom_set_termios(struct uart_port *port,
1101 struct ktermios *termios,
1102 struct ktermios *old_termios)
1105 unsigned cflag, iflag;
1107 char new_config3 = 0;
1110 int rcv_buff, xmit_buff;
1111 unsigned long offset;
1112 unsigned long flags;
1114 spin_lock_irqsave(&port->lock, flags);
1115 trace(ICOM_PORT, "CHANGE_SPEED", 0);
1117 cflag = termios->c_cflag;
1118 iflag = termios->c_iflag;
1120 new_config2 = ICOM_ACFG_DRIVE1;
1122 /* byte size and parity */
1123 switch (cflag & CSIZE) {
1124 case CS5: /* 5 bits/char */
1125 new_config2 |= ICOM_ACFG_5BPC;
1127 case CS6: /* 6 bits/char */
1128 new_config2 |= ICOM_ACFG_6BPC;
1130 case CS7: /* 7 bits/char */
1131 new_config2 |= ICOM_ACFG_7BPC;
1133 case CS8: /* 8 bits/char */
1134 new_config2 |= ICOM_ACFG_8BPC;
1139 if (cflag & CSTOPB) {
1141 new_config2 |= ICOM_ACFG_2STOP_BIT;
1143 if (cflag & PARENB) {
1144 /* parity bit enabled */
1145 new_config2 |= ICOM_ACFG_PARITY_ENAB;
1146 trace(ICOM_PORT, "PARENB", 0);
1148 if (cflag & PARODD) {
1150 new_config2 |= ICOM_ACFG_PARITY_ODD;
1151 trace(ICOM_PORT, "PARODD", 0);
1154 /* Determine divisor based on baud rate */
1155 baud = uart_get_baud_rate(port, termios, old_termios,
1157 icom_acfg_baud[BAUD_TABLE_LIMIT]);
1159 baud = 9600; /* B0 transition handled in rs_set_termios */
1161 for (index = 0; index < BAUD_TABLE_LIMIT; index++) {
1162 if (icom_acfg_baud[index] == baud) {
1163 new_config3 = index;
1168 uart_update_timeout(port, cflag, baud);
1170 /* CTS flow control flag and modem status interrupts */
1171 tmp_byte = readb(&(ICOM_PORT->dram->HDLCConfigReg));
1172 if (cflag & CRTSCTS)
1173 tmp_byte |= HDLC_HDW_FLOW;
1175 tmp_byte &= ~HDLC_HDW_FLOW;
1176 writeb(tmp_byte, &(ICOM_PORT->dram->HDLCConfigReg));
1179 * Set up parity check flag
1181 ICOM_PORT->read_status_mask = SA_FLAGS_OVERRUN | SA_FL_RCV_DONE;
1183 ICOM_PORT->read_status_mask |=
1184 SA_FLAGS_FRAME_ERROR | SA_FLAGS_PARITY_ERROR;
1186 if ((iflag & BRKINT) || (iflag & PARMRK))
1187 ICOM_PORT->read_status_mask |= SA_FLAGS_BREAK_DET;
1190 * Characters to ignore
1192 ICOM_PORT->ignore_status_mask = 0;
1194 ICOM_PORT->ignore_status_mask |=
1195 SA_FLAGS_PARITY_ERROR | SA_FLAGS_FRAME_ERROR;
1196 if (iflag & IGNBRK) {
1197 ICOM_PORT->ignore_status_mask |= SA_FLAGS_BREAK_DET;
1199 * If we're ignore parity and break indicators, ignore
1200 * overruns too. (For real raw support).
1203 ICOM_PORT->ignore_status_mask |= SA_FLAGS_OVERRUN;
1207 * !!! ignore all characters if CREAD is not set
1209 if ((cflag & CREAD) == 0)
1210 ICOM_PORT->ignore_status_mask |= SA_FL_RCV_DONE;
1212 /* Turn off Receiver to prepare for reset */
1213 writeb(CMD_RCV_DISABLE, &ICOM_PORT->dram->CmdReg);
1215 for (index = 0; index < 10; index++) {
1216 if (readb(&ICOM_PORT->dram->PrevCmdReg) == 0x00) {
1221 /* clear all current buffers of data */
1222 for (rcv_buff = 0; rcv_buff < NUM_RBUFFS; rcv_buff++) {
1223 ICOM_PORT->statStg->rcv[rcv_buff].flags = 0;
1224 ICOM_PORT->statStg->rcv[rcv_buff].leLength = 0;
1225 ICOM_PORT->statStg->rcv[rcv_buff].WorkingLength =
1226 (unsigned short int) cpu_to_le16(RCV_BUFF_SZ);
1229 for (xmit_buff = 0; xmit_buff < NUM_XBUFFS; xmit_buff++) {
1230 ICOM_PORT->statStg->xmit[xmit_buff].flags = 0;
1233 /* activate changes and start xmit and receiver here */
1234 /* Enable the receiver */
1235 writeb(new_config3, &(ICOM_PORT->dram->async_config3));
1236 writeb(new_config2, &(ICOM_PORT->dram->async_config2));
1237 tmp_byte = readb(&(ICOM_PORT->dram->HDLCConfigReg));
1238 tmp_byte |= HDLC_PPP_PURE_ASYNC | HDLC_FF_FILL;
1239 writeb(tmp_byte, &(ICOM_PORT->dram->HDLCConfigReg));
1240 writeb(0x04, &(ICOM_PORT->dram->FlagFillIdleTimer)); /* 0.5 seconds */
1241 writeb(0xFF, &(ICOM_PORT->dram->ier)); /* enable modem signal interrupts */
1243 /* reset processor */
1244 writeb(CMD_RESTART, &ICOM_PORT->dram->CmdReg);
1246 for (index = 0; index < 10; index++) {
1247 if (readb(&ICOM_PORT->dram->CmdReg) == 0x00) {
1252 /* Enable Transmitter and Receiver */
1254 (unsigned long) &ICOM_PORT->statStg->rcv[0] -
1255 (unsigned long) ICOM_PORT->statStg;
1256 writel(ICOM_PORT->statStg_pci + offset,
1257 &ICOM_PORT->dram->RcvStatusAddr);
1258 ICOM_PORT->next_rcv = 0;
1259 ICOM_PORT->put_length = 0;
1260 *ICOM_PORT->xmitRestart = 0;
1261 writel(ICOM_PORT->xmitRestart_pci,
1262 &ICOM_PORT->dram->XmitStatusAddr);
1263 trace(ICOM_PORT, "XR_ENAB", 0);
1264 writeb(CMD_XMIT_RCV_ENABLE, &ICOM_PORT->dram->CmdReg);
1266 spin_unlock_irqrestore(&port->lock, flags);
1269 static const char *icom_type(struct uart_port *port)
1274 static void icom_release_port(struct uart_port *port)
1278 static int icom_request_port(struct uart_port *port)
1283 static void icom_config_port(struct uart_port *port, int flags)
1285 port->type = PORT_ICOM;
1288 static struct uart_ops icom_ops = {
1289 .tx_empty = icom_tx_empty,
1290 .set_mctrl = icom_set_mctrl,
1291 .get_mctrl = icom_get_mctrl,
1292 .stop_tx = icom_stop_tx,
1293 .start_tx = icom_start_tx,
1294 .send_xchar = icom_send_xchar,
1295 .stop_rx = icom_stop_rx,
1296 .enable_ms = icom_enable_ms,
1297 .break_ctl = icom_break,
1298 .startup = icom_open,
1299 .shutdown = icom_close,
1300 .set_termios = icom_set_termios,
1302 .release_port = icom_release_port,
1303 .request_port = icom_request_port,
1304 .config_port = icom_config_port,
1307 #define ICOM_CONSOLE NULL
1309 static struct uart_driver icom_uart_driver = {
1310 .owner = THIS_MODULE,
1311 .driver_name = ICOM_DRIVER_NAME,
1313 .major = ICOM_MAJOR,
1314 .minor = ICOM_MINOR_START,
1316 .cons = ICOM_CONSOLE,
1319 static int icom_init_ports(struct icom_adapter *icom_adapter)
1321 u32 subsystem_id = icom_adapter->subsystem_id;
1323 struct icom_port *icom_port;
1325 if (icom_adapter->version == ADAPTER_V1) {
1326 icom_adapter->numb_ports = 2;
1328 for (i = 0; i < 2; i++) {
1329 icom_port = &icom_adapter->port_info[i];
1330 icom_port->port = i;
1331 icom_port->status = ICOM_PORT_ACTIVE;
1332 icom_port->imbed_modem = ICOM_UNKNOWN;
1335 if (subsystem_id == PCI_DEVICE_ID_IBM_ICOM_FOUR_PORT_MODEL) {
1336 icom_adapter->numb_ports = 4;
1338 for (i = 0; i < 4; i++) {
1339 icom_port = &icom_adapter->port_info[i];
1341 icom_port->port = i;
1342 icom_port->status = ICOM_PORT_ACTIVE;
1343 icom_port->imbed_modem = ICOM_IMBED_MODEM;
1346 icom_adapter->numb_ports = 4;
1348 icom_adapter->port_info[0].port = 0;
1349 icom_adapter->port_info[0].status = ICOM_PORT_ACTIVE;
1352 PCI_DEVICE_ID_IBM_ICOM_V2_ONE_PORT_RVX_ONE_PORT_MDM) {
1353 icom_adapter->port_info[0].imbed_modem = ICOM_IMBED_MODEM;
1355 icom_adapter->port_info[0].imbed_modem = ICOM_RVX;
1358 icom_adapter->port_info[1].status = ICOM_PORT_OFF;
1360 icom_adapter->port_info[2].port = 2;
1361 icom_adapter->port_info[2].status = ICOM_PORT_ACTIVE;
1362 icom_adapter->port_info[2].imbed_modem = ICOM_RVX;
1363 icom_adapter->port_info[3].status = ICOM_PORT_OFF;
1370 static void icom_port_active(struct icom_port *icom_port, struct icom_adapter *icom_adapter, int port_num)
1372 if (icom_adapter->version == ADAPTER_V1) {
1373 icom_port->global_reg = icom_adapter->base_addr + 0x4000;
1374 icom_port->int_reg = icom_adapter->base_addr +
1375 0x4004 + 2 - 2 * port_num;
1377 icom_port->global_reg = icom_adapter->base_addr + 0x8000;
1378 if (icom_port->port < 2)
1379 icom_port->int_reg = icom_adapter->base_addr +
1380 0x8004 + 2 - 2 * icom_port->port;
1382 icom_port->int_reg = icom_adapter->base_addr +
1383 0x8024 + 2 - 2 * (icom_port->port - 2);
1386 static int icom_load_ports(struct icom_adapter *icom_adapter)
1388 struct icom_port *icom_port;
1391 for (port_num = 0; port_num < icom_adapter->numb_ports; port_num++) {
1393 icom_port = &icom_adapter->port_info[port_num];
1395 if (icom_port->status == ICOM_PORT_ACTIVE) {
1396 icom_port_active(icom_port, icom_adapter, port_num);
1397 icom_port->dram = icom_adapter->base_addr +
1398 0x2000 * icom_port->port;
1400 icom_port->adapter = icom_adapter;
1402 /* get port memory */
1403 if (get_port_memory(icom_port) != 0) {
1404 dev_err(&icom_port->adapter->pci_dev->dev,
1405 "Memory allocation for port FAILED\n");
1412 static int icom_alloc_adapter(struct icom_adapter
1415 int adapter_count = 0;
1416 struct icom_adapter *icom_adapter;
1417 struct icom_adapter *cur_adapter_entry;
1418 struct list_head *tmp;
1420 icom_adapter = kzalloc(sizeof(struct icom_adapter), GFP_KERNEL);
1422 if (!icom_adapter) {
1426 list_for_each(tmp, &icom_adapter_head) {
1428 list_entry(tmp, struct icom_adapter,
1429 icom_adapter_entry);
1430 if (cur_adapter_entry->index != adapter_count) {
1436 icom_adapter->index = adapter_count;
1437 list_add_tail(&icom_adapter->icom_adapter_entry, tmp);
1439 *icom_adapter_ref = icom_adapter;
1443 static void icom_free_adapter(struct icom_adapter *icom_adapter)
1445 list_del(&icom_adapter->icom_adapter_entry);
1446 kfree(icom_adapter);
1449 static void icom_remove_adapter(struct icom_adapter *icom_adapter)
1451 struct icom_port *icom_port;
1454 for (index = 0; index < icom_adapter->numb_ports; index++) {
1455 icom_port = &icom_adapter->port_info[index];
1457 if (icom_port->status == ICOM_PORT_ACTIVE) {
1458 dev_info(&icom_adapter->pci_dev->dev,
1459 "Device removed\n");
1461 uart_remove_one_port(&icom_uart_driver,
1462 &icom_port->uart_port);
1464 /* be sure that DTR and RTS are dropped */
1465 writeb(0x00, &icom_port->dram->osr);
1467 /* Wait 0.1 Sec for simple Init to complete */
1470 /* Stop proccessor */
1471 stop_processor(icom_port);
1473 free_port_memory(icom_port);
1477 free_irq(icom_adapter->pci_dev->irq, (void *) icom_adapter);
1478 iounmap(icom_adapter->base_addr);
1479 pci_release_regions(icom_adapter->pci_dev);
1480 icom_free_adapter(icom_adapter);
1483 static void icom_kref_release(struct kref *kref)
1485 struct icom_adapter *icom_adapter;
1487 icom_adapter = to_icom_adapter(kref);
1488 icom_remove_adapter(icom_adapter);
1491 static int icom_probe(struct pci_dev *dev,
1492 const struct pci_device_id *ent)
1495 unsigned int command_reg;
1497 struct icom_adapter *icom_adapter;
1498 struct icom_port *icom_port;
1500 retval = pci_enable_device(dev);
1502 dev_err(&dev->dev, "Device enable FAILED\n");
1506 if ( (retval = pci_request_regions(dev, "icom"))) {
1507 dev_err(&dev->dev, "pci_request_regions FAILED\n");
1508 pci_disable_device(dev);
1512 pci_set_master(dev);
1514 if ( (retval = pci_read_config_dword(dev, PCI_COMMAND, &command_reg))) {
1515 dev_err(&dev->dev, "PCI Config read FAILED\n");
1519 pci_write_config_dword(dev, PCI_COMMAND,
1520 command_reg | PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER
1521 | PCI_COMMAND_PARITY | PCI_COMMAND_SERR);
1523 if (ent->driver_data == ADAPTER_V1) {
1524 pci_write_config_dword(dev, 0x44, 0x8300830A);
1526 pci_write_config_dword(dev, 0x44, 0x42004200);
1527 pci_write_config_dword(dev, 0x48, 0x42004200);
1531 retval = icom_alloc_adapter(&icom_adapter);
1533 dev_err(&dev->dev, "icom_alloc_adapter FAILED\n");
1538 icom_adapter->base_addr_pci = pci_resource_start(dev, 0);
1539 icom_adapter->pci_dev = dev;
1540 icom_adapter->version = ent->driver_data;
1541 icom_adapter->subsystem_id = ent->subdevice;
1544 retval = icom_init_ports(icom_adapter);
1546 dev_err(&dev->dev, "Port configuration failed\n");
1550 icom_adapter->base_addr = pci_ioremap_bar(dev, 0);
1552 if (!icom_adapter->base_addr)
1555 /* save off irq and request irq line */
1556 if ( (retval = request_irq(dev->irq, icom_interrupt,
1557 IRQF_SHARED, ICOM_DRIVER_NAME,
1558 (void *) icom_adapter))) {
1562 retval = icom_load_ports(icom_adapter);
1564 for (index = 0; index < icom_adapter->numb_ports; index++) {
1565 icom_port = &icom_adapter->port_info[index];
1567 if (icom_port->status == ICOM_PORT_ACTIVE) {
1568 icom_port->uart_port.irq = icom_port->adapter->pci_dev->irq;
1569 icom_port->uart_port.type = PORT_ICOM;
1570 icom_port->uart_port.iotype = UPIO_MEM;
1571 icom_port->uart_port.membase =
1572 (unsigned char __iomem *)icom_adapter->base_addr_pci;
1573 icom_port->uart_port.fifosize = 16;
1574 icom_port->uart_port.ops = &icom_ops;
1575 icom_port->uart_port.line =
1576 icom_port->port + icom_adapter->index * 4;
1577 if (uart_add_one_port (&icom_uart_driver, &icom_port->uart_port)) {
1578 icom_port->status = ICOM_PORT_OFF;
1579 dev_err(&dev->dev, "Device add failed\n");
1581 dev_info(&dev->dev, "Device added\n");
1585 kref_init(&icom_adapter->kref);
1589 iounmap(icom_adapter->base_addr);
1591 icom_free_adapter(icom_adapter);
1594 pci_release_regions(dev);
1595 pci_disable_device(dev);
1600 static void icom_remove(struct pci_dev *dev)
1602 struct icom_adapter *icom_adapter;
1603 struct list_head *tmp;
1605 list_for_each(tmp, &icom_adapter_head) {
1606 icom_adapter = list_entry(tmp, struct icom_adapter,
1607 icom_adapter_entry);
1608 if (icom_adapter->pci_dev == dev) {
1609 kref_put(&icom_adapter->kref, icom_kref_release);
1614 dev_err(&dev->dev, "Unable to find device to remove\n");
1617 static struct pci_driver icom_pci_driver = {
1618 .name = ICOM_DRIVER_NAME,
1619 .id_table = icom_pci_table,
1620 .probe = icom_probe,
1621 .remove = icom_remove,
1624 static int __init icom_init(void)
1628 spin_lock_init(&icom_lock);
1630 ret = uart_register_driver(&icom_uart_driver);
1634 ret = pci_register_driver(&icom_pci_driver);
1637 uart_unregister_driver(&icom_uart_driver);
1642 static void __exit icom_exit(void)
1644 pci_unregister_driver(&icom_pci_driver);
1645 uart_unregister_driver(&icom_uart_driver);
1648 module_init(icom_init);
1649 module_exit(icom_exit);
1651 MODULE_AUTHOR("Michael Anderson <mjanders@us.ibm.com>");
1652 MODULE_DESCRIPTION("IBM iSeries Serial IOA driver");
1653 MODULE_SUPPORTED_DEVICE
1654 ("IBM iSeries 2745, 2771, 2772, 2742, 2793 and 2805 Communications adapters");
1655 MODULE_LICENSE("GPL");
1656 MODULE_FIRMWARE("icom_call_setup.bin");
1657 MODULE_FIRMWARE("icom_res_dce.bin");
1658 MODULE_FIRMWARE("icom_asc.bin");