Lines Matching refs:dino_dev

162 	struct dino_device *dino_dev;  in pci_dev_is_behind_card_dino()  local
164 dino_dev = DINO_DEV(parisc_walk_tree(dev->bus->bridge)); in pci_dev_is_behind_card_dino()
165 return is_card_dino(&dino_dev->hba.dev->id); in pci_dev_is_behind_card_dino()
308 struct dino_device *dino_dev = irq_data_get_irq_chip_data(d); in dino_mask_irq() local
309 int local_irq = gsc_find_local_irq(d->irq, dino_dev->global_irq, DINO_LOCAL_IRQS); in dino_mask_irq()
311 DBG(KERN_WARNING "%s(0x%px, %d)\n", __func__, dino_dev, d->irq); in dino_mask_irq()
314 dino_dev->imr &= ~(DINO_MASK_IRQ(local_irq)); in dino_mask_irq()
315 __raw_writel(dino_dev->imr, dino_dev->hba.base_addr+DINO_IMR); in dino_mask_irq()
320 struct dino_device *dino_dev = irq_data_get_irq_chip_data(d); in dino_unmask_irq() local
321 int local_irq = gsc_find_local_irq(d->irq, dino_dev->global_irq, DINO_LOCAL_IRQS); in dino_unmask_irq()
324 DBG(KERN_WARNING "%s(0x%px, %d)\n", __func__, dino_dev, d->irq); in dino_unmask_irq()
332 __raw_readl(dino_dev->hba.base_addr+DINO_IPR); in dino_unmask_irq()
335 dino_dev->imr |= DINO_MASK_IRQ(local_irq); /* used in dino_isr() */ in dino_unmask_irq()
336 __raw_writel( dino_dev->imr, dino_dev->hba.base_addr+DINO_IMR); in dino_unmask_irq()
347 tmp = __raw_readl(dino_dev->hba.base_addr+DINO_ILR); in dino_unmask_irq()
351 gsc_writel(dino_dev->txn_data, dino_dev->txn_addr); in dino_unmask_irq()
370 struct dino_device *dino_dev = intr_dev; in dino_isr() local
376 dino_dev->dino_irr0 = in dino_isr()
378 mask = __raw_readl(dino_dev->hba.base_addr+DINO_IRR0) & DINO_IRR_MASK; in dino_isr()
386 int irq = dino_dev->global_irq[local_irq]; in dino_isr()
400 mask = __raw_readl(dino_dev->hba.base_addr+DINO_ILR) & dino_dev->imr; in dino_isr()
405 dino_dev->hba.base_addr, mask); in dino_isr()
483 struct dino_device *dino_dev = DINO_DEV(parisc_walk_tree(bus->bridge)); in dino_card_setup() local
488 res = &dino_dev->hba.lmmio_space; in dino_card_setup()
496 res->name = dino_dev->hba.lmmio_space.name; in dino_card_setup()
499 if (ccio_allocate_resource(dino_dev->hba.dev, res, _8MB, in dino_card_setup()
514 bus->resource[0] = &(dino_dev->hba.io_space); in dino_card_setup()
573 struct dino_device *dino_dev = DINO_DEV(parisc_walk_tree(bus->bridge)); in dino_fixup_bus() local
580 if (is_card_dino(&dino_dev->hba.dev->id)) { in dino_fixup_bus()
581 dino_card_setup(bus, dino_dev->hba.base_addr); in dino_fixup_bus()
617 if (is_card_dino(&dino_dev->hba.dev->id)) in dino_fixup_bus()
654 dino_assign_irq(dino_dev, irq_pin, &dev->irq); in dino_fixup_bus()
661 dino_assign_irq(dino_dev, dev->irq, &dev->irq); in dino_fixup_bus()
677 dino_card_init(struct dino_device *dino_dev) in dino_card_init() argument
682 status = __raw_readl(dino_dev->hba.base_addr+DINO_IO_STATUS); in dino_card_init()
685 dino_dev->hba.base_addr+DINO_IO_COMMAND); in dino_card_init()
689 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_GMASK); in dino_card_init()
690 __raw_writel(0x00000001, dino_dev->hba.base_addr+DINO_IO_FBB_EN); in dino_card_init()
691 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_ICR); in dino_card_init()
701 __raw_writel( brdg_feat, dino_dev->hba.base_addr+DINO_BRDG_FEAT); in dino_card_init()
708 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_IO_ADDR_EN); in dino_card_init()
710 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_DAMODE); in dino_card_init()
711 __raw_writel(0x00222222, dino_dev->hba.base_addr+DINO_PCIROR); in dino_card_init()
712 __raw_writel(0x00222222, dino_dev->hba.base_addr+DINO_PCIWOR); in dino_card_init()
714 __raw_writel(0x00000040, dino_dev->hba.base_addr+DINO_MLTIM); in dino_card_init()
715 __raw_writel(0x00000080, dino_dev->hba.base_addr+DINO_IO_CONTROL); in dino_card_init()
716 __raw_writel(0x0000008c, dino_dev->hba.base_addr+DINO_TLTIM); in dino_card_init()
719 __raw_writel(0x0000007e, dino_dev->hba.base_addr+DINO_PAMR); in dino_card_init()
720 __raw_writel(0x0000007f, dino_dev->hba.base_addr+DINO_PAPR); in dino_card_init()
721 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_PAMR); in dino_card_init()
728 __raw_writel(0x0000004f, dino_dev->hba.base_addr+DINO_PCICMD); in dino_card_init()
739 dino_bridge_init(struct dino_device *dino_dev, const char *name) in dino_bridge_init() argument
749 io_addr = __raw_readl(dino_dev->hba.base_addr + DINO_IO_ADDR_EN); in dino_bridge_init()
755 res = &dino_dev->hba.lmmio_space; in dino_bridge_init()
788 res = &dino_dev->hba.lmmio_space; in dino_bridge_init()
794 result = ccio_request_resource(dino_dev->hba.dev, &res[i]); in dino_bridge_init()
805 struct dino_device *dino_dev, const char *name) in dino_common_init() argument
812 pcibios_register_hba(&dino_dev->hba); in dino_common_init()
825 dino_dev->txn_addr = gsc_irq.txn_addr; in dino_common_init()
826 dino_dev->txn_data = gsc_irq.txn_data; in dino_common_init()
838 status = request_irq(dev->irq, dino_isr, 0, name, dino_dev); in dino_common_init()
849 gsc_fixup_irqs(dev, dino_dev, dino_choose_irq); in dino_common_init()
856 __raw_writel(eim, dino_dev->hba.base_addr+DINO_IAR0); in dino_common_init()
862 __raw_readl(dino_dev->hba.base_addr+DINO_IRR0); in dino_common_init()
865 res = &dino_dev->hba.io_space; in dino_common_init()
871 res->start = HBA_PORT_BASE(dino_dev->hba.hba_num); in dino_common_init()
878 dino_dev->hba.base_addr); in dino_common_init()
911 struct dino_device *dino_dev; // Dino specific control struct in dino_probe() local
970 dino_dev = kzalloc(sizeof(struct dino_device), GFP_KERNEL); in dino_probe()
971 if (!dino_dev) { in dino_probe()
976 dino_dev->hba.dev = dev; in dino_probe()
977 dino_dev->hba.base_addr = ioremap_nocache(hpa, 4096); in dino_probe()
978 dino_dev->hba.lmmio_space_offset = PCI_F_EXTEND; in dino_probe()
979 spin_lock_init(&dino_dev->dinosaur_pen); in dino_probe()
980 dino_dev->hba.iommu = ccio_get_iommu(dev); in dino_probe()
983 dino_card_init(dino_dev); in dino_probe()
985 dino_bridge_init(dino_dev, name); in dino_probe()
988 if (dino_common_init(dev, dino_dev, name)) in dino_probe()
991 dev->dev.platform_data = dino_dev; in dino_probe()
993 pci_add_resource_offset(&resources, &dino_dev->hba.io_space, in dino_probe()
994 HBA_PORT_BASE(dino_dev->hba.hba_num)); in dino_probe()
995 if (dino_dev->hba.lmmio_space.flags) in dino_probe()
996 pci_add_resource_offset(&resources, &dino_dev->hba.lmmio_space, in dino_probe()
997 dino_dev->hba.lmmio_space_offset); in dino_probe()
998 if (dino_dev->hba.elmmio_space.flags) in dino_probe()
999 pci_add_resource_offset(&resources, &dino_dev->hba.elmmio_space, in dino_probe()
1000 dino_dev->hba.lmmio_space_offset); in dino_probe()
1001 if (dino_dev->hba.gmmio_space.flags) in dino_probe()
1002 pci_add_resource(&resources, &dino_dev->hba.gmmio_space); in dino_probe()
1004 dino_dev->hba.bus_num.start = dino_current_bus; in dino_probe()
1005 dino_dev->hba.bus_num.end = 255; in dino_probe()
1006 dino_dev->hba.bus_num.flags = IORESOURCE_BUS; in dino_probe()
1007 pci_add_resource(&resources, &dino_dev->hba.bus_num); in dino_probe()
1012 dino_dev->hba.hba_bus = bus = pci_create_root_bus(&dev->dev, in dino_probe()