xref: /linux/drivers/pci/msi/irqdomain.c (revision a4bd4c330d5deaaa54db3a2ca4d2dd402d3a7248)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * PCI Message Signaled Interrupt (MSI) - irqdomain support
4  */
5 #include <linux/acpi_iort.h>
6 #include <linux/irqdomain.h>
7 #include <linux/of_irq.h>
8 
9 #include "msi.h"
10 
11 int pci_msi_setup_msi_irqs(struct pci_dev *dev, int nvec, int type)
12 {
13 	struct irq_domain *domain;
14 
15 	domain = dev_get_msi_domain(&dev->dev);
16 	if (domain && irq_domain_is_hierarchy(domain))
17 		return msi_domain_alloc_irqs_all_locked(&dev->dev, MSI_DEFAULT_DOMAIN, nvec);
18 
19 	return pci_msi_legacy_setup_msi_irqs(dev, nvec, type);
20 }
21 
22 void pci_msi_teardown_msi_irqs(struct pci_dev *dev)
23 {
24 	struct irq_domain *domain;
25 
26 	domain = dev_get_msi_domain(&dev->dev);
27 	if (domain && irq_domain_is_hierarchy(domain)) {
28 		msi_domain_free_irqs_all_locked(&dev->dev, MSI_DEFAULT_DOMAIN);
29 	} else {
30 		pci_msi_legacy_teardown_msi_irqs(dev);
31 		msi_free_msi_descs(&dev->dev);
32 	}
33 }
34 
35 /**
36  * pci_msi_domain_write_msg - Helper to write MSI message to PCI config space
37  * @irq_data:	Pointer to interrupt data of the MSI interrupt
38  * @msg:	Pointer to the message
39  */
40 static void pci_msi_domain_write_msg(struct irq_data *irq_data, struct msi_msg *msg)
41 {
42 	struct msi_desc *desc = irq_data_get_msi_desc(irq_data);
43 
44 	/*
45 	 * For MSI-X desc->irq is always equal to irq_data->irq. For
46 	 * MSI only the first interrupt of MULTI MSI passes the test.
47 	 */
48 	if (desc->irq == irq_data->irq)
49 		__pci_write_msi_msg(desc, msg);
50 }
51 
52 /**
53  * pci_msi_domain_calc_hwirq - Generate a unique ID for an MSI source
54  * @desc:	Pointer to the MSI descriptor
55  *
56  * The ID number is only used within the irqdomain.
57  */
58 static irq_hw_number_t pci_msi_domain_calc_hwirq(struct msi_desc *desc)
59 {
60 	struct pci_dev *dev = msi_desc_to_pci_dev(desc);
61 
62 	return (irq_hw_number_t)desc->msi_index |
63 		pci_dev_id(dev) << 11 |
64 		((irq_hw_number_t)(pci_domain_nr(dev->bus) & 0xFFFFFFFF)) << 27;
65 }
66 
67 static void pci_msi_domain_set_desc(msi_alloc_info_t *arg,
68 				    struct msi_desc *desc)
69 {
70 	arg->desc = desc;
71 	arg->hwirq = pci_msi_domain_calc_hwirq(desc);
72 }
73 
74 static struct msi_domain_ops pci_msi_domain_ops_default = {
75 	.set_desc	= pci_msi_domain_set_desc,
76 };
77 
78 static void pci_msi_domain_update_dom_ops(struct msi_domain_info *info)
79 {
80 	struct msi_domain_ops *ops = info->ops;
81 
82 	if (ops == NULL) {
83 		info->ops = &pci_msi_domain_ops_default;
84 	} else {
85 		if (ops->set_desc == NULL)
86 			ops->set_desc = pci_msi_domain_set_desc;
87 	}
88 }
89 
90 static void pci_msi_domain_update_chip_ops(struct msi_domain_info *info)
91 {
92 	struct irq_chip *chip = info->chip;
93 
94 	BUG_ON(!chip);
95 	if (!chip->irq_write_msi_msg)
96 		chip->irq_write_msi_msg = pci_msi_domain_write_msg;
97 	if (!chip->irq_mask)
98 		chip->irq_mask = pci_msi_mask_irq;
99 	if (!chip->irq_unmask)
100 		chip->irq_unmask = pci_msi_unmask_irq;
101 }
102 
103 /**
104  * pci_msi_create_irq_domain - Create a MSI interrupt domain
105  * @fwnode:	Optional fwnode of the interrupt controller
106  * @info:	MSI domain info
107  * @parent:	Parent irq domain
108  *
109  * Updates the domain and chip ops and creates a MSI interrupt domain.
110  *
111  * Returns:
112  * A domain pointer or NULL in case of failure.
113  */
114 struct irq_domain *pci_msi_create_irq_domain(struct fwnode_handle *fwnode,
115 					     struct msi_domain_info *info,
116 					     struct irq_domain *parent)
117 {
118 	if (WARN_ON(info->flags & MSI_FLAG_LEVEL_CAPABLE))
119 		info->flags &= ~MSI_FLAG_LEVEL_CAPABLE;
120 
121 	if (info->flags & MSI_FLAG_USE_DEF_DOM_OPS)
122 		pci_msi_domain_update_dom_ops(info);
123 	if (info->flags & MSI_FLAG_USE_DEF_CHIP_OPS)
124 		pci_msi_domain_update_chip_ops(info);
125 
126 	/* Let the core code free MSI descriptors when freeing interrupts */
127 	info->flags |= MSI_FLAG_FREE_MSI_DESCS;
128 
129 	info->flags |= MSI_FLAG_ACTIVATE_EARLY | MSI_FLAG_DEV_SYSFS;
130 	if (IS_ENABLED(CONFIG_GENERIC_IRQ_RESERVATION_MODE))
131 		info->flags |= MSI_FLAG_MUST_REACTIVATE;
132 
133 	/* PCI-MSI is oneshot-safe */
134 	info->chip->flags |= IRQCHIP_ONESHOT_SAFE;
135 	/* Let the core update the bus token */
136 	info->bus_token = DOMAIN_BUS_PCI_MSI;
137 
138 	return msi_create_irq_domain(fwnode, info, parent);
139 }
140 EXPORT_SYMBOL_GPL(pci_msi_create_irq_domain);
141 
142 /*
143  * Per device MSI[-X] domain functionality
144  */
145 static void pci_device_domain_set_desc(msi_alloc_info_t *arg, struct msi_desc *desc)
146 {
147 	arg->desc = desc;
148 	arg->hwirq = desc->msi_index;
149 }
150 
151 static void cond_shutdown_parent(struct irq_data *data)
152 {
153 	struct msi_domain_info *info = data->domain->host_data;
154 
155 	if (unlikely(info->flags & MSI_FLAG_PCI_MSI_STARTUP_PARENT))
156 		irq_chip_shutdown_parent(data);
157 	else if (unlikely(info->flags & MSI_FLAG_PCI_MSI_MASK_PARENT))
158 		irq_chip_mask_parent(data);
159 }
160 
161 static unsigned int cond_startup_parent(struct irq_data *data)
162 {
163 	struct msi_domain_info *info = data->domain->host_data;
164 
165 	if (unlikely(info->flags & MSI_FLAG_PCI_MSI_STARTUP_PARENT))
166 		return irq_chip_startup_parent(data);
167 	else if (unlikely(info->flags & MSI_FLAG_PCI_MSI_MASK_PARENT))
168 		irq_chip_unmask_parent(data);
169 
170 	return 0;
171 }
172 
173 static __always_inline void cond_mask_parent(struct irq_data *data)
174 {
175 	struct msi_domain_info *info = data->domain->host_data;
176 
177 	if (unlikely(info->flags & MSI_FLAG_PCI_MSI_MASK_PARENT))
178 		irq_chip_mask_parent(data);
179 }
180 
181 static __always_inline void cond_unmask_parent(struct irq_data *data)
182 {
183 	struct msi_domain_info *info = data->domain->host_data;
184 
185 	if (unlikely(info->flags & MSI_FLAG_PCI_MSI_MASK_PARENT))
186 		irq_chip_unmask_parent(data);
187 }
188 
189 static void pci_irq_shutdown_msi(struct irq_data *data)
190 {
191 	struct msi_desc *desc = irq_data_get_msi_desc(data);
192 
193 	pci_msi_mask(desc, BIT(data->irq - desc->irq));
194 	cond_shutdown_parent(data);
195 }
196 
197 static unsigned int pci_irq_startup_msi(struct irq_data *data)
198 {
199 	struct msi_desc *desc = irq_data_get_msi_desc(data);
200 	unsigned int ret = cond_startup_parent(data);
201 
202 	pci_msi_unmask(desc, BIT(data->irq - desc->irq));
203 	return ret;
204 }
205 
206 static void pci_irq_mask_msi(struct irq_data *data)
207 {
208 	struct msi_desc *desc = irq_data_get_msi_desc(data);
209 
210 	pci_msi_mask(desc, BIT(data->irq - desc->irq));
211 	cond_mask_parent(data);
212 }
213 
214 static void pci_irq_unmask_msi(struct irq_data *data)
215 {
216 	struct msi_desc *desc = irq_data_get_msi_desc(data);
217 
218 	cond_unmask_parent(data);
219 	pci_msi_unmask(desc, BIT(data->irq - desc->irq));
220 }
221 
222 #ifdef CONFIG_GENERIC_IRQ_RESERVATION_MODE
223 # define MSI_REACTIVATE		MSI_FLAG_MUST_REACTIVATE
224 #else
225 # define MSI_REACTIVATE		0
226 #endif
227 
228 #define MSI_COMMON_FLAGS	(MSI_FLAG_FREE_MSI_DESCS |	\
229 				 MSI_FLAG_ACTIVATE_EARLY |	\
230 				 MSI_FLAG_DEV_SYSFS |		\
231 				 MSI_REACTIVATE)
232 
233 static const struct msi_domain_template pci_msi_template = {
234 	.chip = {
235 		.name			= "PCI-MSI",
236 		.irq_startup		= pci_irq_startup_msi,
237 		.irq_shutdown		= pci_irq_shutdown_msi,
238 		.irq_mask		= pci_irq_mask_msi,
239 		.irq_unmask		= pci_irq_unmask_msi,
240 		.irq_write_msi_msg	= pci_msi_domain_write_msg,
241 		.flags			= IRQCHIP_ONESHOT_SAFE,
242 	},
243 
244 	.ops = {
245 		.set_desc		= pci_device_domain_set_desc,
246 	},
247 
248 	.info = {
249 		.flags			= MSI_COMMON_FLAGS | MSI_FLAG_MULTI_PCI_MSI,
250 		.bus_token		= DOMAIN_BUS_PCI_DEVICE_MSI,
251 	},
252 };
253 
254 static void pci_irq_shutdown_msix(struct irq_data *data)
255 {
256 	pci_msix_mask(irq_data_get_msi_desc(data));
257 	cond_shutdown_parent(data);
258 }
259 
260 static unsigned int pci_irq_startup_msix(struct irq_data *data)
261 {
262 	unsigned int ret = cond_startup_parent(data);
263 
264 	pci_msix_unmask(irq_data_get_msi_desc(data));
265 	return ret;
266 }
267 
268 static void pci_irq_mask_msix(struct irq_data *data)
269 {
270 	pci_msix_mask(irq_data_get_msi_desc(data));
271 	cond_mask_parent(data);
272 }
273 
274 static void pci_irq_unmask_msix(struct irq_data *data)
275 {
276 	cond_unmask_parent(data);
277 	pci_msix_unmask(irq_data_get_msi_desc(data));
278 }
279 
280 void pci_msix_prepare_desc(struct irq_domain *domain, msi_alloc_info_t *arg,
281 			   struct msi_desc *desc)
282 {
283 	/* Don't fiddle with preallocated MSI descriptors */
284 	if (!desc->pci.mask_base)
285 		msix_prepare_msi_desc(to_pci_dev(desc->dev), desc);
286 }
287 EXPORT_SYMBOL_GPL(pci_msix_prepare_desc);
288 
289 static const struct msi_domain_template pci_msix_template = {
290 	.chip = {
291 		.name			= "PCI-MSIX",
292 		.irq_startup		= pci_irq_startup_msix,
293 		.irq_shutdown		= pci_irq_shutdown_msix,
294 		.irq_mask		= pci_irq_mask_msix,
295 		.irq_unmask		= pci_irq_unmask_msix,
296 		.irq_write_msi_msg	= pci_msi_domain_write_msg,
297 		.flags			= IRQCHIP_ONESHOT_SAFE,
298 	},
299 
300 	.ops = {
301 		.prepare_desc		= pci_msix_prepare_desc,
302 		.set_desc		= pci_device_domain_set_desc,
303 	},
304 
305 	.info = {
306 		.flags			= MSI_COMMON_FLAGS | MSI_FLAG_PCI_MSIX |
307 					  MSI_FLAG_PCI_MSIX_ALLOC_DYN,
308 		.bus_token		= DOMAIN_BUS_PCI_DEVICE_MSIX,
309 	},
310 };
311 
312 static bool pci_match_device_domain(struct pci_dev *pdev, enum irq_domain_bus_token bus_token)
313 {
314 	return msi_match_device_irq_domain(&pdev->dev, MSI_DEFAULT_DOMAIN, bus_token);
315 }
316 
317 static bool pci_create_device_domain(struct pci_dev *pdev, const struct msi_domain_template *tmpl,
318 				     unsigned int hwsize)
319 {
320 	struct irq_domain *domain = dev_get_msi_domain(&pdev->dev);
321 
322 	if (!domain || !irq_domain_is_msi_parent(domain))
323 		return true;
324 
325 	return msi_create_device_irq_domain(&pdev->dev, MSI_DEFAULT_DOMAIN, tmpl,
326 					    hwsize, NULL, NULL);
327 }
328 
329 /**
330  * pci_setup_msi_device_domain - Setup a device MSI interrupt domain
331  * @pdev:	The PCI device to create the domain on
332  * @hwsize:	The maximum number of MSI vectors
333  *
334  * Return:
335  *  True when:
336  *	- The device does not have a MSI parent irq domain associated,
337  *	  which keeps the legacy architecture specific and the global
338  *	  PCI/MSI domain models working
339  *	- The MSI domain exists already
340  *	- The MSI domain was successfully allocated
341  *  False when:
342  *	- MSI-X is enabled
343  *	- The domain creation fails.
344  *
345  * The created MSI domain is preserved until:
346  *	- The device is removed
347  *	- MSI is disabled and a MSI-X domain is created
348  */
349 bool pci_setup_msi_device_domain(struct pci_dev *pdev, unsigned int hwsize)
350 {
351 	if (WARN_ON_ONCE(pdev->msix_enabled))
352 		return false;
353 
354 	if (pci_match_device_domain(pdev, DOMAIN_BUS_PCI_DEVICE_MSI))
355 		return true;
356 	if (pci_match_device_domain(pdev, DOMAIN_BUS_PCI_DEVICE_MSIX))
357 		msi_remove_device_irq_domain(&pdev->dev, MSI_DEFAULT_DOMAIN);
358 
359 	return pci_create_device_domain(pdev, &pci_msi_template, hwsize);
360 }
361 
362 /**
363  * pci_setup_msix_device_domain - Setup a device MSI-X interrupt domain
364  * @pdev:	The PCI device to create the domain on
365  * @hwsize:	The size of the MSI-X vector table
366  *
367  * Return:
368  *  True when:
369  *	- The device does not have a MSI parent irq domain associated,
370  *	  which keeps the legacy architecture specific and the global
371  *	  PCI/MSI domain models working
372  *	- The MSI-X domain exists already
373  *	- The MSI-X domain was successfully allocated
374  *  False when:
375  *	- MSI is enabled
376  *	- The domain creation fails.
377  *
378  * The created MSI-X domain is preserved until:
379  *	- The device is removed
380  *	- MSI-X is disabled and a MSI domain is created
381  */
382 bool pci_setup_msix_device_domain(struct pci_dev *pdev, unsigned int hwsize)
383 {
384 	if (WARN_ON_ONCE(pdev->msi_enabled))
385 		return false;
386 
387 	if (pci_match_device_domain(pdev, DOMAIN_BUS_PCI_DEVICE_MSIX))
388 		return true;
389 	if (pci_match_device_domain(pdev, DOMAIN_BUS_PCI_DEVICE_MSI))
390 		msi_remove_device_irq_domain(&pdev->dev, MSI_DEFAULT_DOMAIN);
391 
392 	return pci_create_device_domain(pdev, &pci_msix_template, hwsize);
393 }
394 
395 /**
396  * pci_msi_domain_supports - Check for support of a particular feature flag
397  * @pdev:		The PCI device to operate on
398  * @feature_mask:	The feature mask to check for (full match)
399  * @mode:		If ALLOW_LEGACY this grants the feature when there is no irq domain
400  *			associated to the device. If DENY_LEGACY the lack of an irq domain
401  *			makes the feature unsupported
402  */
403 bool pci_msi_domain_supports(struct pci_dev *pdev, unsigned int feature_mask,
404 			     enum support_mode mode)
405 {
406 	struct msi_domain_info *info;
407 	struct irq_domain *domain;
408 	unsigned int supported;
409 
410 	domain = dev_get_msi_domain(&pdev->dev);
411 
412 	if (!domain || !irq_domain_is_hierarchy(domain)) {
413 		if (IS_ENABLED(CONFIG_PCI_MSI_ARCH_FALLBACKS))
414 			return mode == ALLOW_LEGACY;
415 		return false;
416 	}
417 
418 	if (!irq_domain_is_msi_parent(domain)) {
419 		/*
420 		 * For "global" PCI/MSI interrupt domains the associated
421 		 * msi_domain_info::flags is the authoritative source of
422 		 * information.
423 		 */
424 		info = domain->host_data;
425 		supported = info->flags;
426 	} else {
427 		/*
428 		 * For MSI parent domains the supported feature set
429 		 * is available in the parent ops. This makes checks
430 		 * possible before actually instantiating the
431 		 * per device domain because the parent is never
432 		 * expanding the PCI/MSI functionality.
433 		 */
434 		supported = domain->msi_parent_ops->supported_flags;
435 	}
436 
437 	return (supported & feature_mask) == feature_mask;
438 }
439 
440 /*
441  * Users of the generic MSI infrastructure expect a device to have a single ID,
442  * so with DMA aliases we have to pick the least-worst compromise. Devices with
443  * DMA phantom functions tend to still emit MSIs from the real function number,
444  * so we ignore those and only consider topological aliases where either the
445  * alias device or RID appears on a different bus number. We also make the
446  * reasonable assumption that bridges are walked in an upstream direction (so
447  * the last one seen wins), and the much braver assumption that the most likely
448  * case is that of PCI->PCIe so we should always use the alias RID. This echoes
449  * the logic from intel_irq_remapping's set_msi_sid(), which presumably works
450  * well enough in practice; in the face of the horrible PCIe<->PCI-X conditions
451  * for taking ownership all we can really do is close our eyes and hope...
452  */
453 static int get_msi_id_cb(struct pci_dev *pdev, u16 alias, void *data)
454 {
455 	u32 *pa = data;
456 	u8 bus = PCI_BUS_NUM(*pa);
457 
458 	if (pdev->bus->number != bus || PCI_BUS_NUM(alias) != bus)
459 		*pa = alias;
460 
461 	return 0;
462 }
463 
464 /**
465  * pci_msi_domain_get_msi_rid - Get the MSI requester id (RID)
466  * @domain:	The interrupt domain
467  * @pdev:	The PCI device.
468  *
469  * The RID for a device is formed from the alias, with a firmware
470  * supplied mapping applied
471  *
472  * Returns: The RID.
473  */
474 u32 pci_msi_domain_get_msi_rid(struct irq_domain *domain, struct pci_dev *pdev)
475 {
476 	struct device_node *of_node;
477 	u32 rid = pci_dev_id(pdev);
478 
479 	pci_for_each_dma_alias(pdev, get_msi_id_cb, &rid);
480 
481 	of_node = irq_domain_get_of_node(domain);
482 	rid = of_node ? of_msi_map_id(&pdev->dev, of_node, rid) :
483 			iort_msi_map_id(&pdev->dev, rid);
484 
485 	return rid;
486 }
487 
488 /**
489  * pci_msi_map_rid_ctlr_node - Get the MSI controller node and MSI requester id (RID)
490  * @pdev:	The PCI device
491  * @node:	Pointer to store the MSI controller device node
492  *
493  * Use the firmware data to find the MSI controller node for @pdev.
494  * If found map the RID and initialize @node with it. @node value must
495  * be set to NULL on entry.
496  *
497  * Returns: The RID.
498  */
499 u32 pci_msi_map_rid_ctlr_node(struct pci_dev *pdev, struct device_node **node)
500 {
501 	u32 rid = pci_dev_id(pdev);
502 
503 	pci_for_each_dma_alias(pdev, get_msi_id_cb, &rid);
504 
505 	return of_msi_xlate(&pdev->dev, node, rid);
506 }
507 
508 /**
509  * pci_msi_get_device_domain - Get the MSI domain for a given PCI device
510  * @pdev:	The PCI device
511  *
512  * Use the firmware data to find a device-specific MSI domain
513  * (i.e. not one that is set as a default).
514  *
515  * Returns: The corresponding MSI domain or NULL if none has been found.
516  */
517 struct irq_domain *pci_msi_get_device_domain(struct pci_dev *pdev)
518 {
519 	struct irq_domain *dom;
520 	u32 rid = pci_dev_id(pdev);
521 
522 	pci_for_each_dma_alias(pdev, get_msi_id_cb, &rid);
523 	dom = of_msi_map_get_device_domain(&pdev->dev, rid, DOMAIN_BUS_PCI_MSI);
524 	if (!dom)
525 		dom = iort_get_device_domain(&pdev->dev, rid,
526 					     DOMAIN_BUS_PCI_MSI);
527 	return dom;
528 }
529