Lines Matching refs:dino_dev
303 struct dino_device *dino_dev = irq_data_get_irq_chip_data(d); in dino_mask_irq() local
304 int local_irq = gsc_find_local_irq(d->irq, dino_dev->global_irq, DINO_LOCAL_IRQS); in dino_mask_irq()
306 DBG(KERN_WARNING "%s(0x%px, %d)\n", __func__, dino_dev, d->irq); in dino_mask_irq()
309 dino_dev->imr &= ~(DINO_MASK_IRQ(local_irq)); in dino_mask_irq()
310 __raw_writel(dino_dev->imr, dino_dev->hba.base_addr+DINO_IMR); in dino_mask_irq()
315 struct dino_device *dino_dev = irq_data_get_irq_chip_data(d); in dino_unmask_irq() local
316 int local_irq = gsc_find_local_irq(d->irq, dino_dev->global_irq, DINO_LOCAL_IRQS); in dino_unmask_irq()
319 DBG(KERN_WARNING "%s(0x%px, %d)\n", __func__, dino_dev, d->irq); in dino_unmask_irq()
327 __raw_readl(dino_dev->hba.base_addr+DINO_IPR); in dino_unmask_irq()
330 dino_dev->imr |= DINO_MASK_IRQ(local_irq); /* used in dino_isr() */ in dino_unmask_irq()
331 __raw_writel( dino_dev->imr, dino_dev->hba.base_addr+DINO_IMR); in dino_unmask_irq()
342 tmp = __raw_readl(dino_dev->hba.base_addr+DINO_ILR); in dino_unmask_irq()
346 gsc_writel(dino_dev->txn_data, dino_dev->txn_addr); in dino_unmask_irq()
365 struct dino_device *dino_dev = intr_dev; in dino_isr() local
371 dino_dev->dino_irr0 = in dino_isr()
373 mask = __raw_readl(dino_dev->hba.base_addr+DINO_IRR0) & DINO_IRR_MASK; in dino_isr()
381 int irq = dino_dev->global_irq[local_irq]; in dino_isr()
395 mask = __raw_readl(dino_dev->hba.base_addr+DINO_ILR) & dino_dev->imr; in dino_isr()
400 dino_dev->hba.base_addr, mask); in dino_isr()
464 struct dino_device *dino_dev = DINO_DEV(parisc_walk_tree(bus->bridge)); in dino_card_setup() local
469 res = &dino_dev->hba.lmmio_space; in dino_card_setup()
477 res->name = dino_dev->hba.lmmio_space.name; in dino_card_setup()
480 if (ccio_allocate_resource(dino_dev->hba.dev, res, _8MB, in dino_card_setup()
495 bus->resource[0] = &(dino_dev->hba.io_space); in dino_card_setup()
554 struct dino_device *dino_dev = DINO_DEV(parisc_walk_tree(bus->bridge)); in dino_fixup_bus() local
561 if (is_card_dino(&dino_dev->hba.dev->id)) { in dino_fixup_bus()
562 dino_card_setup(bus, dino_dev->hba.base_addr); in dino_fixup_bus()
598 if (is_card_dino(&dino_dev->hba.dev->id)) in dino_fixup_bus()
635 dino_assign_irq(dino_dev, irq_pin, &dev->irq); in dino_fixup_bus()
642 dino_assign_irq(dino_dev, dev->irq, &dev->irq); in dino_fixup_bus()
658 dino_card_init(struct dino_device *dino_dev) in dino_card_init() argument
663 status = __raw_readl(dino_dev->hba.base_addr+DINO_IO_STATUS); in dino_card_init()
666 dino_dev->hba.base_addr+DINO_IO_COMMAND); in dino_card_init()
670 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_GMASK); in dino_card_init()
671 __raw_writel(0x00000001, dino_dev->hba.base_addr+DINO_IO_FBB_EN); in dino_card_init()
672 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_ICR); in dino_card_init()
682 __raw_writel( brdg_feat, dino_dev->hba.base_addr+DINO_BRDG_FEAT); in dino_card_init()
689 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_IO_ADDR_EN); in dino_card_init()
691 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_DAMODE); in dino_card_init()
692 __raw_writel(0x00222222, dino_dev->hba.base_addr+DINO_PCIROR); in dino_card_init()
693 __raw_writel(0x00222222, dino_dev->hba.base_addr+DINO_PCIWOR); in dino_card_init()
695 __raw_writel(0x00000040, dino_dev->hba.base_addr+DINO_MLTIM); in dino_card_init()
696 __raw_writel(0x00000080, dino_dev->hba.base_addr+DINO_IO_CONTROL); in dino_card_init()
697 __raw_writel(0x0000008c, dino_dev->hba.base_addr+DINO_TLTIM); in dino_card_init()
700 __raw_writel(0x0000007e, dino_dev->hba.base_addr+DINO_PAMR); in dino_card_init()
701 __raw_writel(0x0000007f, dino_dev->hba.base_addr+DINO_PAPR); in dino_card_init()
702 __raw_writel(0x00000000, dino_dev->hba.base_addr+DINO_PAMR); in dino_card_init()
709 __raw_writel(0x0000004f, dino_dev->hba.base_addr+DINO_PCICMD); in dino_card_init()
720 dino_bridge_init(struct dino_device *dino_dev, const char *name) in dino_bridge_init() argument
730 io_addr = __raw_readl(dino_dev->hba.base_addr + DINO_IO_ADDR_EN); in dino_bridge_init()
736 res = &dino_dev->hba.lmmio_space; in dino_bridge_init()
769 res = &dino_dev->hba.lmmio_space; in dino_bridge_init()
775 result = ccio_request_resource(dino_dev->hba.dev, &res[i]); in dino_bridge_init()
786 struct dino_device *dino_dev, const char *name) in dino_common_init() argument
793 pcibios_register_hba(&dino_dev->hba); in dino_common_init()
806 dino_dev->txn_addr = gsc_irq.txn_addr; in dino_common_init()
807 dino_dev->txn_data = gsc_irq.txn_data; in dino_common_init()
819 status = request_irq(dev->irq, dino_isr, 0, name, dino_dev); in dino_common_init()
830 gsc_fixup_irqs(dev, dino_dev, dino_choose_irq); in dino_common_init()
837 __raw_writel(eim, dino_dev->hba.base_addr+DINO_IAR0); in dino_common_init()
843 __raw_readl(dino_dev->hba.base_addr+DINO_IRR0); in dino_common_init()
846 res = &dino_dev->hba.io_space; in dino_common_init()
852 res->start = HBA_PORT_BASE(dino_dev->hba.hba_num); in dino_common_init()
859 dino_dev->hba.base_addr); in dino_common_init()
892 struct dino_device *dino_dev; // Dino specific control struct in dino_probe() local
951 dino_dev = kzalloc(sizeof(struct dino_device), GFP_KERNEL); in dino_probe()
952 if (!dino_dev) { in dino_probe()
957 dino_dev->hba.dev = dev; in dino_probe()
958 dino_dev->hba.base_addr = ioremap_nocache(hpa, 4096); in dino_probe()
959 dino_dev->hba.lmmio_space_offset = PCI_F_EXTEND; in dino_probe()
960 spin_lock_init(&dino_dev->dinosaur_pen); in dino_probe()
961 dino_dev->hba.iommu = ccio_get_iommu(dev); in dino_probe()
964 dino_card_init(dino_dev); in dino_probe()
966 dino_bridge_init(dino_dev, name); in dino_probe()
969 if (dino_common_init(dev, dino_dev, name)) in dino_probe()
972 dev->dev.platform_data = dino_dev; in dino_probe()
974 pci_add_resource_offset(&resources, &dino_dev->hba.io_space, in dino_probe()
975 HBA_PORT_BASE(dino_dev->hba.hba_num)); in dino_probe()
976 if (dino_dev->hba.lmmio_space.flags) in dino_probe()
977 pci_add_resource_offset(&resources, &dino_dev->hba.lmmio_space, in dino_probe()
978 dino_dev->hba.lmmio_space_offset); in dino_probe()
979 if (dino_dev->hba.elmmio_space.flags) in dino_probe()
980 pci_add_resource_offset(&resources, &dino_dev->hba.elmmio_space, in dino_probe()
981 dino_dev->hba.lmmio_space_offset); in dino_probe()
982 if (dino_dev->hba.gmmio_space.flags) in dino_probe()
983 pci_add_resource(&resources, &dino_dev->hba.gmmio_space); in dino_probe()
985 dino_dev->hba.bus_num.start = dino_current_bus; in dino_probe()
986 dino_dev->hba.bus_num.end = 255; in dino_probe()
987 dino_dev->hba.bus_num.flags = IORESOURCE_BUS; in dino_probe()
988 pci_add_resource(&resources, &dino_dev->hba.bus_num); in dino_probe()
993 dino_dev->hba.hba_bus = bus = pci_create_root_bus(&dev->dev, in dino_probe()