Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
icom.c
Go to the documentation of this file.
1 /*
2  * icom.c
3  *
4  * Copyright (C) 2001 IBM Corporation. All rights reserved.
5  *
6  * Serial device driver.
7  *
8  * Based on code from serial.c
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23  *
24  */
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>
34 #include <linux/fs.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>
43 #include <linux/mm.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>
54 
55 #include <asm/io.h>
56 #include <asm/irq.h>
57 #include <asm/uaccess.h>
58 
59 #include "icom.h"
60 
61 /*#define ICOM_TRACE enable port trace capabilities */
62 
63 #define ICOM_DRIVER_NAME "icom"
64 #define ICOM_VERSION_STR "1.3.1"
65 #define NR_PORTS 128
66 #define ICOM_PORT ((struct icom_port *)port)
67 #define to_icom_adapter(d) container_of(d, struct icom_adapter, kref)
68 
69 static const struct pci_device_id icom_pci_table[] = {
70  {
71  .vendor = PCI_VENDOR_ID_IBM,
73  .subvendor = PCI_ANY_ID,
74  .subdevice = PCI_ANY_ID,
75  .driver_data = ADAPTER_V1,
76  },
77  {
78  .vendor = PCI_VENDOR_ID_IBM,
80  .subvendor = PCI_VENDOR_ID_IBM,
82  .driver_data = ADAPTER_V2,
83  },
84  {
85  .vendor = PCI_VENDOR_ID_IBM,
87  .subvendor = PCI_VENDOR_ID_IBM,
89  .driver_data = ADAPTER_V2,
90  },
91  {
92  .vendor = PCI_VENDOR_ID_IBM,
94  .subvendor = PCI_VENDOR_ID_IBM,
96  .driver_data = ADAPTER_V2,
97  },
98  {
99  .vendor = PCI_VENDOR_ID_IBM,
101  .subvendor = PCI_VENDOR_ID_IBM,
103  .driver_data = ADAPTER_V2,
104  },
105  {}
106 };
107 
113 };
114 
115 
121 };
122 
128 };
129 
130 
131 MODULE_DEVICE_TABLE(pci, icom_pci_table);
132 
133 static LIST_HEAD(icom_adapter_head);
134 
135 /* spinlock for adapter initialization and changing adapter operations */
136 static spinlock_t icom_lock;
137 
138 #ifdef ICOM_TRACE
139 static inline void trace(struct icom_port *icom_port, char *trace_pt,
140  unsigned long trace_data)
141 {
142  dev_info(&icom_port->adapter->pci_dev->dev, ":%d:%s - %lx\n",
143  icom_port->port, trace_pt, trace_data);
144 }
145 #else
146 static inline void trace(struct icom_port *icom_port, char *trace_pt, unsigned long trace_data) {};
147 #endif
148 static void icom_kref_release(struct kref *kref);
149 
150 static void free_port_memory(struct icom_port *icom_port)
151 {
152  struct pci_dev *dev = icom_port->adapter->pci_dev;
153 
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;
159  }
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;
164  }
165  if (icom_port->statStg) {
166  pci_free_consistent(dev, 4096, icom_port->statStg,
167  icom_port->statStg_pci);
168  icom_port->statStg = NULL;
169  }
170 
171  if (icom_port->xmitRestart) {
172  pci_free_consistent(dev, 4096, icom_port->xmitRestart,
173  icom_port->xmitRestart_pci);
174  icom_port->xmitRestart = NULL;
175  }
176 }
177 
178 static int __devinit get_port_memory(struct icom_port *icom_port)
179 {
180  int index;
181  unsigned long stgAddr;
182  unsigned long startStgAddr;
183  unsigned long offset;
184  struct pci_dev *dev = icom_port->adapter->pci_dev;
185 
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");
190  return -ENOMEM;
191  }
192 
193  trace(icom_port, "GET_PORT_MEM",
194  (unsigned long) icom_port->xmit_buf);
195 
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);
201  return -ENOMEM;
202  }
203  trace(icom_port, "GET_PORT_MEM",
204  (unsigned long) icom_port->recv_buf);
205 
206  icom_port->statStg =
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);
211  return -ENOMEM;
212  }
213  trace(icom_port, "GET_PORT_MEM",
214  (unsigned long) icom_port->statStg);
215 
216  icom_port->xmitRestart =
217  pci_alloc_consistent(dev, 4096, &icom_port->xmitRestart_pci);
218  if (!icom_port->xmitRestart) {
219  dev_err(&dev->dev,
220  "Can not allocate xmit Restart buffer\n");
221  free_port_memory(icom_port);
222  return -ENOMEM;
223  }
224 
225  memset(icom_port->statStg, 0, 4096);
226 
227  /* FODs: Frame Out Descriptor Queue, this is a FIFO queue that
228  indicates that frames are to be transmitted
229  */
230 
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);
252  } else {
253  memset(&icom_port->statStg->xmit[index], 0, sizeof(struct xmit_status_area));
254  }
255  }
256  /* FIDs */
257  startStgAddr = stgAddr;
258 
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);
282  } else {
283  icom_port->statStg->rcv[index].leNext = 0;
284  icom_port->statStg->rcv[index].leBuffer = 0;
285  }
286  }
287 
288  return 0;
289 }
290 
291 static void stop_processor(struct icom_port *icom_port)
292 {
293  unsigned long temp;
294  unsigned long flags;
295  int port;
296 
297  spin_lock_irqsave(&icom_lock, flags);
298 
299  port = icom_port->port;
300  if (port == 0 || port == 1)
301  stop_proc[port].global_control_reg = &icom_port->global_reg->control;
302  else
303  stop_proc[port].global_control_reg = &icom_port->global_reg->control_2;
304 
305 
306  if (port < 4) {
307  temp = readl(stop_proc[port].global_control_reg);
308  temp =
309  (temp & ~start_proc[port].processor_id) | stop_proc[port].processor_id;
310  writel(temp, stop_proc[port].global_control_reg);
311 
312  /* write flush */
313  readl(stop_proc[port].global_control_reg);
314  } else {
315  dev_err(&icom_port->adapter->pci_dev->dev,
316  "Invalid port assignment\n");
317  }
318 
319  spin_unlock_irqrestore(&icom_lock, flags);
320 }
321 
322 static void start_processor(struct icom_port *icom_port)
323 {
324  unsigned long temp;
325  unsigned long flags;
326  int port;
327 
328  spin_lock_irqsave(&icom_lock, flags);
329 
330  port = icom_port->port;
331  if (port == 0 || port == 1)
332  start_proc[port].global_control_reg = &icom_port->global_reg->control;
333  else
334  start_proc[port].global_control_reg = &icom_port->global_reg->control_2;
335  if (port < 4) {
336  temp = readl(start_proc[port].global_control_reg);
337  temp =
338  (temp & ~stop_proc[port].processor_id) | start_proc[port].processor_id;
339  writel(temp, start_proc[port].global_control_reg);
340 
341  /* write flush */
342  readl(start_proc[port].global_control_reg);
343  } else {
344  dev_err(&icom_port->adapter->pci_dev->dev,
345  "Invalid port assignment\n");
346  }
347 
348  spin_unlock_irqrestore(&icom_lock, flags);
349 }
350 
351 static void load_code(struct icom_port *icom_port)
352 {
353  const struct firmware *fw;
354  char __iomem *iram_ptr;
355  int index;
356  int status = 0;
357  void __iomem *dram_ptr = icom_port->dram;
358  dma_addr_t temp_pci;
359  unsigned char *new_page = NULL;
360  unsigned char cable_id = NO_CABLE;
361  struct pci_dev *dev = icom_port->adapter->pci_dev;
362 
363  /* Clear out any pending interrupts */
364  writew(0x3FFF, icom_port->int_reg);
365 
366  trace(icom_port, "CLEAR_INTERRUPTS", 0);
367 
368  /* Stop processor */
369  stop_processor(icom_port);
370 
371  /* Zero out DRAM */
372  memset_io(dram_ptr, 0, 512);
373 
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");
377  status = -1;
378  goto load_code_exit;
379  }
380 
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);
384  status = -1;
385  goto load_code_exit;
386  }
387 
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]);
391 
392  release_firmware(fw);
393 
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");
397  status = -1;
398  goto load_code_exit;
399  }
400 
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);
404  status = -1;
405  goto load_code_exit;
406  }
407 
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]);
411 
412  release_firmware(fw);
413 
414  /* Set Hardware level */
415  if (icom_port->adapter->version == ADAPTER_V2)
416  writeb(V2_HARDWARE, &(icom_port->dram->misc_flags));
417 
418  /* Start the processor in Adapter */
419  start_processor(icom_port);
420 
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));
427  ICOM_ACFG_1STOP_BIT), &(icom_port->dram->async_config2));
428 
429  /*Set up data in icom DRAM to indicate where personality
430  *code is located and its length.
431  */
432  new_page = pci_alloc_consistent(dev, 4096, &temp_pci);
433 
434  if (!new_page) {
435  dev_err(&dev->dev, "Can not allocate DMA buffer\n");
436  status = -1;
437  goto load_code_exit;
438  }
439 
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");
442  status = -1;
443  goto load_code_exit;
444  }
445 
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);
449  status = -1;
450  goto load_code_exit;
451  }
452 
453  for (index = 0; index < fw->size; index++)
454  new_page[index] = fw->data[index];
455 
456  release_firmware(fw);
457 
458  writeb((char) ((fw->size + 16)/16), &icom_port->dram->mac_length);
459  writel(temp_pci, &icom_port->dram->mac_load_addr);
460 
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.
466  */
467  /* the wait loop below verifies this write operation has been done
468  and processed
469  */
470  writeb(START_DOWNLOAD, &icom_port->dram->sync);
471 
472  /* Wait max 1 Sec for data download and processor to start */
473  for (index = 0; index < 10; index++) {
474  msleep(100);
475  if (readb(&icom_port->dram->misc_flags) & ICOM_HDW_ACTIVE)
476  break;
477  }
478 
479  if (index == 10)
480  status = -1;
481 
482  /*
483  * check Cable ID
484  */
485  cable_id = readb(&icom_port->dram->cable_id);
486 
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;
491  } else {
492  dev_err(&dev->dev,"Invalid or no cable attached\n");
493  icom_port->cable_id = NO_CABLE;
494  }
495 
496  load_code_exit:
497 
498  if (status != 0) {
499  /* Clear out any pending interrupts */
500  writew(0x3FFF, icom_port->int_reg);
501 
502  /* Turn off port */
503  writeb(ICOM_DISABLE, &(icom_port->dram->disable));
504 
505  /* Stop processor */
506  stop_processor(icom_port);
507 
508  dev_err(&icom_port->adapter->pci_dev->dev,"Port not opertional\n");
509  }
510 
511  if (new_page != NULL)
512  pci_free_consistent(dev, 4096, new_page, temp_pci);
513 }
514 
515 static int startup(struct icom_port *icom_port)
516 {
517  unsigned long temp;
518  unsigned char cable_id, raw_cable_id;
519  unsigned long flags;
520  int port;
521 
522  trace(icom_port, "STARTUP", 0);
523 
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");
528  return -ENODEV;
529  }
530 
531  /*
532  * check Cable ID
533  */
534  raw_cable_id = readb(&icom_port->dram->cable_id);
535  trace(icom_port, "CABLE_ID", raw_cable_id);
536 
537  /* Get cable ID into the lower 4 bits (standard form) */
538  cable_id = (raw_cable_id & ICOM_CABLE_ID_MASK) >> 4;
539 
540  /* Check for valid Cable ID */
541  if (!(raw_cable_id & ICOM_CABLE_ID_VALID) ||
542  (cable_id != icom_port->cable_id)) {
543 
544  /* reload adapter code, pick up any potential changes in cable id */
545  load_code(icom_port);
546 
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))
552  return -EIO;
553  }
554 
555  /*
556  * Finally, clear and enable interrupts
557  */
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;
562  else
563  int_mask_tbl[port].global_int_mask = &icom_port->global_reg->int_mask_2;
564 
565  if (port == 0 || port == 2)
566  writew(0x00FF, icom_port->int_reg);
567  else
568  writew(0x3F00, icom_port->int_reg);
569  if (port < 4) {
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);
572 
573  /* write flush */
574  readl(int_mask_tbl[port].global_int_mask);
575  } else {
576  dev_err(&icom_port->adapter->pci_dev->dev,
577  "Invalid port assignment\n");
578  }
579 
580  spin_unlock_irqrestore(&icom_lock, flags);
581  return 0;
582 }
583 
584 static void shutdown(struct icom_port *icom_port)
585 {
586  unsigned long temp;
587  unsigned char cmdReg;
588  unsigned long flags;
589  int port;
590 
591  spin_lock_irqsave(&icom_lock, flags);
592  trace(icom_port, "SHUTDOWN", 0);
593 
594  /*
595  * disable all interrupts
596  */
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;
600  else
601  int_mask_tbl[port].global_int_mask = &icom_port->global_reg->int_mask_2;
602 
603  if (port < 4) {
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);
606 
607  /* write flush */
608  readl(int_mask_tbl[port].global_int_mask);
609  } else {
610  dev_err(&icom_port->adapter->pci_dev->dev,
611  "Invalid port assignment\n");
612  }
613  spin_unlock_irqrestore(&icom_lock, flags);
614 
615  /*
616  * disable break condition
617  */
618  cmdReg = readb(&icom_port->dram->CmdReg);
619  if (cmdReg & CMD_SND_BREAK) {
620  writeb(cmdReg & ~CMD_SND_BREAK, &icom_port->dram->CmdReg);
621  }
622 }
623 
624 static int icom_write(struct uart_port *port)
625 {
626  unsigned long data_count;
627  unsigned char cmdReg;
628  unsigned long offset;
629  int temp_tail = port->state->xmit.tail;
630 
631  trace(ICOM_PORT, "WRITE", 0);
632 
633  if (cpu_to_le16(ICOM_PORT->statStg->xmit[0].flags) &
635  trace(ICOM_PORT, "WRITE_FULL", 0);
636  return 0;
637  }
638 
639  data_count = 0;
640  while ((port->state->xmit.head != temp_tail) &&
641  (data_count <= XMIT_BUFF_SZ)) {
642 
643  ICOM_PORT->xmit_buf[data_count++] =
644  port->state->xmit.buf[temp_tail];
645 
646  temp_tail++;
647  temp_tail &= (UART_XMIT_SIZE - 1);
648  }
649 
650  if (data_count) {
651  ICOM_PORT->statStg->xmit[0].flags =
653  ICOM_PORT->statStg->xmit[0].leLength =
654  cpu_to_le16(data_count);
655  offset =
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);
665  /* write flush */
666  readb(&ICOM_PORT->dram->StartXmitCmd);
667  }
668 
669  return data_count;
670 }
671 
672 static inline void check_modem_status(struct icom_port *icom_port)
673 {
674  static char old_status = 0;
675  char delta_status;
676  unsigned char status;
677 
678  spin_lock(&icom_port->uart_port.lock);
679 
680  /*modem input register */
681  status = readb(&icom_port->dram->isr);
682  trace(icom_port, "CHECK_MODEM", status);
683  delta_status = status ^ old_status;
684  if (delta_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);
695 
696  wake_up_interruptible(&icom_port->uart_port.state->
697  port.delta_msr_wait);
698  old_status = status;
699  }
700  spin_unlock(&icom_port->uart_port.lock);
701 }
702 
703 static void xmit_interrupt(u16 port_int_reg, struct icom_port *icom_port)
704 {
705  unsigned short int count;
706  int i;
707 
708  if (port_int_reg & (INT_XMIT_COMPLETED)) {
709  trace(icom_port, "XMIT_COMPLETE", 0);
710 
711  /* clear buffer in use bit */
712  icom_port->statStg->xmit[0].flags &=
714 
715  count = (unsigned short int)
716  cpu_to_le16(icom_port->statStg->xmit[0].leLength);
717  icom_port->uart_port.icount.tx += count;
718 
719  for (i=0; i<count &&
720  !uart_circ_empty(&icom_port->uart_port.state->xmit); i++) {
721 
722  icom_port->uart_port.state->xmit.tail++;
723  icom_port->uart_port.state->xmit.tail &=
724  (UART_XMIT_SIZE - 1);
725  }
726 
727  if (!icom_write(&icom_port->uart_port))
728  /* activate write queue */
729  uart_write_wakeup(&icom_port->uart_port);
730  } else
731  trace(icom_port, "XMIT_DISABLED", 0);
732 }
733 
734 static void recv_interrupt(u16 port_int_reg, struct icom_port *icom_port)
735 {
736  short int count, rcv_buff;
737  struct tty_struct *tty = icom_port->uart_port.state->port.tty;
738  unsigned short int status;
739  struct uart_icount *icount;
740  unsigned long offset;
741  unsigned char flag;
742 
743  trace(icom_port, "RCV_COMPLETE", 0);
744  rcv_buff = icom_port->next_rcv;
745 
746  status = cpu_to_le16(icom_port->statStg->rcv[rcv_buff].flags);
747  while (status & SA_FL_RCV_DONE) {
748  int first = -1;
749 
750  trace(icom_port, "FID_STATUS", status);
751  count = cpu_to_le16(icom_port->statStg->rcv[rcv_buff].leLength);
752 
753  trace(icom_port, "RCV_COUNT", count);
754 
755  trace(icom_port, "REAL_COUNT", count);
756 
757  offset =
758  cpu_to_le32(icom_port->statStg->rcv[rcv_buff].leBuffer) -
759  icom_port->recv_buf_pci;
760 
761  /* Block copy all but the last byte as this may have status */
762  if (count > 0) {
763  first = icom_port->recv_buf[offset];
764  tty_insert_flip_string(tty, icom_port->recv_buf + offset, count - 1);
765  }
766 
767  icount = &icom_port->uart_port.icount;
768  icount->rx += count;
769 
770  /* Break detect logic */
771  if ((status & SA_FLAGS_FRAME_ERROR)
772  && first == 0) {
773  status &= ~SA_FLAGS_FRAME_ERROR;
774  status |= SA_FLAGS_BREAK_DET;
775  trace(icom_port, "BREAK_DET", 0);
776  }
777 
778  flag = TTY_NORMAL;
779 
780  if (status &
782  SA_FLAGS_FRAME_ERROR | SA_FLAGS_OVERRUN)) {
783 
784  if (status & SA_FLAGS_BREAK_DET)
785  icount->brk++;
786  if (status & SA_FLAGS_PARITY_ERROR)
787  icount->parity++;
788  if (status & SA_FLAGS_FRAME_ERROR)
789  icount->frame++;
790  if (status & SA_FLAGS_OVERRUN)
791  icount->overrun++;
792 
793  /*
794  * Now check to see if character should be
795  * ignored, and mask off conditions which
796  * should be ignored.
797  */
798  if (status & icom_port->ignore_status_mask) {
799  trace(icom_port, "IGNORE_CHAR", 0);
800  goto ignore_char;
801  }
802 
803  status &= icom_port->read_status_mask;
804 
805  if (status & SA_FLAGS_BREAK_DET) {
806  flag = TTY_BREAK;
807  } else if (status & SA_FLAGS_PARITY_ERROR) {
808  trace(icom_port, "PARITY_ERROR", 0);
809  flag = TTY_PARITY;
810  } else if (status & SA_FLAGS_FRAME_ERROR)
811  flag = TTY_FRAME;
812 
813  }
814 
815  tty_insert_flip_char(tty, *(icom_port->recv_buf + offset + count - 1), flag);
816 
817  if (status & SA_FLAGS_OVERRUN)
818  /*
819  * Overrun is special, since it's
820  * reported immediately, and doesn't
821  * affect the current character
822  */
823  tty_insert_flip_char(tty, 0, TTY_OVERRUN);
824 ignore_char:
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);
829 
830  rcv_buff++;
831  if (rcv_buff == NUM_RBUFFS)
832  rcv_buff = 0;
833 
834  status = cpu_to_le16(icom_port->statStg->rcv[rcv_buff].flags);
835  }
836  icom_port->next_rcv = rcv_buff;
838 }
839 
840 static void process_interrupt(u16 port_int_reg,
841  struct icom_port *icom_port)
842 {
843 
844  spin_lock(&icom_port->uart_port.lock);
845  trace(icom_port, "INTERRUPT", port_int_reg);
846 
847  if (port_int_reg & (INT_XMIT_COMPLETED | INT_XMIT_DISABLED))
848  xmit_interrupt(port_int_reg, icom_port);
849 
850  if (port_int_reg & INT_RCV_COMPLETED)
851  recv_interrupt(port_int_reg, icom_port);
852 
853  spin_unlock(&icom_port->uart_port.lock);
854 }
855 
856 static irqreturn_t icom_interrupt(int irq, void *dev_id)
857 {
858  void __iomem * int_reg;
859  u32 adapter_interrupts;
860  u16 port_int_reg;
861  struct icom_adapter *icom_adapter;
862  struct icom_port *icom_port;
863 
864  /* find icom_port for this interrupt */
865  icom_adapter = (struct icom_adapter *) dev_id;
866 
867  if (icom_adapter->version == ADAPTER_V2) {
868  int_reg = icom_adapter->base_addr + 0x8024;
869 
870  adapter_interrupts = readl(int_reg);
871 
872  if (adapter_interrupts & 0x00003FFF) {
873  /* port 2 interrupt, NOTE: for all ADAPTER_V2, port 2 will be active */
874  icom_port = &icom_adapter->port_info[2];
875  port_int_reg = (u16) adapter_interrupts;
876  process_interrupt(port_int_reg, icom_port);
877  check_modem_status(icom_port);
878  }
879  if (adapter_interrupts & 0x3FFF0000) {
880  /* port 3 interrupt */
881  icom_port = &icom_adapter->port_info[3];
882  if (icom_port->status == ICOM_PORT_ACTIVE) {
883  port_int_reg =
884  (u16) (adapter_interrupts >> 16);
885  process_interrupt(port_int_reg, icom_port);
886  check_modem_status(icom_port);
887  }
888  }
889 
890  /* Clear out any pending interrupts */
891  writel(adapter_interrupts, int_reg);
892 
893  int_reg = icom_adapter->base_addr + 0x8004;
894  } else {
895  int_reg = icom_adapter->base_addr + 0x4004;
896  }
897 
898  adapter_interrupts = readl(int_reg);
899 
900  if (adapter_interrupts & 0x00003FFF) {
901  /* port 0 interrupt, NOTE: for all adapters, port 0 will be active */
902  icom_port = &icom_adapter->port_info[0];
903  port_int_reg = (u16) adapter_interrupts;
904  process_interrupt(port_int_reg, icom_port);
905  check_modem_status(icom_port);
906  }
907  if (adapter_interrupts & 0x3FFF0000) {
908  /* port 1 interrupt */
909  icom_port = &icom_adapter->port_info[1];
910  if (icom_port->status == ICOM_PORT_ACTIVE) {
911  port_int_reg = (u16) (adapter_interrupts >> 16);
912  process_interrupt(port_int_reg, icom_port);
913  check_modem_status(icom_port);
914  }
915  }
916 
917  /* Clear out any pending interrupts */
918  writel(adapter_interrupts, int_reg);
919 
920  /* flush the write */
921  adapter_interrupts = readl(int_reg);
922 
923  return IRQ_HANDLED;
924 }
925 
926 /*
927  * ------------------------------------------------------------------
928  * Begin serial-core API
929  * ------------------------------------------------------------------
930  */
931 static unsigned int icom_tx_empty(struct uart_port *port)
932 {
933  int ret;
934  unsigned long flags;
935 
936  spin_lock_irqsave(&port->lock, flags);
937  if (cpu_to_le16(ICOM_PORT->statStg->xmit[0].flags) &
939  ret = TIOCSER_TEMT;
940  else
941  ret = 0;
942 
943  spin_unlock_irqrestore(&port->lock, flags);
944  return ret;
945 }
946 
947 static void icom_set_mctrl(struct uart_port *port, unsigned int mctrl)
948 {
949  unsigned char local_osr;
950 
951  trace(ICOM_PORT, "SET_MODEM", 0);
952  local_osr = readb(&ICOM_PORT->dram->osr);
953 
954  if (mctrl & TIOCM_RTS) {
955  trace(ICOM_PORT, "RAISE_RTS", 0);
956  local_osr |= ICOM_RTS;
957  } else {
958  trace(ICOM_PORT, "LOWER_RTS", 0);
959  local_osr &= ~ICOM_RTS;
960  }
961 
962  if (mctrl & TIOCM_DTR) {
963  trace(ICOM_PORT, "RAISE_DTR", 0);
964  local_osr |= ICOM_DTR;
965  } else {
966  trace(ICOM_PORT, "LOWER_DTR", 0);
967  local_osr &= ~ICOM_DTR;
968  }
969 
970  writeb(local_osr, &ICOM_PORT->dram->osr);
971 }
972 
973 static unsigned int icom_get_mctrl(struct uart_port *port)
974 {
975  unsigned char status;
976  unsigned int result;
977 
978  trace(ICOM_PORT, "GET_MODEM", 0);
979 
980  status = readb(&ICOM_PORT->dram->isr);
981 
982  result = ((status & ICOM_DCD) ? TIOCM_CAR : 0)
983  | ((status & ICOM_RI) ? TIOCM_RNG : 0)
984  | ((status & ICOM_DSR) ? TIOCM_DSR : 0)
985  | ((status & ICOM_CTS) ? TIOCM_CTS : 0);
986  return result;
987 }
988 
989 static void icom_stop_tx(struct uart_port *port)
990 {
991  unsigned char cmdReg;
992 
993  trace(ICOM_PORT, "STOP", 0);
994  cmdReg = readb(&ICOM_PORT->dram->CmdReg);
995  writeb(cmdReg | CMD_HOLD_XMIT, &ICOM_PORT->dram->CmdReg);
996 }
997 
998 static void icom_start_tx(struct uart_port *port)
999 {
1000  unsigned char cmdReg;
1001 
1002  trace(ICOM_PORT, "START", 0);
1003  cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1004  if ((cmdReg & CMD_HOLD_XMIT) == CMD_HOLD_XMIT)
1005  writeb(cmdReg & ~CMD_HOLD_XMIT,
1006  &ICOM_PORT->dram->CmdReg);
1007 
1008  icom_write(port);
1009 }
1010 
1011 static void icom_send_xchar(struct uart_port *port, char ch)
1012 {
1013  unsigned char xdata;
1014  int index;
1015  unsigned long flags;
1016 
1017  trace(ICOM_PORT, "SEND_XCHAR", ch);
1018 
1019  /* wait .1 sec to send char */
1020  for (index = 0; index < 10; index++) {
1021  spin_lock_irqsave(&port->lock, flags);
1022  xdata = readb(&ICOM_PORT->dram->xchar);
1023  if (xdata == 0x00) {
1024  trace(ICOM_PORT, "QUICK_WRITE", 0);
1025  writeb(ch, &ICOM_PORT->dram->xchar);
1026 
1027  /* flush write operation */
1028  xdata = readb(&ICOM_PORT->dram->xchar);
1029  spin_unlock_irqrestore(&port->lock, flags);
1030  break;
1031  }
1032  spin_unlock_irqrestore(&port->lock, flags);
1033  msleep(10);
1034  }
1035 }
1036 
1037 static void icom_stop_rx(struct uart_port *port)
1038 {
1039  unsigned char cmdReg;
1040 
1041  cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1042  writeb(cmdReg & ~CMD_RCV_ENABLE, &ICOM_PORT->dram->CmdReg);
1043 }
1044 
1045 static void icom_enable_ms(struct uart_port *port)
1046 {
1047  /* no-op */
1048 }
1049 
1050 static void icom_break(struct uart_port *port, int break_state)
1051 {
1052  unsigned char cmdReg;
1053  unsigned long flags;
1054 
1055  spin_lock_irqsave(&port->lock, flags);
1056  trace(ICOM_PORT, "BREAK", 0);
1057  cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1058  if (break_state == -1) {
1059  writeb(cmdReg | CMD_SND_BREAK, &ICOM_PORT->dram->CmdReg);
1060  } else {
1061  writeb(cmdReg & ~CMD_SND_BREAK, &ICOM_PORT->dram->CmdReg);
1062  }
1063  spin_unlock_irqrestore(&port->lock, flags);
1064 }
1065 
1066 static int icom_open(struct uart_port *port)
1067 {
1068  int retval;
1069 
1070  kref_get(&ICOM_PORT->adapter->kref);
1071  retval = startup(ICOM_PORT);
1072 
1073  if (retval) {
1074  kref_put(&ICOM_PORT->adapter->kref, icom_kref_release);
1075  trace(ICOM_PORT, "STARTUP_ERROR", 0);
1076  return retval;
1077  }
1078 
1079  return 0;
1080 }
1081 
1082 static void icom_close(struct uart_port *port)
1083 {
1084  unsigned char cmdReg;
1085 
1086  trace(ICOM_PORT, "CLOSE", 0);
1087 
1088  /* stop receiver */
1089  cmdReg = readb(&ICOM_PORT->dram->CmdReg);
1090  writeb(cmdReg & (unsigned char) ~CMD_RCV_ENABLE,
1091  &ICOM_PORT->dram->CmdReg);
1092 
1093  shutdown(ICOM_PORT);
1094 
1095  kref_put(&ICOM_PORT->adapter->kref, icom_kref_release);
1096 }
1097 
1098 static void icom_set_termios(struct uart_port *port,
1099  struct ktermios *termios,
1100  struct ktermios *old_termios)
1101 {
1102  int baud;
1103  unsigned cflag, iflag;
1104  char new_config2;
1105  char new_config3 = 0;
1106  char tmp_byte;
1107  int index;
1108  int rcv_buff, xmit_buff;
1109  unsigned long offset;
1110  unsigned long flags;
1111 
1112  spin_lock_irqsave(&port->lock, flags);
1113  trace(ICOM_PORT, "CHANGE_SPEED", 0);
1114 
1115  cflag = termios->c_cflag;
1116  iflag = termios->c_iflag;
1117 
1118  new_config2 = ICOM_ACFG_DRIVE1;
1119 
1120  /* byte size and parity */
1121  switch (cflag & CSIZE) {
1122  case CS5: /* 5 bits/char */
1123  new_config2 |= ICOM_ACFG_5BPC;
1124  break;
1125  case CS6: /* 6 bits/char */
1126  new_config2 |= ICOM_ACFG_6BPC;
1127  break;
1128  case CS7: /* 7 bits/char */
1129  new_config2 |= ICOM_ACFG_7BPC;
1130  break;
1131  case CS8: /* 8 bits/char */
1132  new_config2 |= ICOM_ACFG_8BPC;
1133  break;
1134  default:
1135  break;
1136  }
1137  if (cflag & CSTOPB) {
1138  /* 2 stop bits */
1139  new_config2 |= ICOM_ACFG_2STOP_BIT;
1140  }
1141  if (cflag & PARENB) {
1142  /* parity bit enabled */
1143  new_config2 |= ICOM_ACFG_PARITY_ENAB;
1144  trace(ICOM_PORT, "PARENB", 0);
1145  }
1146  if (cflag & PARODD) {
1147  /* odd parity */
1148  new_config2 |= ICOM_ACFG_PARITY_ODD;
1149  trace(ICOM_PORT, "PARODD", 0);
1150  }
1151 
1152  /* Determine divisor based on baud rate */
1153  baud = uart_get_baud_rate(port, termios, old_termios,
1154  icom_acfg_baud[0],
1155  icom_acfg_baud[BAUD_TABLE_LIMIT]);
1156  if (!baud)
1157  baud = 9600; /* B0 transition handled in rs_set_termios */
1158 
1159  for (index = 0; index < BAUD_TABLE_LIMIT; index++) {
1160  if (icom_acfg_baud[index] == baud) {
1161  new_config3 = index;
1162  break;
1163  }
1164  }
1165 
1166  uart_update_timeout(port, cflag, baud);
1167 
1168  /* CTS flow control flag and modem status interrupts */
1169  tmp_byte = readb(&(ICOM_PORT->dram->HDLCConfigReg));
1170  if (cflag & CRTSCTS)
1171  tmp_byte |= HDLC_HDW_FLOW;
1172  else
1173  tmp_byte &= ~HDLC_HDW_FLOW;
1174  writeb(tmp_byte, &(ICOM_PORT->dram->HDLCConfigReg));
1175 
1176  /*
1177  * Set up parity check flag
1178  */
1179  ICOM_PORT->read_status_mask = SA_FLAGS_OVERRUN | SA_FL_RCV_DONE;
1180  if (iflag & INPCK)
1181  ICOM_PORT->read_status_mask |=
1182  SA_FLAGS_FRAME_ERROR | SA_FLAGS_PARITY_ERROR;
1183 
1184  if ((iflag & BRKINT) || (iflag & PARMRK))
1185  ICOM_PORT->read_status_mask |= SA_FLAGS_BREAK_DET;
1186 
1187  /*
1188  * Characters to ignore
1189  */
1190  ICOM_PORT->ignore_status_mask = 0;
1191  if (iflag & IGNPAR)
1192  ICOM_PORT->ignore_status_mask |=
1193  SA_FLAGS_PARITY_ERROR | SA_FLAGS_FRAME_ERROR;
1194  if (iflag & IGNBRK) {
1195  ICOM_PORT->ignore_status_mask |= SA_FLAGS_BREAK_DET;
1196  /*
1197  * If we're ignore parity and break indicators, ignore
1198  * overruns too. (For real raw support).
1199  */
1200  if (iflag & IGNPAR)
1201  ICOM_PORT->ignore_status_mask |= SA_FLAGS_OVERRUN;
1202  }
1203 
1204  /*
1205  * !!! ignore all characters if CREAD is not set
1206  */
1207  if ((cflag & CREAD) == 0)
1208  ICOM_PORT->ignore_status_mask |= SA_FL_RCV_DONE;
1209 
1210  /* Turn off Receiver to prepare for reset */
1211  writeb(CMD_RCV_DISABLE, &ICOM_PORT->dram->CmdReg);
1212 
1213  for (index = 0; index < 10; index++) {
1214  if (readb(&ICOM_PORT->dram->PrevCmdReg) == 0x00) {
1215  break;
1216  }
1217  }
1218 
1219  /* clear all current buffers of data */
1220  for (rcv_buff = 0; rcv_buff < NUM_RBUFFS; rcv_buff++) {
1221  ICOM_PORT->statStg->rcv[rcv_buff].flags = 0;
1222  ICOM_PORT->statStg->rcv[rcv_buff].leLength = 0;
1223  ICOM_PORT->statStg->rcv[rcv_buff].WorkingLength =
1224  (unsigned short int) cpu_to_le16(RCV_BUFF_SZ);
1225  }
1226 
1227  for (xmit_buff = 0; xmit_buff < NUM_XBUFFS; xmit_buff++) {
1228  ICOM_PORT->statStg->xmit[xmit_buff].flags = 0;
1229  }
1230 
1231  /* activate changes and start xmit and receiver here */
1232  /* Enable the receiver */
1233  writeb(new_config3, &(ICOM_PORT->dram->async_config3));
1234  writeb(new_config2, &(ICOM_PORT->dram->async_config2));
1235  tmp_byte = readb(&(ICOM_PORT->dram->HDLCConfigReg));
1236  tmp_byte |= HDLC_PPP_PURE_ASYNC | HDLC_FF_FILL;
1237  writeb(tmp_byte, &(ICOM_PORT->dram->HDLCConfigReg));
1238  writeb(0x04, &(ICOM_PORT->dram->FlagFillIdleTimer)); /* 0.5 seconds */
1239  writeb(0xFF, &(ICOM_PORT->dram->ier)); /* enable modem signal interrupts */
1240 
1241  /* reset processor */
1242  writeb(CMD_RESTART, &ICOM_PORT->dram->CmdReg);
1243 
1244  for (index = 0; index < 10; index++) {
1245  if (readb(&ICOM_PORT->dram->CmdReg) == 0x00) {
1246  break;
1247  }
1248  }
1249 
1250  /* Enable Transmitter and Receiver */
1251  offset =
1252  (unsigned long) &ICOM_PORT->statStg->rcv[0] -
1253  (unsigned long) ICOM_PORT->statStg;
1254  writel(ICOM_PORT->statStg_pci + offset,
1255  &ICOM_PORT->dram->RcvStatusAddr);
1256  ICOM_PORT->next_rcv = 0;
1257  ICOM_PORT->put_length = 0;
1258  *ICOM_PORT->xmitRestart = 0;
1259  writel(ICOM_PORT->xmitRestart_pci,
1260  &ICOM_PORT->dram->XmitStatusAddr);
1261  trace(ICOM_PORT, "XR_ENAB", 0);
1262  writeb(CMD_XMIT_RCV_ENABLE, &ICOM_PORT->dram->CmdReg);
1263 
1264  spin_unlock_irqrestore(&port->lock, flags);
1265 }
1266 
1267 static const char *icom_type(struct uart_port *port)
1268 {
1269  return "icom";
1270 }
1271 
1272 static void icom_release_port(struct uart_port *port)
1273 {
1274 }
1275 
1276 static int icom_request_port(struct uart_port *port)
1277 {
1278  return 0;
1279 }
1280 
1281 static void icom_config_port(struct uart_port *port, int flags)
1282 {
1283  port->type = PORT_ICOM;
1284 }
1285 
1286 static struct uart_ops icom_ops = {
1287  .tx_empty = icom_tx_empty,
1288  .set_mctrl = icom_set_mctrl,
1289  .get_mctrl = icom_get_mctrl,
1290  .stop_tx = icom_stop_tx,
1291  .start_tx = icom_start_tx,
1292  .send_xchar = icom_send_xchar,
1293  .stop_rx = icom_stop_rx,
1294  .enable_ms = icom_enable_ms,
1295  .break_ctl = icom_break,
1296  .startup = icom_open,
1297  .shutdown = icom_close,
1298  .set_termios = icom_set_termios,
1299  .type = icom_type,
1300  .release_port = icom_release_port,
1301  .request_port = icom_request_port,
1302  .config_port = icom_config_port,
1303 };
1304 
1305 #define ICOM_CONSOLE NULL
1306 
1307 static struct uart_driver icom_uart_driver = {
1308  .owner = THIS_MODULE,
1309  .driver_name = ICOM_DRIVER_NAME,
1310  .dev_name = "ttyA",
1311  .major = ICOM_MAJOR,
1312  .minor = ICOM_MINOR_START,
1313  .nr = NR_PORTS,
1314  .cons = ICOM_CONSOLE,
1315 };
1316 
1317 static int __devinit icom_init_ports(struct icom_adapter *icom_adapter)
1318 {
1319  u32 subsystem_id = icom_adapter->subsystem_id;
1320  int i;
1321  struct icom_port *icom_port;
1322 
1323  if (icom_adapter->version == ADAPTER_V1) {
1324  icom_adapter->numb_ports = 2;
1325 
1326  for (i = 0; i < 2; i++) {
1327  icom_port = &icom_adapter->port_info[i];
1328  icom_port->port = i;
1329  icom_port->status = ICOM_PORT_ACTIVE;
1330  icom_port->imbed_modem = ICOM_UNKNOWN;
1331  }
1332  } else {
1333  if (subsystem_id == PCI_DEVICE_ID_IBM_ICOM_FOUR_PORT_MODEL) {
1334  icom_adapter->numb_ports = 4;
1335 
1336  for (i = 0; i < 4; i++) {
1337  icom_port = &icom_adapter->port_info[i];
1338 
1339  icom_port->port = i;
1340  icom_port->status = ICOM_PORT_ACTIVE;
1341  icom_port->imbed_modem = ICOM_IMBED_MODEM;
1342  }
1343  } else {
1344  icom_adapter->numb_ports = 4;
1345 
1346  icom_adapter->port_info[0].port = 0;
1347  icom_adapter->port_info[0].status = ICOM_PORT_ACTIVE;
1348 
1349  if (subsystem_id ==
1351  icom_adapter->port_info[0].imbed_modem = ICOM_IMBED_MODEM;
1352  } else {
1353  icom_adapter->port_info[0].imbed_modem = ICOM_RVX;
1354  }
1355 
1356  icom_adapter->port_info[1].status = ICOM_PORT_OFF;
1357 
1358  icom_adapter->port_info[2].port = 2;
1359  icom_adapter->port_info[2].status = ICOM_PORT_ACTIVE;
1360  icom_adapter->port_info[2].imbed_modem = ICOM_RVX;
1361  icom_adapter->port_info[3].status = ICOM_PORT_OFF;
1362  }
1363  }
1364 
1365  return 0;
1366 }
1367 
1368 static void icom_port_active(struct icom_port *icom_port, struct icom_adapter *icom_adapter, int port_num)
1369 {
1370  if (icom_adapter->version == ADAPTER_V1) {
1371  icom_port->global_reg = icom_adapter->base_addr + 0x4000;
1372  icom_port->int_reg = icom_adapter->base_addr +
1373  0x4004 + 2 - 2 * port_num;
1374  } else {
1375  icom_port->global_reg = icom_adapter->base_addr + 0x8000;
1376  if (icom_port->port < 2)
1377  icom_port->int_reg = icom_adapter->base_addr +
1378  0x8004 + 2 - 2 * icom_port->port;
1379  else
1380  icom_port->int_reg = icom_adapter->base_addr +
1381  0x8024 + 2 - 2 * (icom_port->port - 2);
1382  }
1383 }
1384 static int __devinit icom_load_ports(struct icom_adapter *icom_adapter)
1385 {
1386  struct icom_port *icom_port;
1387  int port_num;
1388 
1389  for (port_num = 0; port_num < icom_adapter->numb_ports; port_num++) {
1390 
1391  icom_port = &icom_adapter->port_info[port_num];
1392 
1393  if (icom_port->status == ICOM_PORT_ACTIVE) {
1394  icom_port_active(icom_port, icom_adapter, port_num);
1395  icom_port->dram = icom_adapter->base_addr +
1396  0x2000 * icom_port->port;
1397 
1398  icom_port->adapter = icom_adapter;
1399 
1400  /* get port memory */
1401  if (get_port_memory(icom_port) != 0) {
1402  dev_err(&icom_port->adapter->pci_dev->dev,
1403  "Memory allocation for port FAILED\n");
1404  }
1405  }
1406  }
1407  return 0;
1408 }
1409 
1410 static int __devinit icom_alloc_adapter(struct icom_adapter
1411  **icom_adapter_ref)
1412 {
1413  int adapter_count = 0;
1414  struct icom_adapter *icom_adapter;
1415  struct icom_adapter *cur_adapter_entry;
1416  struct list_head *tmp;
1417 
1418  icom_adapter = (struct icom_adapter *)
1419  kzalloc(sizeof(struct icom_adapter), GFP_KERNEL);
1420 
1421  if (!icom_adapter) {
1422  return -ENOMEM;
1423  }
1424 
1425  list_for_each(tmp, &icom_adapter_head) {
1426  cur_adapter_entry =
1427  list_entry(tmp, struct icom_adapter,
1429  if (cur_adapter_entry->index != adapter_count) {
1430  break;
1431  }
1432  adapter_count++;
1433  }
1434 
1435  icom_adapter->index = adapter_count;
1436  list_add_tail(&icom_adapter->icom_adapter_entry, tmp);
1437 
1438  *icom_adapter_ref = icom_adapter;
1439  return 0;
1440 }
1441 
1442 static void icom_free_adapter(struct icom_adapter *icom_adapter)
1443 {
1444  list_del(&icom_adapter->icom_adapter_entry);
1445  kfree(icom_adapter);
1446 }
1447 
1448 static void icom_remove_adapter(struct icom_adapter *icom_adapter)
1449 {
1450  struct icom_port *icom_port;
1451  int index;
1452 
1453  for (index = 0; index < icom_adapter->numb_ports; index++) {
1454  icom_port = &icom_adapter->port_info[index];
1455 
1456  if (icom_port->status == ICOM_PORT_ACTIVE) {
1457  dev_info(&icom_adapter->pci_dev->dev,
1458  "Device removed\n");
1459 
1460  uart_remove_one_port(&icom_uart_driver,
1461  &icom_port->uart_port);
1462 
1463  /* be sure that DTR and RTS are dropped */
1464  writeb(0x00, &icom_port->dram->osr);
1465 
1466  /* Wait 0.1 Sec for simple Init to complete */
1467  msleep(100);
1468 
1469  /* Stop proccessor */
1470  stop_processor(icom_port);
1471 
1472  free_port_memory(icom_port);
1473  }
1474  }
1475 
1476  free_irq(icom_adapter->pci_dev->irq, (void *) icom_adapter);
1477  iounmap(icom_adapter->base_addr);
1478  pci_release_regions(icom_adapter->pci_dev);
1479  icom_free_adapter(icom_adapter);
1480 }
1481 
1482 static void icom_kref_release(struct kref *kref)
1483 {
1484  struct icom_adapter *icom_adapter;
1485 
1486  icom_adapter = to_icom_adapter(kref);
1487  icom_remove_adapter(icom_adapter);
1488 }
1489 
1490 static int __devinit icom_probe(struct pci_dev *dev,
1491  const struct pci_device_id *ent)
1492 {
1493  int index;
1494  unsigned int command_reg;
1495  int retval;
1496  struct icom_adapter *icom_adapter;
1497  struct icom_port *icom_port;
1498 
1499  retval = pci_enable_device(dev);
1500  if (retval) {
1501  dev_err(&dev->dev, "Device enable FAILED\n");
1502  return retval;
1503  }
1504 
1505  if ( (retval = pci_request_regions(dev, "icom"))) {
1506  dev_err(&dev->dev, "pci_request_regions FAILED\n");
1507  pci_disable_device(dev);
1508  return retval;
1509  }
1510 
1511  pci_set_master(dev);
1512 
1513  if ( (retval = pci_read_config_dword(dev, PCI_COMMAND, &command_reg))) {
1514  dev_err(&dev->dev, "PCI Config read FAILED\n");
1515  return retval;
1516  }
1517 
1518  pci_write_config_dword(dev, PCI_COMMAND,
1519  command_reg | PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER
1521 
1522  if (ent->driver_data == ADAPTER_V1) {
1523  pci_write_config_dword(dev, 0x44, 0x8300830A);
1524  } else {
1525  pci_write_config_dword(dev, 0x44, 0x42004200);
1526  pci_write_config_dword(dev, 0x48, 0x42004200);
1527  }
1528 
1529 
1530  retval = icom_alloc_adapter(&icom_adapter);
1531  if (retval) {
1532  dev_err(&dev->dev, "icom_alloc_adapter FAILED\n");
1533  retval = -EIO;
1534  goto probe_exit0;
1535  }
1536 
1537  icom_adapter->base_addr_pci = pci_resource_start(dev, 0);
1538  icom_adapter->pci_dev = dev;
1539  icom_adapter->version = ent->driver_data;
1540  icom_adapter->subsystem_id = ent->subdevice;
1541 
1542 
1543  retval = icom_init_ports(icom_adapter);
1544  if (retval) {
1545  dev_err(&dev->dev, "Port configuration failed\n");
1546  goto probe_exit1;
1547  }
1548 
1549  icom_adapter->base_addr = pci_ioremap_bar(dev, 0);
1550 
1551  if (!icom_adapter->base_addr)
1552  goto probe_exit1;
1553 
1554  /* save off irq and request irq line */
1555  if ( (retval = request_irq(dev->irq, icom_interrupt,
1557  (void *) icom_adapter))) {
1558  goto probe_exit2;
1559  }
1560 
1561  retval = icom_load_ports(icom_adapter);
1562 
1563  for (index = 0; index < icom_adapter->numb_ports; index++) {
1564  icom_port = &icom_adapter->port_info[index];
1565 
1566  if (icom_port->status == ICOM_PORT_ACTIVE) {
1567  icom_port->uart_port.irq = icom_port->adapter->pci_dev->irq;
1568  icom_port->uart_port.type = PORT_ICOM;
1569  icom_port->uart_port.iotype = UPIO_MEM;
1570  icom_port->uart_port.membase =
1571  (char *) icom_adapter->base_addr_pci;
1572  icom_port->uart_port.fifosize = 16;
1573  icom_port->uart_port.ops = &icom_ops;
1574  icom_port->uart_port.line =
1575  icom_port->port + icom_adapter->index * 4;
1576  if (uart_add_one_port (&icom_uart_driver, &icom_port->uart_port)) {
1577  icom_port->status = ICOM_PORT_OFF;
1578  dev_err(&dev->dev, "Device add failed\n");
1579  } else
1580  dev_info(&dev->dev, "Device added\n");
1581  }
1582  }
1583 
1584  kref_init(&icom_adapter->kref);
1585  return 0;
1586 
1587 probe_exit2:
1588  iounmap(icom_adapter->base_addr);
1589 probe_exit1:
1590  icom_free_adapter(icom_adapter);
1591 
1592 probe_exit0:
1593  pci_release_regions(dev);
1594  pci_disable_device(dev);
1595 
1596  return retval;
1597 }
1598 
1599 static void __devexit icom_remove(struct pci_dev *dev)
1600 {
1601  struct icom_adapter *icom_adapter;
1602  struct list_head *tmp;
1603 
1604  list_for_each(tmp, &icom_adapter_head) {
1605  icom_adapter = list_entry(tmp, struct icom_adapter,
1606  icom_adapter_entry);
1607  if (icom_adapter->pci_dev == dev) {
1608  kref_put(&icom_adapter->kref, icom_kref_release);
1609  return;
1610  }
1611  }
1612 
1613  dev_err(&dev->dev, "Unable to find device to remove\n");
1614 }
1615 
1616 static struct pci_driver icom_pci_driver = {
1617  .name = ICOM_DRIVER_NAME,
1618  .id_table = icom_pci_table,
1619  .probe = icom_probe,
1620  .remove = __devexit_p(icom_remove),
1621 };
1622 
1623 static int __init icom_init(void)
1624 {
1625  int ret;
1626 
1627  spin_lock_init(&icom_lock);
1628 
1629  ret = uart_register_driver(&icom_uart_driver);
1630  if (ret)
1631  return ret;
1632 
1633  ret = pci_register_driver(&icom_pci_driver);
1634 
1635  if (ret < 0)
1636  uart_unregister_driver(&icom_uart_driver);
1637 
1638  return ret;
1639 }
1640 
1641 static void __exit icom_exit(void)
1642 {
1643  pci_unregister_driver(&icom_pci_driver);
1644  uart_unregister_driver(&icom_uart_driver);
1645 }
1646 
1647 module_init(icom_init);
1648 module_exit(icom_exit);
1649 
1650 MODULE_AUTHOR("Michael Anderson <[email protected]>");
1651 MODULE_DESCRIPTION("IBM iSeries Serial IOA driver");
1653  ("IBM iSeries 2745, 2771, 2772, 2742, 2793 and 2805 Communications adapters");
1654 MODULE_LICENSE("GPL");
1655 MODULE_FIRMWARE("icom_call_setup.bin");
1656 MODULE_FIRMWARE("icom_res_dce.bin");
1657 MODULE_FIRMWARE("icom_asc.bin");