diff options
author | Jiang Liu <jiang.liu@linux.intel.com> | 2015-06-01 04:05:43 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2015-09-16 09:46:49 -0400 |
commit | b237721c5d95082a803c0be686f56d2dd1de995b (patch) | |
tree | fcaec3ce10ca018ef4b73860347fe421277bd399 /include | |
parent | 9df872faa7e1619e9278bec00ceaed2236533530 (diff) |
genirq: Move field 'msi_desc' from irq_data into irq_common_data
MSI descriptors are per-irq instead of per irqchip, so move it into
struct irq_common_data.
Signed-off-by: Jiang Liu <jiang.liu@linux.intel.com>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Randy Dunlap <rdunlap@infradead.org>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Jason Cooper <jason@lakedaemon.net>
Cc: Kevin Cernekee <cernekee@gmail.com>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Link: http://lkml.kernel.org/r/1433145945-789-35-git-send-email-jiang.liu@linux.intel.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/irq.h | 8 | ||||
-rw-r--r-- | include/linux/irqdesc.h | 2 |
2 files changed, 5 insertions, 5 deletions
diff --git a/include/linux/irq.h b/include/linux/irq.h index 75d50544a18f..4913c32db942 100644 --- a/include/linux/irq.h +++ b/include/linux/irq.h | |||
@@ -132,6 +132,7 @@ struct irq_domain; | |||
132 | * @node: node index useful for balancing | 132 | * @node: node index useful for balancing |
133 | * @handler_data: per-IRQ data for the irq_chip methods | 133 | * @handler_data: per-IRQ data for the irq_chip methods |
134 | * @affinity: IRQ affinity on SMP | 134 | * @affinity: IRQ affinity on SMP |
135 | * @msi_desc: MSI descriptor | ||
135 | */ | 136 | */ |
136 | struct irq_common_data { | 137 | struct irq_common_data { |
137 | unsigned int state_use_accessors; | 138 | unsigned int state_use_accessors; |
@@ -139,6 +140,7 @@ struct irq_common_data { | |||
139 | unsigned int node; | 140 | unsigned int node; |
140 | #endif | 141 | #endif |
141 | void *handler_data; | 142 | void *handler_data; |
143 | struct msi_desc *msi_desc; | ||
142 | cpumask_var_t affinity; | 144 | cpumask_var_t affinity; |
143 | }; | 145 | }; |
144 | 146 | ||
@@ -155,7 +157,6 @@ struct irq_common_data { | |||
155 | * irq_domain | 157 | * irq_domain |
156 | * @chip_data: platform-specific per-chip private data for the chip | 158 | * @chip_data: platform-specific per-chip private data for the chip |
157 | * methods, to allow shared chip implementations | 159 | * methods, to allow shared chip implementations |
158 | * @msi_desc: MSI descriptor | ||
159 | */ | 160 | */ |
160 | struct irq_data { | 161 | struct irq_data { |
161 | u32 mask; | 162 | u32 mask; |
@@ -168,7 +169,6 @@ struct irq_data { | |||
168 | struct irq_data *parent_data; | 169 | struct irq_data *parent_data; |
169 | #endif | 170 | #endif |
170 | void *chip_data; | 171 | void *chip_data; |
171 | struct msi_desc *msi_desc; | ||
172 | }; | 172 | }; |
173 | 173 | ||
174 | /* | 174 | /* |
@@ -652,12 +652,12 @@ static inline void *irq_data_get_irq_handler_data(struct irq_data *d) | |||
652 | static inline struct msi_desc *irq_get_msi_desc(unsigned int irq) | 652 | static inline struct msi_desc *irq_get_msi_desc(unsigned int irq) |
653 | { | 653 | { |
654 | struct irq_data *d = irq_get_irq_data(irq); | 654 | struct irq_data *d = irq_get_irq_data(irq); |
655 | return d ? d->msi_desc : NULL; | 655 | return d ? d->common->msi_desc : NULL; |
656 | } | 656 | } |
657 | 657 | ||
658 | static inline struct msi_desc *irq_data_get_msi_desc(struct irq_data *d) | 658 | static inline struct msi_desc *irq_data_get_msi_desc(struct irq_data *d) |
659 | { | 659 | { |
660 | return d->msi_desc; | 660 | return d->common->msi_desc; |
661 | } | 661 | } |
662 | 662 | ||
663 | static inline u32 irq_get_trigger_type(unsigned int irq) | 663 | static inline u32 irq_get_trigger_type(unsigned int irq) |
diff --git a/include/linux/irqdesc.h b/include/linux/irqdesc.h index c7b3e1cc6d59..fbb4d5afc32b 100644 --- a/include/linux/irqdesc.h +++ b/include/linux/irqdesc.h | |||
@@ -128,7 +128,7 @@ static inline void *irq_desc_get_handler_data(struct irq_desc *desc) | |||
128 | 128 | ||
129 | static inline struct msi_desc *irq_desc_get_msi_desc(struct irq_desc *desc) | 129 | static inline struct msi_desc *irq_desc_get_msi_desc(struct irq_desc *desc) |
130 | { | 130 | { |
131 | return desc->irq_data.msi_desc; | 131 | return desc->irq_common_data.msi_desc; |
132 | } | 132 | } |
133 | 133 | ||
134 | /* | 134 | /* |