| /linux/kernel/irq/ |
| H A D | cpuhotplug.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * Generic cpu hotunplug interrupt migration code copied from the 12 #include <linux/interrupt.h> 19 /* For !GENERIC_IRQ_EFFECTIVE_AFF_MASK this looks at general affinity mask */ 27 * The cpumask_empty() check is a workaround for interrupt chips, in irq_needs_fixup() 28 * which do not implement effective affinity, but the architecture has in irq_needs_fixup() 29 * enabled the config switch. Use the general affinity mask instead. in irq_needs_fixup() 45 pr_warn("Eff. affinity %*pbl of IRQ %u contains only offline CPUs after offlining CPU %u\n", in irq_needs_fixup() 46 cpumask_pr_args(m), d->irq, cpu); in irq_needs_fixup() 58 const struct cpumask *affinity; in migrate_one_irq() local [all …]
|
| H A D | manage.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * Copyright (C) 1992, 1998-2006 Linus Torvalds, Ingo Molnar 4 * Copyright (C) 2005-2006 Thomas Gleixner 15 #include <linux/interrupt.h> 50 while (irqd_irq_inprogress(&desc->irq_data)) in __synchronize_hardirq() 53 /* Ok, that indicated we're done: double-check carefully. */ in __synchronize_hardirq() 54 guard(raw_spinlock_irqsave)(&desc->lock); in __synchronize_hardirq() 55 inprogress = irqd_irq_inprogress(&desc->irq_data); in __synchronize_hardirq() 75 * synchronize_hardirq - wait for pending hard IRQ handlers (on other CPUs) 76 * @irq: interrupt number to wait for [all …]
|
| H A D | affinity.c | 1 // SPDX-License-Identifier: GPL-2.0 4 * Copyright (C) 2016-2017 Christoph Hellwig. 6 #include <linux/interrupt.h> 14 affd->nr_sets = 1; in default_calc_sets() 15 affd->set_size[0] = affvecs; in default_calc_sets() 19 * irq_create_affinity_masks - Create affinity masks for multiqueue spreading 21 * @affd: Description of the affinity requirements 32 * Determine the number of vectors which need interrupt affinities in irq_create_affinity_masks() 37 if (nvecs > affd->pre_vectors + affd->post_vectors) in irq_create_affinity_masks() 38 affvecs = nvecs - affd->pre_vectors - affd->post_vectors; in irq_create_affinity_masks() [all …]
|
| H A D | Kconfig | 1 # SPDX-License-Identifier: GPL-2.0-only 21 # Supports effective affinity mask 26 # Support for delayed migration from interrupt context 34 # Alpha specific irq affinity mechanism 38 # Interrupt injection mechanism 46 # Generic configurable interrupt chip implementation 51 # Generic irq_domain hw <--> linux irq number translation 66 # Support for obsolete non-mapping irq domains 86 # Generic MSI hierarchical interrupt domain support 104 # Snapshot for interrupt statistics [all …]
|
| H A D | devres.c | 1 // SPDX-License-Identifier: GPL-2.0 3 #include <linux/interrupt.h> 23 free_irq(this->irq, this->dev_id); in devm_irq_release() 30 return this->irq == match->irq && this->dev_id == match->dev_id; in devm_irq_match() 56 return -ENOMEM; in __devm_request_threaded_irq() 68 dr->irq = irq; in __devm_request_threaded_irq() 69 dr->dev_id = dev_id; in __devm_request_threaded_irq() 76 * devm_request_threaded_irq - allocate an interrupt line for a managed device with error logging 77 * @dev: Device to request interrupt for 78 * @irq: Interrupt line to allocate [all …]
|
| H A D | chip.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * Copyright (C) 1992, 1998-2006 Linus Torvalds, Ingo Molnar 4 * Copyright (C) 2005-2006, Thomas Gleixner, Russell King 6 * This file contains the core interrupt handling code, for irq-chip based 8 * Documentation/core-api/genericirq.rst 14 #include <linux/interrupt.h> 37 * irq_set_chip - set the irq chip for an irq 43 int ret = -EINVAL; in irq_set_chip() 46 scoped_irqdesc->irq_data.chip = (struct irq_chip *)(chip ?: &no_irq_chip); in irq_set_chip() 57 * irq_set_irq_type - set the irq trigger type for an irq [all …]
|
| H A D | irq_test.c | 1 // SPDX-License-Identifier: LGPL-2.1+ 6 #include <linux/interrupt.h> 49 virq = irq_domain_alloc_descs(-1, 1, 0, NUMA_NO_NODE, affd); in irq_test_setup_fake_irq() 76 KUNIT_EXPECT_EQ(test, desc->depth, 0); in irq_disable_depth_test() 79 KUNIT_EXPECT_EQ(test, desc->depth, 1); in irq_disable_depth_test() 82 KUNIT_EXPECT_EQ(test, desc->depth, 0); in irq_disable_depth_test() 100 KUNIT_EXPECT_EQ(test, desc->depth, 0); in irq_free_disabled_test() 103 KUNIT_EXPECT_EQ(test, desc->depth, 1); in irq_free_disabled_test() 106 KUNIT_EXPECT_GE(test, desc->depth, 1); in irq_free_disabled_test() 110 KUNIT_EXPECT_EQ(test, desc->depth, 0); in irq_free_disabled_test() [all …]
|
| /linux/drivers/pci/msi/ |
| H A D | api.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * PCI MSI/MSI-X — Exported APIs for device drivers 5 * Copyright (C) 2003-2004 Intel 17 * pci_enable_msi() - Enable MSI interrupt mode on device 21 * allocate a single interrupt vector. On success, the allocated vector 22 * Linux IRQ will be saved at @dev->irq. The driver must invoke 40 * pci_disable_msi() - Disable MSI interrupt mode on device 43 * Legacy device driver API to disable MSI interrupt mode on device, 44 * free earlier allocated interrupt vectors, and restore INTx emulation. 45 * The PCI device Linux IRQ (@dev->irq) is restored to its default [all …]
|
| /linux/Documentation/devicetree/bindings/interrupt-controller/ |
| H A D | apple,aic.yaml | 1 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 3 --- 4 $id: http://devicetree.org/schemas/interrupt-controller/apple,aic.yaml# 5 $schema: http://devicetree.org/meta-schemas/core.yaml# 7 title: Apple Interrupt Controller 10 - Hector Martin <marcan@marcan.st> 13 The Apple Interrupt Controller is a simple interrupt controller present on 19 - Level-triggered hardware IRQs wired to SoC blocks 20 - Single mask bit per IRQ 21 - Per-IRQ affinity setting [all …]
|
| /linux/arch/powerpc/sysdev/xics/ |
| H A D | xics-common.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 12 #include <linux/interrupt.h> 60 ireg = of_get_property(np, "ibm,ppc-interrupt-gserver#s", &ilen); in xics_update_irq_servers() 68 /* Global interrupt distribution server is specified in the last in xics_update_irq_servers() 69 * entry of "ibm,ppc-interrupt-gserver#s" property. Get the last in xics_update_irq_servers() 96 index = (1UL << xics_interrupt_server_size) - 1 - gserver; in xics_set_cpu_giq() 100 WARN(status < 0, "set-indicator(%d, %d, %u) returned %d\n", in xics_set_cpu_giq() 107 icp_ops->set_priority(LOWEST_PRIORITY); in xics_setup_cpu() 114 pr_err("Interrupt 0x%x (real) is invalid, disabling it.\n", vec); in xics_mask_unknown_vec() 118 xics_ics->mask_unknown(xics_ics, vec); in xics_mask_unknown_vec() [all …]
|
| /linux/drivers/irqchip/ |
| H A D | irq-bcm7038-l1.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * Broadcom BCM7038 style Level 1 interrupt controller driver 14 #include <linux/interrupt.h> 47 u8 affinity[MAX_WORDS * IRQS_PER_WORD]; member 82 return (0 * intc->n_words + word) * sizeof(u32); in reg_status() 88 return (2 * intc->n_words + word) * sizeof(u32); in reg_mask_set() 94 return (3 * intc->n_words + word) * sizeof(u32); in reg_mask_clr() 121 cpu = intc->cpus[cpu_logical_map(smp_processor_id())]; in bcm7038_l1_irq_handle() 123 cpu = intc->cpus[0]; in bcm7038_l1_irq_handle() 128 for (idx = 0; idx < intc->n_words; idx++) { in bcm7038_l1_irq_handle() [all …]
|
| H A D | irq-msi-lib.c | 1 // SPDX-License-Identifier: GPL-2.0-only 7 #include <linux/irqchip/irq-msi-lib.h> 10 * msi_lib_init_dev_msi_info - Domain info setup for MSI domains 30 const struct msi_parent_ops *pops = real_parent->msi_parent_ops; in msi_lib_init_dev_msi_info() 31 struct irq_chip *chip = info->chip; in msi_lib_init_dev_msi_info() 41 * possible to stack MSI parents. See x86 vector -> irq remapping in msi_lib_init_dev_msi_info() 43 if (domain->bus_token == pops->bus_select_token) { in msi_lib_init_dev_msi_info() 51 required_flags = pops->required_flags; in msi_lib_init_dev_msi_info() 54 switch(info->bus_token) { in msi_lib_init_dev_msi_info() 64 * set. It's sole purpose is to create a dumb interrupt in msi_lib_init_dev_msi_info() [all …]
|
| /linux/arch/alpha/kernel/ |
| H A D | sys_dp264.c | 1 // SPDX-License-Identifier: GPL-2.0 68 dim0 = &cchip->dim0.csr; in tsunami_update_irq_hw() 69 dim1 = &cchip->dim1.csr; in tsunami_update_irq_hw() 70 dim2 = &cchip->dim2.csr; in tsunami_update_irq_hw() 71 dim3 = &cchip->dim3.csr; in tsunami_update_irq_hw() 88 if (bcpu == 0) dimB = &cchip->dim0.csr; in tsunami_update_irq_hw() 89 else if (bcpu == 1) dimB = &cchip->dim1.csr; in tsunami_update_irq_hw() 90 else if (bcpu == 2) dimB = &cchip->dim2.csr; in tsunami_update_irq_hw() 91 else dimB = &cchip->dim3.csr; in tsunami_update_irq_hw() 103 cached_irq_mask |= 1UL << d->irq; in dp264_enable_irq() [all …]
|
| /linux/lib/ |
| H A D | cpu_rmap.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * cpu_rmap.c: CPU affinity reverse-map support 8 #include <linux/interrupt.h> 13 * objects with CPU affinities. This can be seen as a reverse-map of 14 * CPU affinity. However, we do not assume that the object affinities 21 * alloc_cpu_rmap - allocate CPU affinity reverse-map 39 rmap = kzalloc(obj_offset + size * sizeof(rmap->obj[0]), flags); in alloc_cpu_rmap() 43 kref_init(&rmap->refcount); in alloc_cpu_rmap() 44 rmap->obj = (void **)((char *)rmap + obj_offset); in alloc_cpu_rmap() 50 * any newly-hotplugged CPUs to have some object assigned. in alloc_cpu_rmap() [all …]
|
| /linux/drivers/iommu/ |
| H A D | hyperv-iommu.c | 1 // SPDX-License-Identifier: GPL-2.0 4 * Hyper-V stub IOMMU driver. 12 #include <linux/interrupt.h> 30 * According 82093AA IO-APIC spec , IO APIC has a 24-entry Interrupt 31 * Redirection Table. Hyper-V exposes one single IO-APIC and so define 42 struct irq_data *parent = data->parent_data; in hyperv_ir_set_affinity() 46 /* Return error If new irq affinity is out of ioapic_max_cpumask. */ in hyperv_ir_set_affinity() 48 return -EINVAL; in hyperv_ir_set_affinity() 50 ret = parent->chip->irq_set_affinity(parent, mask, force); in hyperv_ir_set_affinity() 60 .name = "HYPERV-IR", [all …]
|
| /linux/arch/x86/kernel/apic/ |
| H A D | vector.c | 1 // SPDX-License-Identifier: GPL-2.0-only 10 #include <linux/interrupt.h> 78 info->mask = mask; in init_irq_alloc_info() 94 while (irqd->parent_data) in apic_chip_data() 95 irqd = irqd->parent_data; in apic_chip_data() 97 return irqd->chip_data; in apic_chip_data() 104 return apicd ? &apicd->hw_irq_cfg : NULL; in irqd_cfg() 119 INIT_HLIST_NODE(&apicd->clist); in alloc_apic_chip_data() 135 apicd->hw_irq_cfg.vector = vector; in apic_update_irq_cfg() 136 apicd->hw_irq_cfg.dest_apicid = apic->calc_dest_apicid(cpu); in apic_update_irq_cfg() [all …]
|
| /linux/arch/arm64/boot/dts/apple/ |
| H A D | t6001.dtsi | 1 // SPDX-License-Identifier: GPL-2.0+ OR MIT 10 #include <dt-bindings/gpio/gpio.h> 11 #include <dt-bindings/interrupt-controller/apple-aic.h> 12 #include <dt-bindings/interrupt-controller/irq.h> 13 #include <dt-bindings/pinctrl/apple.h> 14 #include <dt-bindings/spmi/spmi.h> 16 #include "multi-die-cpp.h" 18 #include "t600x-common.dtsi" 21 compatible = "apple,t6001", "apple,arm-platform"; 24 compatible = "simple-bus"; [all …]
|
| /linux/arch/mips/sibyte/sb1250/ |
| H A D | irq.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 8 #include <linux/interrupt.h> 26 * These are the routines that handle all the low level interrupt stuff. 27 * Actions handled here are: initialization of the interrupt map, requesting of 28 * interrupt lines by handlers, dispatching if interrupts to handlers, probing 29 * for interrupt lines 74 unsigned int irq = d->irq; in sb1250_set_affinity() 83 /* Protect against other affinity changers and IMR manipulation */ in sb1250_set_affinity() 114 unsigned int irq = d->irq; in disable_sb1250_irq() 121 unsigned int irq = d->irq; in enable_sb1250_irq() [all …]
|
| /linux/Documentation/virt/hyperv/ |
| H A D | vpci.rst | 1 .. SPDX-License-Identifier: GPL-2.0 3 PCI pass-thru devices 5 In a Hyper-V guest VM, PCI pass-thru devices (also called 16 Hyper-V terminology for vPCI devices is "Discrete Device 17 Assignment" (DDA). Public documentation for Hyper-V DDA is 20 …tps://learn.microsoft.com/en-us/windows-server/virtualization/hyper-v/plan/plan-for-deploying-devi… 23 and for GPUs. A similar mechanism for NICs is called SR-IOV 25 driver to interact directly with the hardware. See Hyper-V 26 public documentation here: `SR-IOV`_ 28 .. _SR-IOV: https://learn.microsoft.com/en-us/windows-hardware/drivers/network/overview-of-single-r… [all …]
|
| /linux/arch/arm64/boot/dts/exynos/ |
| H A D | exynos990.dtsi | 1 // SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause 8 #include <dt-bindings/clock/samsung,exynos990.h> 9 #include <dt-bindings/interrupt-controller/arm-gic.h> 13 #address-cells = <2>; 14 #size-cells = <1>; 16 interrupt-parent = <&gic>; 29 #address-cells = <1>; 30 #size-cells = <0>; 32 cpu-map { 74 compatible = "arm,cortex-a55"; [all …]
|
| /linux/arch/mips/sibyte/bcm1480/ |
| H A D | irq.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 8 #include <linux/interrupt.h> 27 * These are the routines that handle all the low level interrupt stuff. 28 * Actions handled here are: initialization of the interrupt map, requesting of 29 * interrupt lines by handlers, dispatching if interrupts to handlers, probing 30 * for interrupt lines 51 irq -= BCM1480_NR_IRQS_HALF; in bcm1480_mask_irq() 68 irq -= BCM1480_NR_IRQS_HALF; in bcm1480_unmask_irq() 80 unsigned int irq_dirty, irq = d->irq; in bcm1480_set_affinity() 90 /* Protect against other affinity changers and IMR manipulation */ in bcm1480_set_affinity() [all …]
|
| /linux/arch/arm64/kernel/ |
| H A D | setup.c | 1 // SPDX-License-Identifier: GPL-2.0-only 5 * Copyright (C) 1995-2001 Russell King 23 #include <linux/interrupt.h> 106 * smp_build_mpidr_hash - Pre-compute shifts required at each affinity 113 u32 i, affinity, fs[4], bits[4], ls; in smp_build_mpidr_hash() local 116 * Pre-scan the list of MPIDRS and filter out bits that do in smp_build_mpidr_hash() 117 * not contribute to affinity levels, ie they never toggle. in smp_build_mpidr_hash() 123 * Find and stash the last and first bit set at all affinity levels to in smp_build_mpidr_hash() 127 affinity = MPIDR_AFFINITY_LEVEL(mask, i); in smp_build_mpidr_hash() 131 * to express the affinity level. in smp_build_mpidr_hash() [all …]
|
| /linux/arch/arc/kernel/ |
| H A D | mcip.c | 1 // SPDX-License-Identifier: GPL-2.0-only 13 #include <asm/irqflags-arcv2.h> 71 * STATUS32[H]/actionpoint/breakpoint/self-halt in mcip_update_debug_halt_mask() 111 * If receiver already has a pending interrupt, elide sending this one. in mcip_ipi_send() 181 * ARCv2 Interrupt Distribution Unit (IDU) 184 * -dynamic routing (IRQ affinity) 185 * -load balancing (Round Robin interrupt distribution) 186 * -1:N distribution 232 idu_irq_mask_raw(data->hwirq); in idu_irq_mask() 240 __mcip_cmd_data(CMD_IDU_SET_MASK, data->hwirq, 0); in idu_irq_unmask() [all …]
|
| /linux/samples/pktgen/ |
| H A D | pktgen_sample06_numa_awared_queue_irq_affinity.sh | 5 # * bound devices queue's irq affinity to the threads, 1:1 mapping 14 # Required param: -i dev in $DEV 21 [ -z "$COUNT" ] && COUNT="20000000" # Zero means indefinitely 22 [ -z "$CLONE_SKB" ] && CLONE_SKB="0" 32 [ $THREADS -gt ${#irq_array[*]} -o $THREADS -gt ${#cpu_array[*]} ] && \ 36 if [ -z "$DEST_IP" ]; then 37 [ -z "$IP6" ] && DEST_IP="198.18.0.42" || DEST_IP="FD00::1" 39 [ -z "$DST_MAC" ] && DST_MAC="90:e2:ba:ff:ff:ff" 40 if [ -n "$DEST_IP" ]; then 42 read -r DST_MIN DST_MAX <<< $(parse_addr${IP6} $DEST_IP) [all …]
|
| /linux/arch/arm/boot/dts/nxp/vf/ |
| H A D | vf500.dtsi | 1 // SPDX-License-Identifier: (GPL-2.0 OR MIT) 6 #include <dt-bindings/interrupt-controller/arm-gic.h> 9 #address-cells = <1>; 10 #size-cells = <1>; 15 #address-cells = <1>; 16 #size-cells = <0>; 19 compatible = "arm,cortex-a5"; 28 intc: interrupt-controller@40003000 { 29 compatible = "arm,cortex-a9-gic"; 30 #interrupt-cells = <3>; [all …]
|