Lines Matching refs:fore200e
178 fore200e_chunk_alloc(struct fore200e* fore200e, struct chunk* chunk, int size, int alignment, int d… in fore200e_chunk_alloc() argument
198 …chunk->dma_addr = fore200e->bus->dma_map(fore200e, chunk->align_addr, chunk->align_size, direction… in fore200e_chunk_alloc()
207 fore200e_chunk_free(struct fore200e* fore200e, struct chunk* chunk) in fore200e_chunk_free() argument
209 fore200e->bus->dma_unmap(fore200e, chunk->dma_addr, chunk->dma_size, chunk->direction); in fore200e_chunk_free()
224 fore200e_poll(struct fore200e* fore200e, volatile u32* addr, u32 val, int msecs) in fore200e_poll() argument
248 fore200e_io_poll(struct fore200e* fore200e, volatile u32 __iomem *addr, u32 val, int msecs) in fore200e_io_poll() argument
254 if ((ok = (fore200e->bus->read(addr) == val))) in fore200e_io_poll()
262 fore200e->bus->read(addr), val); in fore200e_io_poll()
271 fore200e_free_rx_buf(struct fore200e* fore200e) in fore200e_free_rx_buf() argument
279 if ((buffer = fore200e->host_bsq[ scheme ][ magn ].buffer) != NULL) { in fore200e_free_rx_buf()
286 fore200e_chunk_free(fore200e, data); in fore200e_free_rx_buf()
295 fore200e_uninit_bs_queue(struct fore200e* fore200e) in fore200e_uninit_bs_queue() argument
302 struct chunk* status = &fore200e->host_bsq[ scheme ][ magn ].status; in fore200e_uninit_bs_queue()
303 struct chunk* rbd_block = &fore200e->host_bsq[ scheme ][ magn ].rbd_block; in fore200e_uninit_bs_queue()
306 fore200e->bus->dma_chunk_free(fore200e, status); in fore200e_uninit_bs_queue()
309 fore200e->bus->dma_chunk_free(fore200e, rbd_block); in fore200e_uninit_bs_queue()
316 fore200e_reset(struct fore200e* fore200e, int diag) in fore200e_reset() argument
320 fore200e->cp_monitor = fore200e->virt_base + FORE200E_CP_MONITOR_OFFSET; in fore200e_reset()
322 fore200e->bus->write(BSTAT_COLD_START, &fore200e->cp_monitor->bstat); in fore200e_reset()
324 fore200e->bus->reset(fore200e); in fore200e_reset()
327 ok = fore200e_io_poll(fore200e, &fore200e->cp_monitor->bstat, BSTAT_SELFTEST_OK, 1000); in fore200e_reset()
330 printk(FORE200E "device %s self-test failed\n", fore200e->name); in fore200e_reset()
334 printk(FORE200E "device %s self-test passed\n", fore200e->name); in fore200e_reset()
336 fore200e->state = FORE200E_STATE_RESET; in fore200e_reset()
344 fore200e_shutdown(struct fore200e* fore200e) in fore200e_shutdown() argument
347 fore200e->name, fore200e->phys_base, in fore200e_shutdown()
348 fore200e_irq_itoa(fore200e->irq)); in fore200e_shutdown()
350 if (fore200e->state > FORE200E_STATE_RESET) { in fore200e_shutdown()
352 fore200e_reset(fore200e, 0); in fore200e_shutdown()
356 switch(fore200e->state) { in fore200e_shutdown()
359 kfree(fore200e->stats); in fore200e_shutdown()
363 free_irq(fore200e->irq, fore200e->atm_dev); in fore200e_shutdown()
367 fore200e_free_rx_buf(fore200e); in fore200e_shutdown()
371 fore200e_uninit_bs_queue(fore200e); in fore200e_shutdown()
375 fore200e->bus->dma_chunk_free(fore200e, &fore200e->host_rxq.status); in fore200e_shutdown()
376 fore200e->bus->dma_chunk_free(fore200e, &fore200e->host_rxq.rpd); in fore200e_shutdown()
380 fore200e->bus->dma_chunk_free(fore200e, &fore200e->host_txq.status); in fore200e_shutdown()
381 fore200e->bus->dma_chunk_free(fore200e, &fore200e->host_txq.tpd); in fore200e_shutdown()
385 fore200e->bus->dma_chunk_free(fore200e, &fore200e->host_cmdq.status); in fore200e_shutdown()
398 fore200e->bus->unmap(fore200e); in fore200e_shutdown()
406 atm_dev_deregister(fore200e->atm_dev); in fore200e_shutdown()
434 fore200e_pca_dma_map(struct fore200e* fore200e, void* virt_addr, int size, int direction) in fore200e_pca_dma_map() argument
436 …u32 dma_addr = dma_map_single(&((struct pci_dev *) fore200e->bus_dev)->dev, virt_addr, size, direc… in fore200e_pca_dma_map()
446 fore200e_pca_dma_unmap(struct fore200e* fore200e, u32 dma_addr, int size, int direction) in fore200e_pca_dma_unmap() argument
451 dma_unmap_single(&((struct pci_dev *) fore200e->bus_dev)->dev, dma_addr, size, direction); in fore200e_pca_dma_unmap()
456 fore200e_pca_dma_sync_for_cpu(struct fore200e* fore200e, u32 dma_addr, int size, int direction) in fore200e_pca_dma_sync_for_cpu() argument
460 … dma_sync_single_for_cpu(&((struct pci_dev *) fore200e->bus_dev)->dev, dma_addr, size, direction); in fore200e_pca_dma_sync_for_cpu()
464 fore200e_pca_dma_sync_for_device(struct fore200e* fore200e, u32 dma_addr, int size, int direction) in fore200e_pca_dma_sync_for_device() argument
468 …dma_sync_single_for_device(&((struct pci_dev *) fore200e->bus_dev)->dev, dma_addr, size, direction… in fore200e_pca_dma_sync_for_device()
476 fore200e_pca_dma_chunk_alloc(struct fore200e* fore200e, struct chunk* chunk, in fore200e_pca_dma_chunk_alloc() argument
481 chunk->alloc_addr = dma_alloc_coherent(&((struct pci_dev *) fore200e->bus_dev)->dev, in fore200e_pca_dma_chunk_alloc()
498 fore200e_pca_dma_chunk_free(struct fore200e* fore200e, struct chunk* chunk) in fore200e_pca_dma_chunk_free() argument
500 dma_free_coherent(&((struct pci_dev *) fore200e->bus_dev)->dev, in fore200e_pca_dma_chunk_free()
508 fore200e_pca_irq_check(struct fore200e* fore200e) in fore200e_pca_irq_check() argument
511 int irq_posted = readl(fore200e->regs.pca.psr); in fore200e_pca_irq_check()
514 if (irq_posted && (readl(fore200e->regs.pca.hcr) & PCA200E_HCR_OUTFULL)) { in fore200e_pca_irq_check()
515 DPRINTK(2,"FIFO OUT full, device %d\n", fore200e->atm_dev->number); in fore200e_pca_irq_check()
524 fore200e_pca_irq_ack(struct fore200e* fore200e) in fore200e_pca_irq_ack() argument
526 writel(PCA200E_HCR_CLRINTR, fore200e->regs.pca.hcr); in fore200e_pca_irq_ack()
531 fore200e_pca_reset(struct fore200e* fore200e) in fore200e_pca_reset() argument
533 writel(PCA200E_HCR_RESET, fore200e->regs.pca.hcr); in fore200e_pca_reset()
535 writel(0, fore200e->regs.pca.hcr); in fore200e_pca_reset()
539 static int fore200e_pca_map(struct fore200e* fore200e) in fore200e_pca_map() argument
541 DPRINTK(2, "device %s being mapped in memory\n", fore200e->name); in fore200e_pca_map()
543 fore200e->virt_base = ioremap(fore200e->phys_base, PCA200E_IOSPACE_LENGTH); in fore200e_pca_map()
545 if (fore200e->virt_base == NULL) { in fore200e_pca_map()
546 printk(FORE200E "can't map device %s\n", fore200e->name); in fore200e_pca_map()
550 DPRINTK(1, "device %s mapped to 0x%p\n", fore200e->name, fore200e->virt_base); in fore200e_pca_map()
553 fore200e->regs.pca.hcr = fore200e->virt_base + PCA200E_HCR_OFFSET; in fore200e_pca_map()
554 fore200e->regs.pca.imr = fore200e->virt_base + PCA200E_IMR_OFFSET; in fore200e_pca_map()
555 fore200e->regs.pca.psr = fore200e->virt_base + PCA200E_PSR_OFFSET; in fore200e_pca_map()
557 fore200e->state = FORE200E_STATE_MAP; in fore200e_pca_map()
563 fore200e_pca_unmap(struct fore200e* fore200e) in fore200e_pca_unmap() argument
565 DPRINTK(2, "device %s being unmapped from memory\n", fore200e->name); in fore200e_pca_unmap()
567 if (fore200e->virt_base != NULL) in fore200e_pca_unmap()
568 iounmap(fore200e->virt_base); in fore200e_pca_unmap()
572 static int fore200e_pca_configure(struct fore200e *fore200e) in fore200e_pca_configure() argument
574 struct pci_dev* pci_dev = (struct pci_dev*)fore200e->bus_dev; in fore200e_pca_configure()
577 DPRINTK(2, "device %s being configured\n", fore200e->name); in fore200e_pca_configure()
607 fore200e->state = FORE200E_STATE_CONFIGURE; in fore200e_pca_configure()
613 fore200e_pca_prom_read(struct fore200e* fore200e, struct prom_data* prom) in fore200e_pca_prom_read() argument
615 struct host_cmdq* cmdq = &fore200e->host_cmdq; in fore200e_pca_prom_read()
626 prom_dma = fore200e->bus->dma_map(fore200e, prom, sizeof(struct prom_data), DMA_FROM_DEVICE); in fore200e_pca_prom_read()
628 fore200e->bus->write(prom_dma, &entry->cp_entry->cmd.prom_block.prom_haddr); in fore200e_pca_prom_read()
632 fore200e->bus->write(*(u32*)&opcode, (u32 __iomem *)&entry->cp_entry->cmd.prom_block.opcode); in fore200e_pca_prom_read()
634 ok = fore200e_poll(fore200e, entry->status, STATUS_COMPLETE, 400); in fore200e_pca_prom_read()
638 fore200e->bus->dma_unmap(fore200e, prom_dma, sizeof(struct prom_data), DMA_FROM_DEVICE); in fore200e_pca_prom_read()
641 printk(FORE200E "unable to get PROM data from device %s\n", fore200e->name); in fore200e_pca_prom_read()
659 fore200e_pca_proc_read(struct fore200e* fore200e, char *page) in fore200e_pca_proc_read() argument
661 struct pci_dev* pci_dev = (struct pci_dev*)fore200e->bus_dev; in fore200e_pca_proc_read()
682 static u32 fore200e_sba_dma_map(struct fore200e *fore200e, void* virt_addr, int size, int direction) in fore200e_sba_dma_map() argument
684 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_dma_map()
695 static void fore200e_sba_dma_unmap(struct fore200e *fore200e, u32 dma_addr, int size, int direction) in fore200e_sba_dma_unmap() argument
697 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_dma_unmap()
705 static void fore200e_sba_dma_sync_for_cpu(struct fore200e *fore200e, u32 dma_addr, int size, int di… in fore200e_sba_dma_sync_for_cpu() argument
707 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_dma_sync_for_cpu()
714 static void fore200e_sba_dma_sync_for_device(struct fore200e *fore200e, u32 dma_addr, int size, int… in fore200e_sba_dma_sync_for_device() argument
716 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_dma_sync_for_device()
726 static int fore200e_sba_dma_chunk_alloc(struct fore200e *fore200e, struct chunk *chunk, in fore200e_sba_dma_chunk_alloc() argument
729 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_dma_chunk_alloc()
746 static void fore200e_sba_dma_chunk_free(struct fore200e *fore200e, struct chunk *chunk) in fore200e_sba_dma_chunk_free() argument
748 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_dma_chunk_free()
754 static void fore200e_sba_irq_enable(struct fore200e *fore200e) in fore200e_sba_irq_enable() argument
756 u32 hcr = fore200e->bus->read(fore200e->regs.sba.hcr) & SBA200E_HCR_STICKY; in fore200e_sba_irq_enable()
757 fore200e->bus->write(hcr | SBA200E_HCR_INTR_ENA, fore200e->regs.sba.hcr); in fore200e_sba_irq_enable()
760 static int fore200e_sba_irq_check(struct fore200e *fore200e) in fore200e_sba_irq_check() argument
762 return fore200e->bus->read(fore200e->regs.sba.hcr) & SBA200E_HCR_INTR_REQ; in fore200e_sba_irq_check()
765 static void fore200e_sba_irq_ack(struct fore200e *fore200e) in fore200e_sba_irq_ack() argument
767 u32 hcr = fore200e->bus->read(fore200e->regs.sba.hcr) & SBA200E_HCR_STICKY; in fore200e_sba_irq_ack()
768 fore200e->bus->write(hcr | SBA200E_HCR_INTR_CLR, fore200e->regs.sba.hcr); in fore200e_sba_irq_ack()
771 static void fore200e_sba_reset(struct fore200e *fore200e) in fore200e_sba_reset() argument
773 fore200e->bus->write(SBA200E_HCR_RESET, fore200e->regs.sba.hcr); in fore200e_sba_reset()
775 fore200e->bus->write(0, fore200e->regs.sba.hcr); in fore200e_sba_reset()
778 static int __init fore200e_sba_map(struct fore200e *fore200e) in fore200e_sba_map() argument
780 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_map()
784 fore200e->regs.sba.hcr = of_ioremap(&op->resource[0], 0, SBA200E_HCR_LENGTH, "SBA HCR"); in fore200e_sba_map()
785 fore200e->regs.sba.bsr = of_ioremap(&op->resource[1], 0, SBA200E_BSR_LENGTH, "SBA BSR"); in fore200e_sba_map()
786 fore200e->regs.sba.isr = of_ioremap(&op->resource[2], 0, SBA200E_ISR_LENGTH, "SBA ISR"); in fore200e_sba_map()
787 fore200e->virt_base = of_ioremap(&op->resource[3], 0, SBA200E_RAM_LENGTH, "SBA RAM"); in fore200e_sba_map()
789 if (!fore200e->virt_base) { in fore200e_sba_map()
790 printk(FORE200E "unable to map RAM of device %s\n", fore200e->name); in fore200e_sba_map()
794 DPRINTK(1, "device %s mapped to 0x%p\n", fore200e->name, fore200e->virt_base); in fore200e_sba_map()
796 fore200e->bus->write(0x02, fore200e->regs.sba.isr); /* XXX hardwired interrupt level */ in fore200e_sba_map()
804 fore200e->state = FORE200E_STATE_MAP; in fore200e_sba_map()
808 static void fore200e_sba_unmap(struct fore200e *fore200e) in fore200e_sba_unmap() argument
810 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_unmap()
812 of_iounmap(&op->resource[0], fore200e->regs.sba.hcr, SBA200E_HCR_LENGTH); in fore200e_sba_unmap()
813 of_iounmap(&op->resource[1], fore200e->regs.sba.bsr, SBA200E_BSR_LENGTH); in fore200e_sba_unmap()
814 of_iounmap(&op->resource[2], fore200e->regs.sba.isr, SBA200E_ISR_LENGTH); in fore200e_sba_unmap()
815 of_iounmap(&op->resource[3], fore200e->virt_base, SBA200E_RAM_LENGTH); in fore200e_sba_unmap()
818 static int __init fore200e_sba_configure(struct fore200e *fore200e) in fore200e_sba_configure() argument
820 fore200e->state = FORE200E_STATE_CONFIGURE; in fore200e_sba_configure()
824 static int __init fore200e_sba_prom_read(struct fore200e *fore200e, struct prom_data *prom) in fore200e_sba_prom_read() argument
826 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_prom_read()
848 static int fore200e_sba_proc_read(struct fore200e *fore200e, char *page) in fore200e_sba_proc_read() argument
850 struct platform_device *op = fore200e->bus_dev; in fore200e_sba_proc_read()
862 fore200e_tx_irq(struct fore200e* fore200e) in fore200e_tx_irq() argument
864 struct host_txq* txq = &fore200e->host_txq; in fore200e_tx_irq()
869 if (fore200e->host_txq.txing == 0) in fore200e_tx_irq()
887 fore200e->bus->dma_unmap(fore200e, entry->tpd->tsd[ 0 ].buffer, entry->tpd->tsd[ 0 ].length, in fore200e_tx_irq()
897 fore200e->atm_dev->number); in fore200e_tx_irq()
920 fore200e->atm_dev->number); in fore200e_tx_irq()
946 fore200e->host_txq.txing--; in fore200e_tx_irq()
996 fore200e_supply(struct fore200e* fore200e) in fore200e_supply() argument
1007 bsq = &fore200e->host_bsq[ scheme ][ magn ]; in fore200e_supply()
1046 fore200e->bus->write(entry->rbd_block_dma, &entry->cp_entry->rbd_block_haddr); in fore200e_supply()
1054 fore200e_push_rpd(struct fore200e* fore200e, struct atm_vcc* vcc, struct rpd* rpd) in fore200e_push_rpd() argument
1108 …fore200e->bus->dma_sync_for_cpu(fore200e, buffer->data.dma_addr, rpd->rsd[ i ].length, DMA_FROM_DE… in fore200e_push_rpd()
1113 …fore200e->bus->dma_sync_for_device(fore200e, buffer->data.dma_addr, rpd->rsd[ i ].length, DMA_FROM… in fore200e_push_rpd()
1144 fore200e_collect_rpd(struct fore200e* fore200e, struct rpd* rpd) in fore200e_collect_rpd() argument
1155 bsq = &fore200e->host_bsq[ buffer->scheme ][ buffer->magn ]; in fore200e_collect_rpd()
1177 fore200e_rx_irq(struct fore200e* fore200e) in fore200e_rx_irq() argument
1179 struct host_rxq* rxq = &fore200e->host_rxq; in fore200e_rx_irq()
1192 vc_map = FORE200E_VC_MAP(fore200e, entry->rpd->atm_header.vpi, entry->rpd->atm_header.vci); in fore200e_rx_irq()
1198 fore200e->atm_dev->number, in fore200e_rx_irq()
1207 fore200e_push_rpd(fore200e, vcc, entry->rpd); in fore200e_rx_irq()
1211 fore200e->atm_dev->number, in fore200e_rx_irq()
1219 fore200e_collect_rpd(fore200e, entry->rpd); in fore200e_rx_irq()
1222 fore200e->bus->write(entry->rpd_dma, &entry->cp_entry->rpd_haddr); in fore200e_rx_irq()
1225 fore200e_supply(fore200e); in fore200e_rx_irq()
1232 fore200e_irq(struct fore200e* fore200e) in fore200e_irq() argument
1236 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_irq()
1237 fore200e_rx_irq(fore200e); in fore200e_irq()
1238 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_irq()
1240 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_irq()
1241 fore200e_tx_irq(fore200e); in fore200e_irq()
1242 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_irq()
1250 struct fore200e* fore200e = FORE200E_DEV((struct atm_dev*)dev); in fore200e_interrupt() local
1252 if (fore200e->bus->irq_check(fore200e) == 0) { in fore200e_interrupt()
1254 DPRINTK(3, "interrupt NOT triggered by device %d\n", fore200e->atm_dev->number); in fore200e_interrupt()
1257 DPRINTK(3, "interrupt triggered by device %d\n", fore200e->atm_dev->number); in fore200e_interrupt()
1260 tasklet_schedule(&fore200e->tx_tasklet); in fore200e_interrupt()
1261 tasklet_schedule(&fore200e->rx_tasklet); in fore200e_interrupt()
1263 fore200e_irq(fore200e); in fore200e_interrupt()
1266 fore200e->bus->irq_ack(fore200e); in fore200e_interrupt()
1275 struct fore200e* fore200e = (struct fore200e*) data; in fore200e_tx_tasklet() local
1278 DPRINTK(3, "tx tasklet scheduled for device %d\n", fore200e->atm_dev->number); in fore200e_tx_tasklet()
1280 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_tx_tasklet()
1281 fore200e_tx_irq(fore200e); in fore200e_tx_tasklet()
1282 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_tx_tasklet()
1289 struct fore200e* fore200e = (struct fore200e*) data; in fore200e_rx_tasklet() local
1292 DPRINTK(3, "rx tasklet scheduled for device %d\n", fore200e->atm_dev->number); in fore200e_rx_tasklet()
1294 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_rx_tasklet()
1295 fore200e_rx_irq((struct fore200e*) data); in fore200e_rx_tasklet()
1296 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_rx_tasklet()
1315 fore200e_activate_vcin(struct fore200e* fore200e, int activate, struct atm_vcc* vcc, int mtu) in fore200e_activate_vcin() argument
1317 struct host_cmdq* cmdq = &fore200e->host_cmdq; in fore200e_activate_vcin()
1351 fore200e->bus->write(mtu, &entry->cp_entry->cmd.activate_block.mtu); in fore200e_activate_vcin()
1352 …fore200e->bus->write(*(u32*)&vpvc, (u32 __iomem *)&entry->cp_entry->cmd.activate_block.vpv… in fore200e_activate_vcin()
1353 …fore200e->bus->write(*(u32*)&activ_opcode, (u32 __iomem *)&entry->cp_entry->cmd.activate_block.opc… in fore200e_activate_vcin()
1356 …fore200e->bus->write(*(u32*)&vpvc, (u32 __iomem *)&entry->cp_entry->cmd.deactivate_block.v… in fore200e_activate_vcin()
1357 …fore200e->bus->write(*(u32*)&deactiv_opcode, (u32 __iomem *)&entry->cp_entry->cmd.deactivate_block… in fore200e_activate_vcin()
1360 ok = fore200e_poll(fore200e, entry->status, STATUS_COMPLETE, 400); in fore200e_activate_vcin()
1398 struct fore200e* fore200e = FORE200E_DEV(vcc->dev); in fore200e_open() local
1408 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_open()
1410 vc_map = FORE200E_VC_MAP(fore200e, vpi, vci); in fore200e_open()
1413 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_open()
1416 fore200e->atm_dev->number, vpi, vci); in fore200e_open()
1423 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_open()
1442 mutex_lock(&fore200e->rate_mtx); in fore200e_open()
1443 if (fore200e->available_cell_rate < vcc->qos.txtp.max_pcr) { in fore200e_open()
1444 mutex_unlock(&fore200e->rate_mtx); in fore200e_open()
1452 fore200e->available_cell_rate -= vcc->qos.txtp.max_pcr; in fore200e_open()
1453 mutex_unlock(&fore200e->rate_mtx); in fore200e_open()
1463 if (fore200e_activate_vcin(fore200e, 1, vcc, vcc->qos.rxtp.max_sdu) < 0) { in fore200e_open()
1472 fore200e->available_cell_rate += vcc->qos.txtp.max_pcr; in fore200e_open()
1495 vc_map->incarn = ++fore200e->incarn_count; in fore200e_open()
1507 struct fore200e* fore200e = FORE200E_DEV(vcc->dev); in fore200e_close() local
1520 fore200e_activate_vcin(fore200e, 0, vcc, 0); in fore200e_close()
1522 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_close()
1524 vc_map = FORE200E_VC_MAP(fore200e, vcc->vpi, vcc->vci); in fore200e_close()
1534 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_close()
1539 mutex_lock(&fore200e->rate_mtx); in fore200e_close()
1540 fore200e->available_cell_rate += vcc->qos.txtp.max_pcr; in fore200e_close()
1541 mutex_unlock(&fore200e->rate_mtx); in fore200e_close()
1557 struct fore200e* fore200e = FORE200E_DEV(vcc->dev); in fore200e_send() local
1560 struct host_txq* txq = &fore200e->host_txq; in fore200e_send()
1574 ASSERT(fore200e); in fore200e_send()
1600 DPRINTK(2, "misaligned tx PDU on device %s\n", fore200e->name); in fore200e_send()
1608 DPRINTK(2, "incomplete tx AAL0 PDU on device %s\n", fore200e->name); in fore200e_send()
1633 vc_map = FORE200E_VC_MAP(fore200e, vcc->vpi, vcc->vci); in fore200e_send()
1638 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_send()
1645 fore200e_tx_irq(fore200e); in fore200e_send()
1649 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_send()
1659 fore200e->tx_sat++; in fore200e_send()
1661 fore200e->name, fore200e->cp_queues->heartbeat); in fore200e_send()
1682 tpd->tsd[ 0 ].buffer = fore200e->bus->dma_map(fore200e, data, tx_len, DMA_TO_DEVICE); in fore200e_send()
1732 fore200e->bus->write(*(u32*)&tpd_haddr, (u32 __iomem *)&entry->cp_entry->tpd_haddr); in fore200e_send()
1734 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_send()
1741 fore200e_getstats(struct fore200e* fore200e) in fore200e_getstats() argument
1743 struct host_cmdq* cmdq = &fore200e->host_cmdq; in fore200e_getstats()
1749 if (fore200e->stats == NULL) { in fore200e_getstats()
1750 fore200e->stats = kzalloc(sizeof(struct stats), GFP_KERNEL | GFP_DMA); in fore200e_getstats()
1751 if (fore200e->stats == NULL) in fore200e_getstats()
1755 stats_dma_addr = fore200e->bus->dma_map(fore200e, fore200e->stats, in fore200e_getstats()
1763 fore200e->bus->write(stats_dma_addr, &entry->cp_entry->cmd.stats_block.stats_haddr); in fore200e_getstats()
1767 fore200e->bus->write(*(u32*)&opcode, (u32 __iomem *)&entry->cp_entry->cmd.stats_block.opcode); in fore200e_getstats()
1769 ok = fore200e_poll(fore200e, entry->status, STATUS_COMPLETE, 400); in fore200e_getstats()
1773 fore200e->bus->dma_unmap(fore200e, stats_dma_addr, sizeof(struct stats), DMA_FROM_DEVICE); in fore200e_getstats()
1776 printk(FORE200E "unable to get statistics from device %s\n", fore200e->name); in fore200e_getstats()
1810 fore200e_get_oc3(struct fore200e* fore200e, struct oc3_regs* regs)
1812 struct host_cmdq* cmdq = &fore200e->host_cmdq;
1818 …oc3_regs_dma_addr = fore200e->bus->dma_map(fore200e, regs, sizeof(struct oc3_regs), DMA_FROM_DEVIC…
1827 fore200e->bus->write(oc3_regs_dma_addr, &entry->cp_entry->cmd.oc3_block.regs_haddr);
1831 fore200e->bus->write(*(u32*)&opcode, (u32*)&entry->cp_entry->cmd.oc3_block.opcode);
1833 ok = fore200e_poll(fore200e, entry->status, STATUS_COMPLETE, 400);
1837 fore200e->bus->dma_unmap(fore200e, oc3_regs_dma_addr, sizeof(struct oc3_regs), DMA_FROM_DEVICE);
1840 printk(FORE200E "unable to get OC-3 regs of device %s\n", fore200e->name);
1850 fore200e_set_oc3(struct fore200e* fore200e, u32 reg, u32 value, u32 mask) in fore200e_set_oc3() argument
1852 struct host_cmdq* cmdq = &fore200e->host_cmdq; in fore200e_set_oc3()
1866 fore200e->bus->write(0, &entry->cp_entry->cmd.oc3_block.regs_haddr); in fore200e_set_oc3()
1870 fore200e->bus->write(*(u32*)&opcode, (u32 __iomem *)&entry->cp_entry->cmd.oc3_block.opcode); in fore200e_set_oc3()
1872 ok = fore200e_poll(fore200e, entry->status, STATUS_COMPLETE, 400); in fore200e_set_oc3()
1877 printk(FORE200E "unable to set OC-3 reg 0x%02x of device %s\n", reg, fore200e->name); in fore200e_set_oc3()
1886 fore200e_setloop(struct fore200e* fore200e, int loop_mode) in fore200e_setloop() argument
1913 error = fore200e_set_oc3(fore200e, SUNI_MCT, mct_value, mct_mask); in fore200e_setloop()
1915 fore200e->loop_mode = loop_mode; in fore200e_setloop()
1922 fore200e_fetch_stats(struct fore200e* fore200e, struct sonet_stats __user *arg) in fore200e_fetch_stats() argument
1926 if (fore200e_getstats(fore200e) < 0) in fore200e_fetch_stats()
1929 tmp.section_bip = be32_to_cpu(fore200e->stats->oc3.section_bip8_errors); in fore200e_fetch_stats()
1930 tmp.line_bip = be32_to_cpu(fore200e->stats->oc3.line_bip24_errors); in fore200e_fetch_stats()
1931 tmp.path_bip = be32_to_cpu(fore200e->stats->oc3.path_bip8_errors); in fore200e_fetch_stats()
1932 tmp.line_febe = be32_to_cpu(fore200e->stats->oc3.line_febe_errors); in fore200e_fetch_stats()
1933 tmp.path_febe = be32_to_cpu(fore200e->stats->oc3.path_febe_errors); in fore200e_fetch_stats()
1934 tmp.corr_hcs = be32_to_cpu(fore200e->stats->oc3.corr_hcs_errors); in fore200e_fetch_stats()
1935 tmp.uncorr_hcs = be32_to_cpu(fore200e->stats->oc3.ucorr_hcs_errors); in fore200e_fetch_stats()
1936 tmp.tx_cells = be32_to_cpu(fore200e->stats->aal0.cells_transmitted) + in fore200e_fetch_stats()
1937 be32_to_cpu(fore200e->stats->aal34.cells_transmitted) + in fore200e_fetch_stats()
1938 be32_to_cpu(fore200e->stats->aal5.cells_transmitted); in fore200e_fetch_stats()
1939 tmp.rx_cells = be32_to_cpu(fore200e->stats->aal0.cells_received) + in fore200e_fetch_stats()
1940 be32_to_cpu(fore200e->stats->aal34.cells_received) + in fore200e_fetch_stats()
1941 be32_to_cpu(fore200e->stats->aal5.cells_received); in fore200e_fetch_stats()
1953 struct fore200e* fore200e = FORE200E_DEV(dev); in fore200e_ioctl() local
1960 return fore200e_fetch_stats(fore200e, (struct sonet_stats __user *)arg); in fore200e_ioctl()
1966 return fore200e_setloop(fore200e, (int)(unsigned long)arg); in fore200e_ioctl()
1969 return put_user(fore200e->loop_mode, (int __user *)arg) ? -EFAULT : 0; in fore200e_ioctl()
1983 struct fore200e* fore200e = FORE200E_DEV(vcc->dev); in fore200e_change_qos() local
1999 flags, fore200e->available_cell_rate); in fore200e_change_qos()
2003 mutex_lock(&fore200e->rate_mtx); in fore200e_change_qos()
2004 if (fore200e->available_cell_rate + vcc->qos.txtp.max_pcr < qos->txtp.max_pcr) { in fore200e_change_qos()
2005 mutex_unlock(&fore200e->rate_mtx); in fore200e_change_qos()
2009 fore200e->available_cell_rate += vcc->qos.txtp.max_pcr; in fore200e_change_qos()
2010 fore200e->available_cell_rate -= qos->txtp.max_pcr; in fore200e_change_qos()
2012 mutex_unlock(&fore200e->rate_mtx); in fore200e_change_qos()
2028 static int fore200e_irq_request(struct fore200e *fore200e) in fore200e_irq_request() argument
2030 …if (request_irq(fore200e->irq, fore200e_interrupt, IRQF_SHARED, fore200e->name, fore200e->atm_dev)… in fore200e_irq_request()
2033 fore200e_irq_itoa(fore200e->irq), fore200e->name); in fore200e_irq_request()
2038 fore200e_irq_itoa(fore200e->irq), fore200e->name); in fore200e_irq_request()
2041 tasklet_init(&fore200e->tx_tasklet, fore200e_tx_tasklet, (unsigned long)fore200e); in fore200e_irq_request()
2042 tasklet_init(&fore200e->rx_tasklet, fore200e_rx_tasklet, (unsigned long)fore200e); in fore200e_irq_request()
2045 fore200e->state = FORE200E_STATE_IRQ; in fore200e_irq_request()
2050 static int fore200e_get_esi(struct fore200e *fore200e) in fore200e_get_esi() argument
2058 ok = fore200e->bus->prom_read(fore200e, prom); in fore200e_get_esi()
2065 fore200e->name, in fore200e_get_esi()
2070 fore200e->esi[ i ] = fore200e->atm_dev->esi[ i ] = prom->mac_addr[ i + 2 ]; in fore200e_get_esi()
2079 static int fore200e_alloc_rx_buf(struct fore200e *fore200e) in fore200e_alloc_rx_buf() argument
2089 bsq = &fore200e->host_bsq[ scheme ][ magn ]; in fore200e_alloc_rx_buf()
2115 if (fore200e_chunk_alloc(fore200e, in fore200e_alloc_rx_buf()
2116 &buffer[ i ].data, size, fore200e->bus->buffer_alignment, in fore200e_alloc_rx_buf()
2120 fore200e_chunk_free(fore200e, &buffer[ --i ].data); in fore200e_alloc_rx_buf()
2139 fore200e->state = FORE200E_STATE_ALLOC_BUF; in fore200e_alloc_rx_buf()
2144 static int fore200e_init_bs_queue(struct fore200e *fore200e) in fore200e_init_bs_queue() argument
2156 bsq = &fore200e->host_bsq[ scheme ][ magn ]; in fore200e_init_bs_queue()
2159 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_bs_queue()
2163 fore200e->bus->status_alignment) < 0) { in fore200e_init_bs_queue()
2168 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_bs_queue()
2172 fore200e->bus->descr_alignment) < 0) { in fore200e_init_bs_queue()
2174 fore200e->bus->dma_chunk_free(fore200e, &bsq->status); in fore200e_init_bs_queue()
2179 cp_entry = fore200e->virt_base + in fore200e_init_bs_queue()
2180 fore200e->bus->read(&fore200e->cp_queues->cp_bsq[ scheme ][ magn ]); in fore200e_init_bs_queue()
2195 fore200e->bus->write(FORE200E_DMA_INDEX(bsq->status.dma_addr, enum status, i), in fore200e_init_bs_queue()
2201 fore200e->state = FORE200E_STATE_INIT_BSQ; in fore200e_init_bs_queue()
2206 static int fore200e_init_rx_queue(struct fore200e *fore200e) in fore200e_init_rx_queue() argument
2208 struct host_rxq* rxq = &fore200e->host_rxq; in fore200e_init_rx_queue()
2215 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_rx_queue()
2219 fore200e->bus->status_alignment) < 0) { in fore200e_init_rx_queue()
2224 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_rx_queue()
2228 fore200e->bus->descr_alignment) < 0) { in fore200e_init_rx_queue()
2230 fore200e->bus->dma_chunk_free(fore200e, &rxq->status); in fore200e_init_rx_queue()
2235 cp_entry = fore200e->virt_base + fore200e->bus->read(&fore200e->cp_queues->cp_rxq); in fore200e_init_rx_queue()
2250 fore200e->bus->write(FORE200E_DMA_INDEX(rxq->status.dma_addr, enum status, i), in fore200e_init_rx_queue()
2253 fore200e->bus->write(FORE200E_DMA_INDEX(rxq->rpd.dma_addr, struct rpd, i), in fore200e_init_rx_queue()
2260 fore200e->state = FORE200E_STATE_INIT_RXQ; in fore200e_init_rx_queue()
2265 static int fore200e_init_tx_queue(struct fore200e *fore200e) in fore200e_init_tx_queue() argument
2267 struct host_txq* txq = &fore200e->host_txq; in fore200e_init_tx_queue()
2274 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_tx_queue()
2278 fore200e->bus->status_alignment) < 0) { in fore200e_init_tx_queue()
2283 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_tx_queue()
2287 fore200e->bus->descr_alignment) < 0) { in fore200e_init_tx_queue()
2289 fore200e->bus->dma_chunk_free(fore200e, &txq->status); in fore200e_init_tx_queue()
2294 cp_entry = fore200e->virt_base + fore200e->bus->read(&fore200e->cp_queues->cp_txq); in fore200e_init_tx_queue()
2309 fore200e->bus->write(FORE200E_DMA_INDEX(txq->status.dma_addr, enum status, i), in fore200e_init_tx_queue()
2322 fore200e->state = FORE200E_STATE_INIT_TXQ; in fore200e_init_tx_queue()
2327 static int fore200e_init_cmd_queue(struct fore200e *fore200e) in fore200e_init_cmd_queue() argument
2329 struct host_cmdq* cmdq = &fore200e->host_cmdq; in fore200e_init_cmd_queue()
2336 if (fore200e->bus->dma_chunk_alloc(fore200e, in fore200e_init_cmd_queue()
2340 fore200e->bus->status_alignment) < 0) { in fore200e_init_cmd_queue()
2345 cp_entry = fore200e->virt_base + fore200e->bus->read(&fore200e->cp_queues->cp_cmdq); in fore200e_init_cmd_queue()
2356 fore200e->bus->write(FORE200E_DMA_INDEX(cmdq->status.dma_addr, enum status, i), in fore200e_init_cmd_queue()
2363 fore200e->state = FORE200E_STATE_INIT_CMDQ; in fore200e_init_cmd_queue()
2368 static void fore200e_param_bs_queue(struct fore200e *fore200e, in fore200e_param_bs_queue() argument
2373 struct bs_spec __iomem * bs_spec = &fore200e->cp_queues->init.bs_spec[ scheme ][ magn ]; in fore200e_param_bs_queue()
2375 fore200e->bus->write(queue_length, &bs_spec->queue_length); in fore200e_param_bs_queue()
2376 fore200e->bus->write(fore200e_rx_buf_size[ scheme ][ magn ], &bs_spec->buffer_size); in fore200e_param_bs_queue()
2377 fore200e->bus->write(pool_size, &bs_spec->pool_size); in fore200e_param_bs_queue()
2378 fore200e->bus->write(supply_blksize, &bs_spec->supply_blksize); in fore200e_param_bs_queue()
2382 static int fore200e_initialize(struct fore200e *fore200e) in fore200e_initialize() argument
2387 DPRINTK(2, "device %s being initialized\n", fore200e->name); in fore200e_initialize()
2389 mutex_init(&fore200e->rate_mtx); in fore200e_initialize()
2390 spin_lock_init(&fore200e->q_lock); in fore200e_initialize()
2392 cpq = fore200e->cp_queues = fore200e->virt_base + FORE200E_CP_QUEUES_OFFSET; in fore200e_initialize()
2395 fore200e->bus->write(1, &cpq->imask); in fore200e_initialize()
2397 if (fore200e->bus->irq_enable) in fore200e_initialize()
2398 fore200e->bus->irq_enable(fore200e); in fore200e_initialize()
2400 fore200e->bus->write(NBR_CONNECT, &cpq->init.num_connect); in fore200e_initialize()
2402 fore200e->bus->write(QUEUE_SIZE_CMD, &cpq->init.cmd_queue_len); in fore200e_initialize()
2403 fore200e->bus->write(QUEUE_SIZE_RX, &cpq->init.rx_queue_len); in fore200e_initialize()
2404 fore200e->bus->write(QUEUE_SIZE_TX, &cpq->init.tx_queue_len); in fore200e_initialize()
2406 fore200e->bus->write(RSD_EXTENSION, &cpq->init.rsd_extension); in fore200e_initialize()
2407 fore200e->bus->write(TSD_EXTENSION, &cpq->init.tsd_extension); in fore200e_initialize()
2411 fore200e_param_bs_queue(fore200e, scheme, magn, in fore200e_initialize()
2417 fore200e->bus->write(STATUS_PENDING, &cpq->init.status); in fore200e_initialize()
2418 fore200e->bus->write(OPCODE_INITIALIZE, &cpq->init.opcode); in fore200e_initialize()
2420 ok = fore200e_io_poll(fore200e, &cpq->init.status, STATUS_COMPLETE, 3000); in fore200e_initialize()
2422 printk(FORE200E "device %s initialization failed\n", fore200e->name); in fore200e_initialize()
2426 printk(FORE200E "device %s initialized\n", fore200e->name); in fore200e_initialize()
2428 fore200e->state = FORE200E_STATE_INITIALIZE; in fore200e_initialize()
2433 static void fore200e_monitor_putc(struct fore200e *fore200e, char c) in fore200e_monitor_putc() argument
2435 struct cp_monitor __iomem * monitor = fore200e->cp_monitor; in fore200e_monitor_putc()
2440 fore200e->bus->write(((u32) c) | FORE200E_CP_MONITOR_UART_AVAIL, &monitor->soft_uart.send); in fore200e_monitor_putc()
2444 static int fore200e_monitor_getc(struct fore200e *fore200e) in fore200e_monitor_getc() argument
2446 struct cp_monitor __iomem * monitor = fore200e->cp_monitor; in fore200e_monitor_getc()
2452 c = (int) fore200e->bus->read(&monitor->soft_uart.recv); in fore200e_monitor_getc()
2456 fore200e->bus->write(FORE200E_CP_MONITOR_UART_FREE, &monitor->soft_uart.recv); in fore200e_monitor_getc()
2468 static void fore200e_monitor_puts(struct fore200e *fore200e, char *str) in fore200e_monitor_puts() argument
2473 while (fore200e_monitor_getc(fore200e) >= 0); in fore200e_monitor_puts()
2475 fore200e_monitor_putc(fore200e, *str++); in fore200e_monitor_puts()
2478 while (fore200e_monitor_getc(fore200e) >= 0); in fore200e_monitor_puts()
2487 static int fore200e_load_and_start_fw(struct fore200e *fore200e) in fore200e_load_and_start_fw() argument
2498 if (strcmp(fore200e->bus->model_name, "PCA-200E") == 0) in fore200e_load_and_start_fw()
2499 device = &((struct pci_dev *) fore200e->bus_dev)->dev; in fore200e_load_and_start_fw()
2501 else if (strcmp(fore200e->bus->model_name, "SBA-200E") == 0) in fore200e_load_and_start_fw()
2502 device = &((struct platform_device *) fore200e->bus_dev)->dev; in fore200e_load_and_start_fw()
2507 sprintf(buf, "%s%s", fore200e->bus->proc_name, FW_EXT); in fore200e_load_and_start_fw()
2509 printk(FORE200E "problem loading firmware image %s\n", fore200e->bus->model_name); in fore200e_load_and_start_fw()
2516 load_addr = fore200e->virt_base + le32_to_cpu(fw_header->load_offset); in fore200e_load_and_start_fw()
2519 fore200e->name, load_addr, fw_size); in fore200e_load_and_start_fw()
2522 printk(FORE200E "corrupted %s firmware image\n", fore200e->bus->model_name); in fore200e_load_and_start_fw()
2527 fore200e->bus->write(le32_to_cpu(*fw_data), load_addr); in fore200e_load_and_start_fw()
2529 DPRINTK(2, "device %s firmware being started\n", fore200e->name); in fore200e_load_and_start_fw()
2537 fore200e_monitor_puts(fore200e, buf); in fore200e_load_and_start_fw()
2539 if (fore200e_io_poll(fore200e, &fore200e->cp_monitor->bstat, BSTAT_CP_RUNNING, 1000) == 0) { in fore200e_load_and_start_fw()
2540 printk(FORE200E "device %s firmware didn't start\n", fore200e->name); in fore200e_load_and_start_fw()
2544 printk(FORE200E "device %s firmware started\n", fore200e->name); in fore200e_load_and_start_fw()
2546 fore200e->state = FORE200E_STATE_START_FW; in fore200e_load_and_start_fw()
2555 static int fore200e_register(struct fore200e *fore200e, struct device *parent) in fore200e_register() argument
2559 DPRINTK(2, "device %s being registered\n", fore200e->name); in fore200e_register()
2561 atm_dev = atm_dev_register(fore200e->bus->proc_name, parent, &fore200e_ops, in fore200e_register()
2564 printk(FORE200E "unable to register device %s\n", fore200e->name); in fore200e_register()
2568 atm_dev->dev_data = fore200e; in fore200e_register()
2569 fore200e->atm_dev = atm_dev; in fore200e_register()
2574 fore200e->available_cell_rate = ATM_OC3_PCR; in fore200e_register()
2576 fore200e->state = FORE200E_STATE_REGISTER; in fore200e_register()
2581 static int fore200e_init(struct fore200e *fore200e, struct device *parent) in fore200e_init() argument
2583 if (fore200e_register(fore200e, parent) < 0) in fore200e_init()
2586 if (fore200e->bus->configure(fore200e) < 0) in fore200e_init()
2589 if (fore200e->bus->map(fore200e) < 0) in fore200e_init()
2592 if (fore200e_reset(fore200e, 1) < 0) in fore200e_init()
2595 if (fore200e_load_and_start_fw(fore200e) < 0) in fore200e_init()
2598 if (fore200e_initialize(fore200e) < 0) in fore200e_init()
2601 if (fore200e_init_cmd_queue(fore200e) < 0) in fore200e_init()
2604 if (fore200e_init_tx_queue(fore200e) < 0) in fore200e_init()
2607 if (fore200e_init_rx_queue(fore200e) < 0) in fore200e_init()
2610 if (fore200e_init_bs_queue(fore200e) < 0) in fore200e_init()
2613 if (fore200e_alloc_rx_buf(fore200e) < 0) in fore200e_init()
2616 if (fore200e_get_esi(fore200e) < 0) in fore200e_init()
2619 if (fore200e_irq_request(fore200e) < 0) in fore200e_init()
2622 fore200e_supply(fore200e); in fore200e_init()
2625 fore200e->state = FORE200E_STATE_COMPLETE; in fore200e_init()
2635 struct fore200e *fore200e; in fore200e_sba_probe() local
2644 fore200e = kzalloc(sizeof(struct fore200e), GFP_KERNEL); in fore200e_sba_probe()
2645 if (!fore200e) in fore200e_sba_probe()
2648 fore200e->bus = bus; in fore200e_sba_probe()
2649 fore200e->bus_dev = op; in fore200e_sba_probe()
2650 fore200e->irq = op->archdata.irqs[0]; in fore200e_sba_probe()
2651 fore200e->phys_base = op->resource[0].start; in fore200e_sba_probe()
2653 sprintf(fore200e->name, "%s-%d", bus->model_name, index); in fore200e_sba_probe()
2655 err = fore200e_init(fore200e, &op->dev); in fore200e_sba_probe()
2657 fore200e_shutdown(fore200e); in fore200e_sba_probe()
2658 kfree(fore200e); in fore200e_sba_probe()
2663 dev_set_drvdata(&op->dev, fore200e); in fore200e_sba_probe()
2670 struct fore200e *fore200e = dev_get_drvdata(&op->dev); in fore200e_sba_remove() local
2672 fore200e_shutdown(fore200e); in fore200e_sba_remove()
2673 kfree(fore200e); in fore200e_sba_remove()
2702 struct fore200e* fore200e; in fore200e_pca_detect() local
2716 fore200e = kzalloc(sizeof(struct fore200e), GFP_KERNEL); in fore200e_pca_detect()
2717 if (fore200e == NULL) { in fore200e_pca_detect()
2722 fore200e->bus = bus; in fore200e_pca_detect()
2723 fore200e->bus_dev = pci_dev; in fore200e_pca_detect()
2724 fore200e->irq = pci_dev->irq; in fore200e_pca_detect()
2725 fore200e->phys_base = pci_resource_start(pci_dev, 0); in fore200e_pca_detect()
2727 sprintf(fore200e->name, "%s-%d", bus->model_name, index - 1); in fore200e_pca_detect()
2732 fore200e->bus->model_name, in fore200e_pca_detect()
2733 fore200e->phys_base, fore200e_irq_itoa(fore200e->irq)); in fore200e_pca_detect()
2735 sprintf(fore200e->name, "%s-%d", bus->model_name, index); in fore200e_pca_detect()
2737 err = fore200e_init(fore200e, &pci_dev->dev); in fore200e_pca_detect()
2739 fore200e_shutdown(fore200e); in fore200e_pca_detect()
2744 pci_set_drvdata(pci_dev, fore200e); in fore200e_pca_detect()
2750 kfree(fore200e); in fore200e_pca_detect()
2759 struct fore200e *fore200e; in fore200e_pca_remove_one() local
2761 fore200e = pci_get_drvdata(pci_dev); in fore200e_pca_remove_one()
2763 fore200e_shutdown(fore200e); in fore200e_pca_remove_one()
2764 kfree(fore200e); in fore200e_pca_remove_one()
2822 struct fore200e* fore200e = FORE200E_DEV(dev); in fore200e_proc_read() local
2830 if (fore200e_getstats(fore200e) < 0) in fore200e_proc_read()
2835 " internal name:\t\t%s\n", fore200e->name); in fore200e_proc_read()
2838 if (fore200e->bus->proc_read) in fore200e_proc_read()
2839 len += fore200e->bus->proc_read(fore200e, page + len); in fore200e_proc_read()
2847 fore200e_irq_itoa(fore200e->irq), in fore200e_proc_read()
2848 (void*)fore200e->phys_base, in fore200e_proc_read()
2849 fore200e->virt_base, in fore200e_proc_read()
2850 fore200e->esi, in fore200e_proc_read()
2851 fore200e->esi[4] * 256 + fore200e->esi[5]); in fore200e_proc_read()
2862 fore200e->host_bsq[ BUFFER_SCHEME_ONE ][ BUFFER_MAGN_SMALL ].freebuf_count, in fore200e_proc_read()
2863 fore200e->host_bsq[ BUFFER_SCHEME_ONE ][ BUFFER_MAGN_LARGE ].freebuf_count, in fore200e_proc_read()
2864 fore200e->host_bsq[ BUFFER_SCHEME_TWO ][ BUFFER_MAGN_SMALL ].freebuf_count, in fore200e_proc_read()
2865 fore200e->host_bsq[ BUFFER_SCHEME_TWO ][ BUFFER_MAGN_LARGE ].freebuf_count); in fore200e_proc_read()
2868 u32 hb = fore200e->bus->read(&fore200e->cp_queues->heartbeat); in fore200e_proc_read()
2899 u32 fw_release = fore200e->bus->read(&fore200e->cp_queues->fw_release); in fore200e_proc_read()
2900 u32 mon960_release = fore200e->bus->read(&fore200e->cp_queues->mon960_release); in fore200e_proc_read()
2901 u32 oc3_revision = fore200e->bus->read(&fore200e->cp_queues->oc3_revision); in fore200e_proc_read()
2902 u32 media_index = FORE200E_MEDIA_INDEX(fore200e->bus->read(&fore200e->cp_queues->media_type)); in fore200e_proc_read()
2908 switch (fore200e->loop_mode) { in fore200e_proc_read()
2932 struct cp_monitor __iomem * cp_monitor = fore200e->cp_monitor; in fore200e_proc_read()
2939 fore200e->bus->read(&cp_monitor->mon_version), in fore200e_proc_read()
2940 fore200e->bus->read(&cp_monitor->bstat)); in fore200e_proc_read()
2950 be32_to_cpu(fore200e->stats->phy.crc_header_errors), in fore200e_proc_read()
2951 be32_to_cpu(fore200e->stats->phy.framing_errors)); in fore200e_proc_read()
2963 be32_to_cpu(fore200e->stats->oc3.section_bip8_errors), in fore200e_proc_read()
2964 be32_to_cpu(fore200e->stats->oc3.path_bip8_errors), in fore200e_proc_read()
2965 be32_to_cpu(fore200e->stats->oc3.line_bip24_errors), in fore200e_proc_read()
2966 be32_to_cpu(fore200e->stats->oc3.line_febe_errors), in fore200e_proc_read()
2967 be32_to_cpu(fore200e->stats->oc3.path_febe_errors), in fore200e_proc_read()
2968 be32_to_cpu(fore200e->stats->oc3.corr_hcs_errors), in fore200e_proc_read()
2969 be32_to_cpu(fore200e->stats->oc3.ucorr_hcs_errors)); in fore200e_proc_read()
2980 be32_to_cpu(fore200e->stats->atm.cells_transmitted), in fore200e_proc_read()
2981 be32_to_cpu(fore200e->stats->atm.cells_received), in fore200e_proc_read()
2982 be32_to_cpu(fore200e->stats->atm.vpi_bad_range), in fore200e_proc_read()
2983 be32_to_cpu(fore200e->stats->atm.vpi_no_conn), in fore200e_proc_read()
2984 be32_to_cpu(fore200e->stats->atm.vci_bad_range), in fore200e_proc_read()
2985 be32_to_cpu(fore200e->stats->atm.vci_no_conn)); in fore200e_proc_read()
2993 be32_to_cpu(fore200e->stats->aal0.cells_transmitted), in fore200e_proc_read()
2994 be32_to_cpu(fore200e->stats->aal0.cells_received), in fore200e_proc_read()
2995 be32_to_cpu(fore200e->stats->aal0.cells_dropped)); in fore200e_proc_read()
3011 be32_to_cpu(fore200e->stats->aal34.cells_transmitted), in fore200e_proc_read()
3012 be32_to_cpu(fore200e->stats->aal34.cells_received), in fore200e_proc_read()
3013 be32_to_cpu(fore200e->stats->aal34.cells_dropped), in fore200e_proc_read()
3014 be32_to_cpu(fore200e->stats->aal34.cells_crc_errors), in fore200e_proc_read()
3015 be32_to_cpu(fore200e->stats->aal34.cells_protocol_errors), in fore200e_proc_read()
3016 be32_to_cpu(fore200e->stats->aal34.cspdus_transmitted), in fore200e_proc_read()
3017 be32_to_cpu(fore200e->stats->aal34.cspdus_received), in fore200e_proc_read()
3018 be32_to_cpu(fore200e->stats->aal34.cspdus_dropped), in fore200e_proc_read()
3019 be32_to_cpu(fore200e->stats->aal34.cspdus_protocol_errors)); in fore200e_proc_read()
3035 be32_to_cpu(fore200e->stats->aal5.cells_transmitted), in fore200e_proc_read()
3036 be32_to_cpu(fore200e->stats->aal5.cells_received), in fore200e_proc_read()
3037 be32_to_cpu(fore200e->stats->aal5.cells_dropped), in fore200e_proc_read()
3038 be32_to_cpu(fore200e->stats->aal5.congestion_experienced), in fore200e_proc_read()
3039 be32_to_cpu(fore200e->stats->aal5.cspdus_transmitted), in fore200e_proc_read()
3040 be32_to_cpu(fore200e->stats->aal5.cspdus_received), in fore200e_proc_read()
3041 be32_to_cpu(fore200e->stats->aal5.cspdus_dropped), in fore200e_proc_read()
3042 be32_to_cpu(fore200e->stats->aal5.cspdus_crc_errors), in fore200e_proc_read()
3043 be32_to_cpu(fore200e->stats->aal5.cspdus_protocol_errors)); in fore200e_proc_read()
3054 be32_to_cpu(fore200e->stats->aux.small_b1_failed), in fore200e_proc_read()
3055 be32_to_cpu(fore200e->stats->aux.large_b1_failed), in fore200e_proc_read()
3056 be32_to_cpu(fore200e->stats->aux.small_b2_failed), in fore200e_proc_read()
3057 be32_to_cpu(fore200e->stats->aux.large_b2_failed), in fore200e_proc_read()
3058 be32_to_cpu(fore200e->stats->aux.rpd_alloc_failed), in fore200e_proc_read()
3059 fore200e->tx_sat); in fore200e_proc_read()
3064 fore200e->stats->aux.receive_carrier ? "ON" : "OFF!"); in fore200e_proc_read()
3074 vcc = fore200e->vc_map[i].vcc; in fore200e_proc_read()
3079 spin_lock_irqsave(&fore200e->q_lock, flags); in fore200e_proc_read()
3097 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_proc_read()
3101 spin_unlock_irqrestore(&fore200e->q_lock, flags); in fore200e_proc_read()