| /kernel/linux/linux-5.10/drivers/net/ethernet/pensando/ionic/ |
| D | ionic_bus_pci.c | 50 struct ionic_dev_bar *bars; in ionic_map_bars() local 53 bars = ionic->bars; in ionic_map_bars() 59 bars[j].len = pci_resource_len(pdev, i); in ionic_map_bars() 63 bars[j].vaddr = NULL; in ionic_map_bars() 65 bars[j].vaddr = pci_iomap(pdev, i, bars[j].len); in ionic_map_bars() 66 if (!bars[j].vaddr) { in ionic_map_bars() 74 bars[j].bus_addr = pci_resource_start(pdev, i); in ionic_map_bars() 75 bars[j].res_index = i; in ionic_map_bars() 85 struct ionic_dev_bar *bars = ionic->bars; in ionic_unmap_bars() local 89 if (bars[i].vaddr) { in ionic_unmap_bars() [all …]
|
| /kernel/linux/linux-6.6/drivers/net/ethernet/pensando/ionic/ |
| D | ionic_bus_pci.c | 50 struct ionic_dev_bar *bars; in ionic_map_bars() local 53 bars = ionic->bars; in ionic_map_bars() 59 bars[j].len = pci_resource_len(pdev, i); in ionic_map_bars() 63 bars[j].vaddr = NULL; in ionic_map_bars() 65 bars[j].vaddr = pci_iomap(pdev, i, bars[j].len); in ionic_map_bars() 66 if (!bars[j].vaddr) { in ionic_map_bars() 74 bars[j].bus_addr = pci_resource_start(pdev, i); in ionic_map_bars() 75 bars[j].res_index = i; in ionic_map_bars() 85 struct ionic_dev_bar *bars = ionic->bars; in ionic_unmap_bars() local 89 if (bars[i].vaddr) { in ionic_unmap_bars() [all …]
|
| /kernel/linux/linux-5.10/drivers/ide/ |
| D | setup-pci.c | 26 * we succeed the BARs are ok and the controller is in PCI mode. 29 * FIXME: if we program the interface and then fail to set the BARS 182 * @bars: PCI BARs mask 193 static int ide_pci_enable(struct pci_dev *dev, int bars, in ide_pci_enable() argument 221 ret = pci_request_selected_regions(dev, bars, d->name); in ide_pci_enable() 331 printk(KERN_ERR "%s %s: bad PCI BARs for port %d, skipping\n", in ide_hw_configure() 396 * @bars: PCI BARs mask 405 static int ide_setup_pci_controller(struct pci_dev *dev, int bars, in ide_setup_pci_controller() argument 414 ret = ide_pci_enable(dev, bars, d); in ide_setup_pci_controller() 435 pci_release_selected_regions(dev, bars); in ide_setup_pci_controller() [all …]
|
| /kernel/linux/linux-6.6/drivers/net/ethernet/amd/pds_core/ |
| D | main.c | 37 struct pdsc_dev_bar *bars = pdsc->bars; in pdsc_unmap_bars() local 46 if (bars[i].vaddr) in pdsc_unmap_bars() 47 pci_iounmap(pdsc->pdev, bars[i].vaddr); in pdsc_unmap_bars() 53 struct pdsc_dev_bar *bar = pdsc->bars; in pdsc_map_bars() 56 struct pdsc_dev_bar *bars; in pdsc_map_bars() local 62 bars = pdsc->bars; in pdsc_map_bars() 65 * we need to poke into all the bars to find the set we're in pdsc_map_bars() 72 bars[j].len = pci_resource_len(pdev, i); in pdsc_map_bars() 73 bars[j].bus_addr = pci_resource_start(pdev, i); in pdsc_map_bars() 74 bars[j].res_index = i; in pdsc_map_bars() [all …]
|
| /kernel/linux/linux-6.6/Documentation/powerpc/ |
| D | pci_iov_resource_on_powernv.rst | 107 scheme where individual function BARs can be "grouped" to fit in one or 127 for large BARs in 64-bit space: 156 PE" mode to overlay over specific BARs to work around some of that, for 157 example for devices with very large BARs, e.g., GPUs. It would make 170 PCI devices, but the BARs in VF config space headers are unusual. For 171 a non-VF device, software uses BARs in the config space header to 174 discover sizes and assign addresses. The BARs in the VF's config space 178 base address for all the corresponding VF(n) BARs. For example, if the 190 window with 1MB segments. VF BARs that are 1MB or larger could be 193 flexible, but it works best when all the VF BARs are the same size. If [all …]
|
| /kernel/linux/linux-5.10/Documentation/powerpc/ |
| D | pci_iov_resource_on_powernv.rst | 107 scheme where individual function BARs can be "grouped" to fit in one or 127 for large BARs in 64-bit space: 156 PE" mode to overlay over specific BARs to work around some of that, for 157 example for devices with very large BARs, e.g., GPUs. It would make 170 PCI devices, but the BARs in VF config space headers are unusual. For 171 a non-VF device, software uses BARs in the config space header to 174 discover sizes and assign addresses. The BARs in the VF's config space 178 base address for all the corresponding VF(n) BARs. For example, if the 190 window with 1MB segments. VF BARs that are 1MB or larger could be 193 flexible, but it works best when all the VF BARs are the same size. If [all …]
|
| /kernel/linux/linux-5.10/drivers/misc/habanalabs/common/ |
| D | pci.c | 21 * hl_pci_bars_map() - Map PCI BARs. 43 bar = i * 2; /* 64-bit BARs */ in hl_pci_bars_map() 59 bar = i * 2; /* 64-bit BARs */ in hl_pci_bars_map() 70 * hl_pci_bars_unmap() - Unmap PCI BARS. 73 * Release all PCI BARs and unmap their virtual addresses. 81 bar = i * 2; /* 64-bit BARs */ in hl_pci_bars_unmap() 352 * Set DMA masks, initialize the PCI controller and map the PCI BARs. 375 dev_err(hdev->dev, "Failed to initialize PCI BARs\n"); in hl_pci_init() 413 * Unmap PCI bars and disable PCI device.
|
| /kernel/linux/linux-5.10/arch/s390/pci/ |
| D | pci.c | 297 idx = zdev->bars[bar].map_idx; in pci_iomap_range_fh() 316 iova = ioremap((unsigned long) zdev->bars[bar].mio_wt, barsize); in pci_iomap_range_mio() 346 iova = ioremap((unsigned long) zdev->bars[bar].mio_wb, barsize); in pci_iomap_wc_range_mio() 431 (resource_size_t __force) zdev->bars[i].mio_wt; in zpci_map_resources() 514 if (!zdev->bars[i].size) in zpci_setup_bus_resources() 519 zdev->bars[i].map_idx = entry; in zpci_setup_bus_resources() 523 if (zdev->bars[i].val & 8) in zpci_setup_bus_resources() 525 if (zdev->bars[i].val & 4) in zpci_setup_bus_resources() 529 addr = (unsigned long) zdev->bars[i].mio_wt; in zpci_setup_bus_resources() 532 size = 1UL << zdev->bars[i].size; in zpci_setup_bus_resources() [all …]
|
| /kernel/linux/linux-6.6/drivers/accel/habanalabs/common/pci/ |
| D | pci.c | 23 * hl_pci_bars_map() - Map PCI BARs. 45 bar = i * 2; /* 64-bit BARs */ in hl_pci_bars_map() 61 bar = i * 2; /* 64-bit BARs */ in hl_pci_bars_map() 72 * hl_pci_bars_unmap() - Unmap PCI BARS. 75 * Release all PCI BARs and unmap their virtual addresses. 83 bar = i * 2; /* 64-bit BARs */ in hl_pci_bars_unmap() 374 * Set DMA masks, initialize the PCI controller and map the PCI BARs. 432 * Unmap PCI bars and disable PCI device.
|
| /kernel/linux/linux-6.6/drivers/mfd/ |
| D | sta2x11-mfd.c | 520 struct sta2x11_mfd_bar_setup_data bars[2]; member 529 .bars = { 542 .bars = { 559 for (i = 0; i < ARRAY_SIZE(sd->bars); i++) in sta2x11_mfd_setup() 560 for (j = 0; j < sd->bars[i].ncells; j++) { in sta2x11_mfd_setup() 561 sd->bars[i].cells[j].pdata_size = sizeof(pdev); in sta2x11_mfd_setup() 562 sd->bars[i].cells[j].platform_data = &pdev; in sta2x11_mfd_setup() 595 /* Just 2 bars for all mfd's at present */ in sta2x11_mfd_probe() 598 setup_data->bars[i].cells, in sta2x11_mfd_probe() 599 setup_data->bars[i].ncells, in sta2x11_mfd_probe()
|
| /kernel/linux/linux-5.10/drivers/mfd/ |
| D | sta2x11-mfd.c | 520 struct sta2x11_mfd_bar_setup_data bars[2]; member 529 .bars = { 542 .bars = { 559 for (i = 0; i < ARRAY_SIZE(sd->bars); i++) in sta2x11_mfd_setup() 560 for (j = 0; j < sd->bars[i].ncells; j++) { in sta2x11_mfd_setup() 561 sd->bars[i].cells[j].pdata_size = sizeof(pdev); in sta2x11_mfd_setup() 562 sd->bars[i].cells[j].platform_data = &pdev; in sta2x11_mfd_setup() 595 /* Just 2 bars for all mfd's at present */ in sta2x11_mfd_probe() 598 setup_data->bars[i].cells, in sta2x11_mfd_probe() 599 setup_data->bars[i].ncells, in sta2x11_mfd_probe()
|
| /kernel/linux/linux-6.6/arch/s390/pci/ |
| D | pci.c | 276 idx = zdev->bars[bar].map_idx; in pci_iomap_range_fh() 295 iova = ioremap((unsigned long) zdev->bars[bar].mio_wt, barsize); in pci_iomap_range_mio() 325 iova = ioremap((unsigned long) zdev->bars[bar].mio_wb, barsize); in pci_iomap_wc_range_mio() 410 (resource_size_t __force) zdev->bars[i].mio_wt; in zpci_map_resources() 467 if (!zdev->bars[bar].size) in zpci_do_update_iomap_fh() 469 idx = zdev->bars[bar].map_idx; in zpci_do_update_iomap_fh() 520 if (!zdev->bars[i].size) in zpci_setup_bus_resources() 525 zdev->bars[i].map_idx = entry; in zpci_setup_bus_resources() 529 if (zdev->bars[i].val & 8) in zpci_setup_bus_resources() 531 if (zdev->bars[i].val & 4) in zpci_setup_bus_resources() [all …]
|
| /kernel/linux/linux-6.6/drivers/scsi/csiostor/ |
| D | csio_init.c | 184 * @bars: Bitmask of bars to be requested. 190 csio_pci_init(struct pci_dev *pdev, int *bars) in csio_pci_init() argument 194 *bars = pci_select_bars(pdev, IORESOURCE_MEM); in csio_pci_init() 199 if (pci_request_selected_regions(pdev, *bars, KBUILD_MODNAME)) in csio_pci_init() 217 pci_release_selected_regions(pdev, *bars); in csio_pci_init() 228 * @bars: Bars to be released. 232 csio_pci_exit(struct pci_dev *pdev, int *bars) in csio_pci_exit() argument 234 pci_release_selected_regions(pdev, *bars); in csio_pci_exit() 512 * Allocates HW structure, DMA, memory resources, maps BARS to 929 * - Allocates HW structure, DMA, memory resources, maps BARS to [all …]
|
| /kernel/linux/linux-5.10/drivers/scsi/csiostor/ |
| D | csio_init.c | 185 * @bars: Bitmask of bars to be requested. 191 csio_pci_init(struct pci_dev *pdev, int *bars) in csio_pci_init() argument 195 *bars = pci_select_bars(pdev, IORESOURCE_MEM); in csio_pci_init() 200 if (pci_request_selected_regions(pdev, *bars, KBUILD_MODNAME)) in csio_pci_init() 218 pci_release_selected_regions(pdev, *bars); in csio_pci_init() 229 * @bars: Bars to be released. 233 csio_pci_exit(struct pci_dev *pdev, int *bars) in csio_pci_exit() argument 235 pci_release_selected_regions(pdev, *bars); in csio_pci_exit() 513 * Allocates HW structure, DMA, memory resources, maps BARS to 930 * - Allocates HW structure, DMA, memory resources, maps BARS to [all …]
|
| /kernel/linux/linux-5.10/arch/powerpc/platforms/powernv/ |
| D | pci-sriov.c | 24 * For conventional PCI devices this isn't really an issue since PCI device BARs 32 * allocate the SR-IOV BARs in a way that lets us map them using the MBT. 48 * (num-vfs * num-sriov-bars) in total. To use a) we need the size of each segment 59 * At this point the device has been probed and the device's BARs are sized, 60 * but no resource allocations have been done. The SR-IOV BARs are sized 66 * sorts the BARs on a bus by their required alignment, which is calculated 112 * it only usable for devices with very large per-VF BARs. Such devices are 126 * us to support SR-IOV BARs in the 32bit MMIO window. This is useful since 218 /* Save ourselves some MMIO space by disabling the unusable BARs */ in pnv_pci_ioda_fixup_iov_resources() 264 * BARs would not be placed in the correct PE. in pnv_pci_iov_resource_alignment() [all …]
|
| /kernel/linux/linux-6.6/arch/powerpc/platforms/powernv/ |
| D | pci-sriov.c | 21 * For conventional PCI devices this isn't really an issue since PCI device BARs 29 * allocate the SR-IOV BARs in a way that lets us map them using the MBT. 45 * (num-vfs * num-sriov-bars) in total. To use a) we need the size of each segment 56 * At this point the device has been probed and the device's BARs are sized, 57 * but no resource allocations have been done. The SR-IOV BARs are sized 63 * sorts the BARs on a bus by their required alignment, which is calculated 109 * it only usable for devices with very large per-VF BARs. Such devices are 123 * us to support SR-IOV BARs in the 32bit MMIO window. This is useful since 215 /* Save ourselves some MMIO space by disabling the unusable BARs */ in pnv_pci_ioda_fixup_iov_resources() 258 * BARs would not be placed in the correct PE. in pnv_pci_iov_resource_alignment() [all …]
|
| /kernel/linux/linux-6.6/drivers/net/ethernet/netronome/nfp/nfpcore/ |
| D | nfp6000_pcie.c | 10 * Multiplexes the NFP BARs between NFP internal resources and 13 * The BARs are managed with refcounts and are allocated/acquired 106 /* The number of explicit BARs to reserve. 149 int bars; member 347 /* We don't match explicit bars through the area interface */ in matching_bar() 372 for (n = 0; n < nfp->bars; n++) { in find_matching_bar() 390 for (n = 0; n < nfp->bars; n++) { in find_unused_bar_noblock() 519 /* Map all PCI bars and fetch the actual BAR configurations from the 566 snprintf(status_msg, sizeof(status_msg) - 1, "RESERVED BARs: "); in enable_bars() 575 /* Skip over BARs that are not IORESOURCE_MEM */ in enable_bars() [all …]
|
| /kernel/linux/linux-5.10/drivers/net/ethernet/netronome/nfp/nfpcore/ |
| D | nfp6000_pcie.c | 10 * Multiplexes the NFP BARs between NFP internal resources and 13 * The BARs are managed with refcounts and are allocated/acquired 109 /* The number of explicit BARs to reserve. 151 int bars; member 352 /* We don't match explicit bars through the area interface */ in matching_bar() 377 for (n = 0; n < nfp->bars; n++) { in find_matching_bar() 395 for (n = 0; n < nfp->bars; n++) { in find_unused_bar_noblock() 524 /* Map all PCI bars and fetch the actual BAR configurations from the 569 snprintf(status_msg, sizeof(status_msg) - 1, "RESERVED BARs: "); in enable_bars() 578 /* Skip over BARs that are not IORESOURCE_MEM */ in enable_bars() [all …]
|
| /kernel/linux/linux-6.6/Documentation/gpu/amdgpu/display/ |
| D | dc-debug.rst | 9 bars added at the scanout time by the driver to convey some specific 33 * Pipe split can be observed if there are two bars with a difference in height 38 feature one or two green bars at the bottom of the video depending on pipe
|
| /kernel/linux/linux-5.10/lib/ |
| D | devres.c | 404 * pcim_iomap_regions - Request and iomap PCI BARs 406 * @mask: Mask of BARs to request and iomap 457 * pcim_iomap_regions_request_all - Request all BARs and iomap specified ones 459 * @mask: Mask of BARs to iomap 462 * Request all PCI BARs and iomap regions specified by @mask. 482 * pcim_iounmap_regions - Unmap and release PCI BARs 484 * @mask: Mask of BARs to unmap and release
|
| /kernel/linux/linux-6.6/drivers/ntb/hw/idt/ |
| D | Kconfig | 18 and SWPORTxCTL registers). Then all NT-function BARs must be enabled 19 with chosen valid aperture. For memory windows related BARs the
|
| /kernel/linux/linux-5.10/drivers/ntb/hw/idt/ |
| D | Kconfig | 18 and SWPORTxCTL registers). Then all NT-function BARs must be enabled 19 with chosen valid aperture. For memory windows related BARs the
|
| /kernel/linux/linux-6.6/lib/ |
| D | devres.c | 416 * pcim_iomap_regions - Request and iomap PCI BARs 418 * @mask: Mask of BARs to request and iomap 469 * pcim_iomap_regions_request_all - Request all BARs and iomap specified ones 471 * @mask: Mask of BARs to iomap 474 * Request all PCI BARs and iomap regions specified by @mask. 494 * pcim_iounmap_regions - Unmap and release PCI BARs 496 * @mask: Mask of BARs to unmap and release
|
| /kernel/linux/linux-6.6/Documentation/PCI/endpoint/ |
| D | pci-ntb-function.rst | 12 machine, expose memory ranges as BARs, and perform DMA. They also support 230 one is permitted. All these regions should be mapped to BARs for hosts to 248 be enough BARs for all the regions in a platform that supports only 64-bit 249 BARs. 252 packed and mapped to BARs in a way that provides NTB functionality and 269 With this scheme, for the basic NTB functionality 3 BARs should be sufficient. 339 space. Allocating and configuring BARs for doorbell and memory window1 348 is mapped to separate BARs.
|
| /kernel/linux/linux-6.6/drivers/pci/ |
| D | setup-res.c | 34 /* Per SR-IOV spec 3.4.1.11, VF BARs are RO zero */ in pci_std_update_resource() 39 * Ignore resources for unimplemented BARs and unused resource slots in pci_std_update_resource() 40 * for 64 bit BARs. in pci_std_update_resource() 74 * Apparently some Matrox devices have ROM BARs that read in pci_std_update_resource() 75 * as zero when disabled, so don't update ROM BARs unless in pci_std_update_resource() 79 * disabled ROM can conflict with other BARs. in pci_std_update_resource()
|