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