Lines Matching +full:local +full:- +full:pid

1 // SPDX-License-Identifier: GPL-2.0
43 unsigned int pid; in io7_device_interrupt() local
52 * -----+-----+--------+--- in io7_device_interrupt()
57 * 0x0800 - 0x0ff0 - 0x0800 + (LSI id << 4) in io7_device_interrupt()
58 * 0x1000 - 0x2ff0 - 0x1000 + (MSI_DAT<8:0> << 4) in io7_device_interrupt()
60 pid = vector >> 16; in io7_device_interrupt()
61 irq = ((vector & 0xffff) - 0x800) >> 4; in io7_device_interrupt()
65 irq |= pid << MARVEL_IRQ_VEC_PE_SHIFT; /* merge the pid */ in io7_device_interrupt()
74 unsigned int pid; in io7_get_irq_ctl() local
77 pid = irq >> MARVEL_IRQ_VEC_PE_SHIFT; in io7_get_irq_ctl()
79 if (!(io7 = marvel_find_io7(pid))) { in io7_get_irq_ctl()
81 "%s for nonexistent io7 -- vec %x, pid %d\n", in io7_get_irq_ctl()
82 __func__, irq, pid); in io7_get_irq_ctl()
87 irq -= 16; /* subtract legacy bias */ in io7_get_irq_ctl()
91 "%s for invalid irq -- pid %d adjusted irq %x\n", in io7_get_irq_ctl()
92 __func__, pid, irq); in io7_get_irq_ctl()
96 ctl = &io7->csrs->PO7_LSI_CTL[irq & 0xff].csr; /* assume LSI */ in io7_get_irq_ctl()
98 ctl = &io7->csrs->PO7_MSI_CTL[((irq - 0x80) >> 5) & 0x0f].csr; in io7_get_irq_ctl()
108 unsigned int irq = d->irq; in io7_enable_irq()
118 raw_spin_lock(&io7->irq_lock); in io7_enable_irq()
122 raw_spin_unlock(&io7->irq_lock); in io7_enable_irq()
129 unsigned int irq = d->irq; in io7_disable_irq()
139 raw_spin_lock(&io7->irq_lock); in io7_disable_irq()
143 raw_spin_unlock(&io7->irq_lock); in io7_disable_irq()
180 val &= ~(0x1ffUL << 24); /* clear the target pid */ in io7_redirect_irq()
181 val |= ((unsigned long)where << 24); /* set the new target pid */ in io7_redirect_irq()
194 * LSI_CTL has target PID @ 14 in io7_redirect_one_lsi()
196 val = io7->csrs->PO7_LSI_CTL[which].csr; in io7_redirect_one_lsi()
197 val &= ~(0x1ffUL << 14); /* clear the target pid */ in io7_redirect_one_lsi()
198 val |= ((unsigned long)where << 14); /* set the new target pid */ in io7_redirect_one_lsi()
200 io7->csrs->PO7_LSI_CTL[which].csr = val; in io7_redirect_one_lsi()
202 io7->csrs->PO7_LSI_CTL[which].csr; in io7_redirect_one_lsi()
211 * MSI_CTL has target PID @ 14 in io7_redirect_one_msi()
213 val = io7->csrs->PO7_MSI_CTL[which].csr; in io7_redirect_one_msi()
214 val &= ~(0x1ffUL << 14); /* clear the target pid */ in io7_redirect_one_msi()
215 val |= ((unsigned long)where << 14); /* set the new target pid */ in io7_redirect_one_msi()
217 io7->csrs->PO7_MSI_CTL[which].csr = val; in io7_redirect_one_msi()
219 io7->csrs->PO7_MSI_CTL[which].csr; in io7_redirect_one_msi()
226 * LSI_CTL has target PID @ 14 in init_one_io7_lsi()
228 io7->csrs->PO7_LSI_CTL[which].csr = ((unsigned long)where << 14); in init_one_io7_lsi()
230 io7->csrs->PO7_LSI_CTL[which].csr; in init_one_io7_lsi()
237 * MSI_CTL has target PID @ 14 in init_one_io7_msi()
239 io7->csrs->PO7_MSI_CTL[which].csr = ((unsigned long)where << 14); in init_one_io7_msi()
241 io7->csrs->PO7_MSI_CTL[which].csr; in init_one_io7_msi()
249 long base = (io7->pe << MARVEL_IRQ_VEC_PE_SHIFT) + 16; in init_io7_irqs()
252 printk("Initializing interrupts for IO7 at PE %u - base %lx\n", in init_io7_irqs()
253 io7->pe, base); in init_io7_irqs()
258 * They really should be sent to the local CPU to avoid having to in init_io7_irqs()
261 * as each secondary starts, it can redirect it's local device in init_io7_irqs()
266 raw_spin_lock(&io7->irq_lock); in init_io7_irqs()
269 io7_redirect_irq(io7, &io7->csrs->HLT_CTL.csr, boot_cpuid); in init_io7_irqs()
270 io7_redirect_irq(io7, &io7->csrs->HPI_CTL.csr, boot_cpuid); in init_io7_irqs()
271 io7_redirect_irq(io7, &io7->csrs->CRD_CTL.csr, boot_cpuid); in init_io7_irqs()
272 io7_redirect_irq(io7, &io7->csrs->STV_CTL.csr, boot_cpuid); in init_io7_irqs()
273 io7_redirect_irq(io7, &io7->csrs->HEI_CTL.csr, boot_cpuid); in init_io7_irqs()
298 raw_spin_unlock(&io7->irq_lock); in init_io7_irqs()
322 struct pci_controller *hose = dev->sysdata; in marvel_map_irq()
323 struct io7_port *io7_port = hose->sysdata; in marvel_map_irq()
324 struct io7 *io7 = io7_port->io7; in marvel_map_irq()
334 msi_loc = dev->msi_cap; in marvel_map_irq()
350 dev->bus->number, in marvel_map_irq()
351 PCI_SLOT(dev->devfn), in marvel_map_irq()
352 PCI_FUNC(dev->devfn), in marvel_map_irq()
353 hose->index); in marvel_map_irq()
359 (irq + 16) | (io7->pe << MARVEL_IRQ_VEC_PE_SHIFT), in marvel_map_irq()
360 (irq + 16) | (io7->pe << MARVEL_IRQ_VEC_PE_SHIFT)); in marvel_map_irq()
374 irq |= io7->pe << MARVEL_IRQ_VEC_PE_SHIFT; /* merge the pid */ in marvel_map_irq()
413 * There is a local IO7 - redirect all of its interrupts here. in marvel_smp_callin()
415 printk("Redirecting IO7 interrupts to local CPU at PE %u\n", cpuid); in marvel_smp_callin()
418 io7_redirect_irq(io7, &io7->csrs->HLT_CTL.csr, cpuid); in marvel_smp_callin()
419 io7_redirect_irq(io7, &io7->csrs->HPI_CTL.csr, cpuid); in marvel_smp_callin()
420 io7_redirect_irq(io7, &io7->csrs->CRD_CTL.csr, cpuid); in marvel_smp_callin()
421 io7_redirect_irq(io7, &io7->csrs->STV_CTL.csr, cpuid); in marvel_smp_callin()
422 io7_redirect_irq(io7, &io7->csrs->HEI_CTL.csr, cpuid); in marvel_smp_callin()