Lines Matching full:card
93 _set_debug(struct tiger_hw *card) in _set_debug() argument
95 card->isac.dch.debug = debug; in _set_debug()
96 card->bc[0].bch.debug = debug; in _set_debug()
97 card->bc[1].bch.debug = debug; in _set_debug()
104 struct tiger_hw *card; in set_debug() local
109 list_for_each_entry(card, &Cards, list) in set_debug()
110 _set_debug(card); in set_debug()
124 nj_disable_hwirq(struct tiger_hw *card) in nj_disable_hwirq() argument
126 outb(0, card->base + NJ_IRQMASK0); in nj_disable_hwirq()
127 outb(0, card->base + NJ_IRQMASK1); in nj_disable_hwirq()
134 struct tiger_hw *card = p; in ReadISAC_nj() local
137 card->auxd &= 0xfc; in ReadISAC_nj()
138 card->auxd |= (offset >> 4) & 3; in ReadISAC_nj()
139 outb(card->auxd, card->base + NJ_AUXDATA); in ReadISAC_nj()
140 ret = inb(card->base + NJ_ISAC_OFF + ((offset & 0x0f) << 2)); in ReadISAC_nj()
147 struct tiger_hw *card = p; in WriteISAC_nj() local
149 card->auxd &= 0xfc; in WriteISAC_nj()
150 card->auxd |= (offset >> 4) & 3; in WriteISAC_nj()
151 outb(card->auxd, card->base + NJ_AUXDATA); in WriteISAC_nj()
152 outb(value, card->base + NJ_ISAC_OFF + ((offset & 0x0f) << 2)); in WriteISAC_nj()
158 struct tiger_hw *card = p; in ReadFiFoISAC_nj() local
160 card->auxd &= 0xfc; in ReadFiFoISAC_nj()
161 outb(card->auxd, card->base + NJ_AUXDATA); in ReadFiFoISAC_nj()
162 insb(card->base + NJ_ISAC_OFF, data, size); in ReadFiFoISAC_nj()
168 struct tiger_hw *card = p; in WriteFiFoISAC_nj() local
170 card->auxd &= 0xfc; in WriteFiFoISAC_nj()
171 outb(card->auxd, card->base + NJ_AUXDATA); in WriteFiFoISAC_nj()
172 outsb(card->base + NJ_ISAC_OFF, data, size); in WriteFiFoISAC_nj()
178 struct tiger_hw *card = bc->bch.hw; in fill_mem() local
181 pr_debug("%s: B%1d fill %02x len %d idx %d/%d\n", card->name, in fill_mem()
182 bc->bch.nr, fill, cnt, idx, card->send.idx); in fill_mem()
189 val = card->send.start[idx]; in fill_mem()
192 card->send.start[idx++] = val; in fill_mem()
193 if (idx >= card->send.size) in fill_mem()
201 struct tiger_hw *card = bc->bch.hw; in mode_tiger() local
203 pr_debug("%s: B%1d protocol %x-->%x\n", card->name, in mode_tiger()
209 fill_mem(bc, 0, card->send.size, 0xff); in mode_tiger()
212 if ((card->bc[0].bch.state == ISDN_P_NONE) && in mode_tiger()
213 (card->bc[1].bch.state == ISDN_P_NONE)) { in mode_tiger()
214 card->dmactrl = 0; in mode_tiger()
215 outb(card->dmactrl, card->base + NJ_DMACTRL); in mode_tiger()
216 outb(0, card->base + NJ_IRQMASK0); in mode_tiger()
228 bc->free = card->send.size / 2; in mode_tiger()
232 if (!card->dmactrl) { in mode_tiger()
233 card->dmactrl = 1; in mode_tiger()
234 outb(card->dmactrl, card->base + NJ_DMACTRL); in mode_tiger()
235 outb(0x0f, card->base + NJ_IRQMASK0); in mode_tiger()
242 bc->free = card->send.size / 2; in mode_tiger()
248 if (!card->dmactrl) { in mode_tiger()
249 card->dmactrl = 1; in mode_tiger()
250 outb(card->dmactrl, card->base + NJ_DMACTRL); in mode_tiger()
251 outb(0x0f, card->base + NJ_IRQMASK0); in mode_tiger()
255 pr_info("%s: %s protocol %x not handled\n", card->name, in mode_tiger()
259 card->send.dmacur = inl(card->base + NJ_DMA_READ_ADR); in mode_tiger()
260 card->recv.dmacur = inl(card->base + NJ_DMA_WRITE_ADR); in mode_tiger()
261 card->send.idx = (card->send.dmacur - card->send.dmastart) >> 2; in mode_tiger()
262 card->recv.idx = (card->recv.dmacur - card->recv.dmastart) >> 2; in mode_tiger()
264 card->name, __func__, in mode_tiger()
265 inb(card->base + NJ_DMACTRL), in mode_tiger()
266 inb(card->base + NJ_IRQMASK0), in mode_tiger()
267 inb(card->base + NJ_IRQSTAT0), in mode_tiger()
268 card->send.idx, in mode_tiger()
269 card->recv.idx); in mode_tiger()
274 nj_reset(struct tiger_hw *card) in nj_reset() argument
276 outb(0xff, card->base + NJ_CTRL); /* Reset On */ in nj_reset()
281 if (card->typ == NETJET_S_TJ320) /* TJ320 */ in nj_reset()
282 card->ctrlreg = 0x40; /* Reset Off and status read clear */ in nj_reset()
284 card->ctrlreg = 0x00; /* Reset Off and status read clear */ in nj_reset()
285 outb(card->ctrlreg, card->base + NJ_CTRL); in nj_reset()
289 card->auxd = 0; in nj_reset()
290 card->dmactrl = 0; in nj_reset()
291 outb(~NJ_ISACIRQ, card->base + NJ_AUXCTRL); in nj_reset()
292 outb(NJ_ISACIRQ, card->base + NJ_IRQMASK1); in nj_reset()
293 outb(card->auxd, card->base + NJ_AUXDATA); in nj_reset()
297 inittiger(struct tiger_hw *card) in inittiger() argument
301 card->dma_p = dma_alloc_coherent(&card->pdev->dev, NJ_DMA_SIZE, in inittiger()
302 &card->dma, GFP_ATOMIC); in inittiger()
303 if (!card->dma_p) { in inittiger()
304 pr_info("%s: No DMA memory\n", card->name); in inittiger()
307 if ((u64)card->dma > 0xffffffff) { in inittiger()
308 pr_info("%s: DMA outside 32 bit\n", card->name); in inittiger()
312 card->bc[i].hsbuf = kmalloc(NJ_DMA_TXSIZE, GFP_ATOMIC); in inittiger()
313 if (!card->bc[i].hsbuf) { in inittiger()
314 pr_info("%s: no B%d send buffer\n", card->name, i + 1); in inittiger()
317 card->bc[i].hrbuf = kmalloc(NJ_DMA_RXSIZE, GFP_ATOMIC); in inittiger()
318 if (!card->bc[i].hrbuf) { in inittiger()
319 pr_info("%s: no B%d recv buffer\n", card->name, i + 1); in inittiger()
323 memset(card->dma_p, 0xff, NJ_DMA_SIZE); in inittiger()
325 card->send.start = card->dma_p; in inittiger()
326 card->send.dmastart = (u32)card->dma; in inittiger()
327 card->send.dmaend = card->send.dmastart + in inittiger()
329 card->send.dmairq = card->send.dmastart + in inittiger()
331 card->send.size = NJ_DMA_TXSIZE; in inittiger()
335 " size %zu u32\n", card->name, in inittiger()
336 card->send.dmastart, card->send.dmairq, in inittiger()
337 card->send.dmaend, card->send.start, card->send.size); in inittiger()
339 outl(card->send.dmastart, card->base + NJ_DMA_READ_START); in inittiger()
340 outl(card->send.dmairq, card->base + NJ_DMA_READ_IRQ); in inittiger()
341 outl(card->send.dmaend, card->base + NJ_DMA_READ_END); in inittiger()
343 card->recv.start = card->dma_p + (NJ_DMA_SIZE / 2); in inittiger()
344 card->recv.dmastart = (u32)card->dma + (NJ_DMA_SIZE / 2); in inittiger()
345 card->recv.dmaend = card->recv.dmastart + in inittiger()
347 card->recv.dmairq = card->recv.dmastart + in inittiger()
349 card->recv.size = NJ_DMA_RXSIZE; in inittiger()
353 " size %zu u32\n", card->name, in inittiger()
354 card->recv.dmastart, card->recv.dmairq, in inittiger()
355 card->recv.dmaend, card->recv.start, card->recv.size); in inittiger()
357 outl(card->recv.dmastart, card->base + NJ_DMA_WRITE_START); in inittiger()
358 outl(card->recv.dmairq, card->base + NJ_DMA_WRITE_IRQ); in inittiger()
359 outl(card->recv.dmaend, card->base + NJ_DMA_WRITE_END); in inittiger()
366 struct tiger_hw *card = bc->bch.hw; in read_dma() local
373 pr_info("%s: B%1d overrun at idx %d\n", card->name, in read_dma()
385 card->name, bc->bch.nr, cnt); in read_dma()
394 val = card->recv.start[idx++]; in read_dma()
397 if (idx >= card->recv.size) in read_dma()
414 snprintf(card->log, LOG_SIZE, in read_dma()
416 card->name, stat); in read_dma()
417 print_hex_dump_bytes(card->log, in read_dma()
425 card->name, bc->bch.nr, cnt); in read_dma()
430 card->name, bc->bch.nr); in read_dma()
433 card->name, bc->bch.nr); in read_dma()
436 card->name, bc->bch.nr, bc->bch.maxlen); in read_dma()
444 recv_tiger(struct tiger_hw *card, u8 irq_stat) in recv_tiger() argument
447 int cnt = card->recv.size / 2; in recv_tiger()
450 card->last_is0 &= ~NJ_IRQM0_WR_MASK; in recv_tiger()
451 card->last_is0 |= (irq_stat & NJ_IRQM0_WR_MASK); in recv_tiger()
456 idx = card->recv.size - 1; in recv_tiger()
458 if (test_bit(FLG_ACTIVE, &card->bc[0].bch.Flags)) in recv_tiger()
459 read_dma(&card->bc[0], idx, cnt); in recv_tiger()
460 if (test_bit(FLG_ACTIVE, &card->bc[1].bch.Flags)) in recv_tiger()
461 read_dma(&card->bc[1], idx, cnt); in recv_tiger()
466 resync(struct tiger_ch *bc, struct tiger_hw *card) in resync() argument
468 card->send.dmacur = inl(card->base | NJ_DMA_READ_ADR); in resync()
469 card->send.idx = (card->send.dmacur - card->send.dmastart) >> 2; in resync()
470 if (bc->free > card->send.size / 2) in resync()
471 bc->free = card->send.size / 2; in resync()
476 if (card->send.idx < ((card->send.size / 2) - 1)) in resync()
477 bc->idx = (card->recv.size / 2) - 1; in resync()
479 bc->idx = card->recv.size - 1; in resync()
481 pr_debug("%s: %s B%1d free %d idx %d/%d\n", card->name, in resync()
482 __func__, bc->bch.nr, bc->free, bc->idx, card->send.idx); in resync()
490 struct tiger_hw *card = bc->bch.hw; in fill_hdlc_flag() local
497 pr_debug("%s: %s B%1d %d state %x idx %d/%d\n", card->name, in fill_hdlc_flag()
499 bc->idx, card->send.idx); in fill_hdlc_flag()
501 resync(bc, card); in fill_hdlc_flag()
504 pr_debug("%s: B%1d hdlc encoded %d flags\n", card->name, in fill_hdlc_flag()
510 if (bc->idx >= card->send.size) in fill_hdlc_flag()
512 v = card->send.start[bc->idx]; in fill_hdlc_flag()
515 card->send.start[bc->idx++] = v; in fill_hdlc_flag()
518 snprintf(card->log, LOG_SIZE, "B%1d-send %s %d ", in fill_hdlc_flag()
519 bc->bch.nr, card->name, count); in fill_hdlc_flag()
520 print_hex_dump_bytes(card->log, DUMP_PREFIX_OFFSET, p, count); in fill_hdlc_flag()
527 struct tiger_hw *card = bc->bch.hw; in fill_dma() local
538 count = card->send.size >> 1; in fill_dma()
545 card->name, __func__, bc->bch.nr, count, bc->free, in fill_dma()
547 bc->idx, card->send.idx); in fill_dma()
551 resync(bc, card); in fill_dma()
555 pr_debug("%s: B%1d hdlc encoded %d in %d\n", card->name, in fill_dma()
573 if (bc->idx >= card->send.size) in fill_dma()
575 v = card->send.start[bc->idx]; in fill_dma()
578 card->send.start[bc->idx++] = v; in fill_dma()
582 if (bc->idx >= card->send.size) in fill_dma()
584 v = card->send.start[bc->idx]; in fill_dma()
588 card->send.start[bc->idx++] = v; in fill_dma()
592 snprintf(card->log, LOG_SIZE, "B%1d-send %s %d ", in fill_dma()
593 bc->bch.nr, card->name, count); in fill_dma()
594 print_hex_dump_bytes(card->log, DUMP_PREFIX_OFFSET, p, count); in fill_dma()
626 send_tiger_bc(struct tiger_hw *card, struct tiger_ch *bc) in send_tiger_bc() argument
630 bc->free += card->send.size / 2; in send_tiger_bc()
631 if (bc->free >= card->send.size) { in send_tiger_bc()
633 pr_info("%s: B%1d TX underrun state %x\n", card->name, in send_tiger_bc()
637 bc->free = card->send.size; in send_tiger_bc()
645 pr_debug("%s: B%1d TX no data free %d idx %d/%d\n", card->name, in send_tiger_bc()
646 bc->bch.nr, bc->free, bc->idx, card->send.idx); in send_tiger_bc()
649 if (bc->free == card->send.size) in send_tiger_bc()
656 send_tiger(struct tiger_hw *card, u8 irq_stat) in send_tiger() argument
661 if ((irq_stat & card->last_is0) & NJ_IRQM0_RD_MASK) { in send_tiger()
663 card->name, irq_stat, card->last_is0); in send_tiger()
666 card->last_is0 &= ~NJ_IRQM0_RD_MASK; in send_tiger()
667 card->last_is0 |= (irq_stat & NJ_IRQM0_RD_MASK); in send_tiger()
670 if (test_bit(FLG_ACTIVE, &card->bc[i].bch.Flags)) in send_tiger()
671 send_tiger_bc(card, &card->bc[i]); in send_tiger()
678 struct tiger_hw *card = dev_id; in nj_irq() local
681 spin_lock(&card->lock); in nj_irq()
682 s0val = inb(card->base | NJ_IRQSTAT0); in nj_irq()
683 s1val = inb(card->base | NJ_IRQSTAT1); in nj_irq()
686 spin_unlock(&card->lock); in nj_irq()
689 pr_debug("%s: IRQSTAT0 %02x IRQSTAT1 %02x\n", card->name, s0val, s1val); in nj_irq()
690 card->irqcnt++; in nj_irq()
692 val = ReadISAC_nj(card, ISAC_ISTA); in nj_irq()
694 mISDNisac_irq(&card->isac, val); in nj_irq()
699 outb(s0val, card->base | NJ_IRQSTAT0); in nj_irq()
704 card->recv.dmacur = inl(card->base | NJ_DMA_WRITE_ADR); in nj_irq()
705 card->recv.idx = (card->recv.dmacur - card->recv.dmastart) >> 2; in nj_irq()
706 if (card->recv.dmacur < card->recv.dmairq) in nj_irq()
711 card->send.dmacur = inl(card->base | NJ_DMA_READ_ADR); in nj_irq()
712 card->send.idx = (card->send.dmacur - card->send.dmastart) >> 2; in nj_irq()
713 if (card->send.dmacur < card->send.dmairq) in nj_irq()
718 pr_debug("%s: DMA Status %02x/%02x/%02x %d/%d\n", card->name, in nj_irq()
719 s1val, s0val, card->last_is0, in nj_irq()
720 card->recv.idx, card->send.idx); in nj_irq()
722 if (s0val != card->last_is0) { in nj_irq()
724 (card->last_is0 & NJ_IRQM0_RD_MASK)) in nj_irq()
726 send_tiger(card, s0val); in nj_irq()
728 (card->last_is0 & NJ_IRQM0_WR_MASK)) in nj_irq()
730 recv_tiger(card, s0val); in nj_irq()
733 spin_unlock(&card->lock); in nj_irq()
743 struct tiger_hw *card = bch->hw; in nj_l2l1B() local
749 spin_lock_irqsave(&card->lock, flags); in nj_l2l1B()
755 spin_unlock_irqrestore(&card->lock, flags); in nj_l2l1B()
758 spin_lock_irqsave(&card->lock, flags); in nj_l2l1B()
763 spin_unlock_irqrestore(&card->lock, flags); in nj_l2l1B()
769 spin_lock_irqsave(&card->lock, flags); in nj_l2l1B()
772 spin_unlock_irqrestore(&card->lock, flags); in nj_l2l1B()
794 struct tiger_hw *card = bch->hw; in nj_bctrl() local
798 pr_debug("%s: %s cmd:%x %p\n", card->name, __func__, cmd, arg); in nj_bctrl()
803 spin_lock_irqsave(&card->lock, flags); in nj_bctrl()
806 spin_unlock_irqrestore(&card->lock, flags); in nj_bctrl()
816 pr_info("%s: %s unknown prim(%x)\n", card->name, __func__, cmd); in nj_bctrl()
822 channel_ctrl(struct tiger_hw *card, struct mISDN_ctrl_req *cq) in channel_ctrl() argument
836 ret = card->isac.ctrl(&card->isac, HW_TESTLOOP, cq->channel); in channel_ctrl()
839 ret = card->isac.ctrl(&card->isac, HW_TIMER3_VALUE, cq->p1); in channel_ctrl()
842 pr_info("%s: %s unknown Op %x\n", card->name, __func__, cq->op); in channel_ctrl()
850 open_bchannel(struct tiger_hw *card, struct channel_req *rq) in open_bchannel() argument
858 bch = &card->bc[rq->adr.channel - 1].bch; in open_bchannel()
875 struct tiger_hw *card = dch->hw; in nj_dctrl() local
879 pr_debug("%s: %s cmd:%x %p\n", card->name, __func__, cmd, arg); in nj_dctrl()
884 err = card->isac.open(&card->isac, rq); in nj_dctrl()
886 err = open_bchannel(card, rq); in nj_dctrl()
890 pr_info("%s: cannot get module\n", card->name); in nj_dctrl()
893 pr_debug("%s: dev(%d) close from %p\n", card->name, dch->dev.id, in nj_dctrl()
898 err = channel_ctrl(card, arg); in nj_dctrl()
902 card->name, __func__, cmd); in nj_dctrl()
909 nj_init_card(struct tiger_hw *card) in nj_init_card() argument
914 spin_lock_irqsave(&card->lock, flags); in nj_init_card()
915 nj_disable_hwirq(card); in nj_init_card()
916 spin_unlock_irqrestore(&card->lock, flags); in nj_init_card()
918 card->irq = card->pdev->irq; in nj_init_card()
919 if (request_irq(card->irq, nj_irq, IRQF_SHARED, card->name, card)) { in nj_init_card()
921 card->name, card->irq); in nj_init_card()
922 card->irq = -1; in nj_init_card()
926 spin_lock_irqsave(&card->lock, flags); in nj_init_card()
927 nj_reset(card); in nj_init_card()
928 ret = card->isac.init(&card->isac); in nj_init_card()
931 ret = inittiger(card); in nj_init_card()
934 mode_tiger(&card->bc[0], ISDN_P_NONE); in nj_init_card()
935 mode_tiger(&card->bc[1], ISDN_P_NONE); in nj_init_card()
937 spin_unlock_irqrestore(&card->lock, flags); in nj_init_card()
943 nj_release(struct tiger_hw *card) in nj_release() argument
948 if (card->base_s) { in nj_release()
949 spin_lock_irqsave(&card->lock, flags); in nj_release()
950 nj_disable_hwirq(card); in nj_release()
951 mode_tiger(&card->bc[0], ISDN_P_NONE); in nj_release()
952 mode_tiger(&card->bc[1], ISDN_P_NONE); in nj_release()
953 spin_unlock_irqrestore(&card->lock, flags); in nj_release()
954 card->isac.release(&card->isac); in nj_release()
955 release_region(card->base, card->base_s); in nj_release()
956 card->base_s = 0; in nj_release()
958 if (card->irq > 0) in nj_release()
959 free_irq(card->irq, card); in nj_release()
960 if (device_is_registered(&card->isac.dch.dev.dev)) in nj_release()
961 mISDN_unregister_device(&card->isac.dch.dev); in nj_release()
964 mISDN_freebchannel(&card->bc[i].bch); in nj_release()
965 kfree(card->bc[i].hsbuf); in nj_release()
966 kfree(card->bc[i].hrbuf); in nj_release()
968 if (card->dma_p) in nj_release()
969 dma_free_coherent(&card->pdev->dev, NJ_DMA_SIZE, card->dma_p, in nj_release()
970 card->dma); in nj_release()
972 list_del(&card->list); in nj_release()
974 pci_disable_device(card->pdev); in nj_release()
975 pci_set_drvdata(card->pdev, NULL); in nj_release()
976 kfree(card); in nj_release()
981 nj_setup(struct tiger_hw *card) in nj_setup() argument
983 card->base = pci_resource_start(card->pdev, 0); in nj_setup()
984 card->base_s = pci_resource_len(card->pdev, 0); in nj_setup()
985 if (!request_region(card->base, card->base_s, card->name)) { in nj_setup()
987 card->name, card->base, in nj_setup()
988 (u32)(card->base + card->base_s - 1)); in nj_setup()
989 card->base_s = 0; in nj_setup()
992 ASSIGN_FUNC(nj, ISAC, card->isac); in nj_setup()
998 setup_instance(struct tiger_hw *card) in setup_instance() argument
1003 snprintf(card->name, MISDN_MAX_IDLEN - 1, "netjet.%d", nj_cnt + 1); in setup_instance()
1005 list_add_tail(&card->list, &Cards); in setup_instance()
1008 _set_debug(card); in setup_instance()
1009 card->isac.name = card->name; in setup_instance()
1010 spin_lock_init(&card->lock); in setup_instance()
1011 card->isac.hwlock = &card->lock; in setup_instance()
1012 mISDNisac_init(&card->isac, card); in setup_instance()
1014 card->isac.dch.dev.Bprotocols = (1 << (ISDN_P_B_RAW & ISDN_P_B_MASK)) | in setup_instance()
1016 card->isac.dch.dev.D.ctrl = nj_dctrl; in setup_instance()
1018 card->bc[i].bch.nr = i + 1; in setup_instance()
1019 set_channelmap(i + 1, card->isac.dch.dev.channelmap); in setup_instance()
1020 mISDN_initbchannel(&card->bc[i].bch, MAX_DATA_MEM, in setup_instance()
1022 card->bc[i].bch.hw = card; in setup_instance()
1023 card->bc[i].bch.ch.send = nj_l2l1B; in setup_instance()
1024 card->bc[i].bch.ch.ctrl = nj_bctrl; in setup_instance()
1025 card->bc[i].bch.ch.nr = i + 1; in setup_instance()
1026 list_add(&card->bc[i].bch.ch.list, in setup_instance()
1027 &card->isac.dch.dev.bchannels); in setup_instance()
1028 card->bc[i].bch.hw = card; in setup_instance()
1030 err = nj_setup(card); in setup_instance()
1033 err = mISDN_register_device(&card->isac.dch.dev, &card->pdev->dev, in setup_instance()
1034 card->name); in setup_instance()
1037 err = nj_init_card(card); in setup_instance()
1044 nj_release(card); in setup_instance()
1053 struct tiger_hw *card; in nj_probe() local
1073 card = kzalloc(sizeof(struct tiger_hw), GFP_KERNEL); in nj_probe()
1074 if (!card) { in nj_probe()
1079 card->pdev = pdev; in nj_probe()
1083 kfree(card); in nj_probe()
1098 card->typ = NETJET_S_TJ320; in nj_probe()
1100 card->typ = NETJET_S_TJ300; in nj_probe()
1102 card->base = pci_resource_start(pdev, 0); in nj_probe()
1103 pci_set_drvdata(pdev, card); in nj_probe()
1104 err = setup_instance(card); in nj_probe()
1114 struct tiger_hw *card = pci_get_drvdata(pdev); in nj_remove() local
1116 if (card) in nj_remove()
1117 nj_release(card); in nj_remove()