/linux-6.6.21/drivers/pci/endpoint/ |
D | pci-epc-core.c | 147 u8 func_no, u8 vfunc_no) in pci_epc_get_features() argument 151 if (IS_ERR_OR_NULL(epc) || func_no >= epc->max_functions) in pci_epc_get_features() 154 if (vfunc_no > 0 && (!epc->max_vfs || vfunc_no > epc->max_vfs[func_no])) in pci_epc_get_features() 161 epc_features = epc->ops->get_features(epc, func_no, vfunc_no); in pci_epc_get_features() 219 int pci_epc_raise_irq(struct pci_epc *epc, u8 func_no, u8 vfunc_no, in pci_epc_raise_irq() argument 224 if (IS_ERR_OR_NULL(epc) || func_no >= epc->max_functions) in pci_epc_raise_irq() 227 if (vfunc_no > 0 && (!epc->max_vfs || vfunc_no > epc->max_vfs[func_no])) in pci_epc_raise_irq() 234 ret = epc->ops->raise_irq(epc, func_no, vfunc_no, type, interrupt_num); in pci_epc_raise_irq() 262 int pci_epc_map_msi_irq(struct pci_epc *epc, u8 func_no, u8 vfunc_no, in pci_epc_map_msi_irq() argument 271 if (vfunc_no > 0 && (!epc->max_vfs || vfunc_no > epc->max_vfs[func_no])) in pci_epc_map_msi_irq() [all …]
|
D | pci-epf-core.c | 63 u8 func_no, vfunc_no; in pci_epf_bind() local 86 func_no = epf->func_no; in pci_epf_bind() 94 if (vfunc_no > epc->max_vfs[func_no]) { in pci_epf_bind() 96 func_no); in pci_epf_bind() 103 func_no = epf->sec_epc_func_no; in pci_epf_bind() 111 if (vfunc_no > epc->max_vfs[func_no]) { in pci_epf_bind() 113 func_no); in pci_epf_bind() 119 epf_vf->func_no = epf->func_no; in pci_epf_bind()
|
/linux-6.6.21/drivers/pci/controller/dwc/ |
D | pcie-designware-ep.c | 34 dw_pcie_ep_get_func_from_ep(struct dw_pcie_ep *ep, u8 func_no) in dw_pcie_ep_get_func_from_ep() argument 39 if (ep_func->func_no == func_no) in dw_pcie_ep_get_func_from_ep() 46 static unsigned int dw_pcie_ep_func_select(struct dw_pcie_ep *ep, u8 func_no) in dw_pcie_ep_func_select() argument 51 func_offset = ep->ops->func_conf_select(ep, func_no); in dw_pcie_ep_func_select() 56 static void __dw_pcie_ep_reset_bar(struct dw_pcie *pci, u8 func_no, in __dw_pcie_ep_reset_bar() argument 63 func_offset = dw_pcie_ep_func_select(ep, func_no); in __dw_pcie_ep_reset_bar() 78 u8 func_no, funcs; in dw_pcie_ep_reset_bar() local 82 for (func_no = 0; func_no < funcs; func_no++) in dw_pcie_ep_reset_bar() 83 __dw_pcie_ep_reset_bar(pci, func_no, bar, 0); in dw_pcie_ep_reset_bar() 87 static u8 __dw_pcie_ep_find_next_cap(struct dw_pcie_ep *ep, u8 func_no, in __dw_pcie_ep_find_next_cap() argument [all …]
|
D | pcie-designware.h | 333 int (*raise_irq)(struct dw_pcie_ep *ep, u8 func_no, 343 unsigned int (*func_conf_select)(struct dw_pcie_ep *ep, u8 func_no); 348 u8 func_no; member 434 int dw_pcie_prog_ep_outbound_atu(struct dw_pcie *pci, u8 func_no, int index, 438 int dw_pcie_prog_ep_inbound_atu(struct dw_pcie *pci, u8 func_no, int index, 578 int dw_pcie_ep_raise_legacy_irq(struct dw_pcie_ep *ep, u8 func_no); 579 int dw_pcie_ep_raise_msi_irq(struct dw_pcie_ep *ep, u8 func_no, 581 int dw_pcie_ep_raise_msix_irq(struct dw_pcie_ep *ep, u8 func_no, 583 int dw_pcie_ep_raise_msix_irq_doorbell(struct dw_pcie_ep *ep, u8 func_no, 587 dw_pcie_ep_get_func_from_ep(struct dw_pcie_ep *ep, u8 func_no); [all …]
|
D | pci-layerscape-ep.c | 168 static int ls_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in ls_pcie_ep_raise_irq() argument 175 return dw_pcie_ep_raise_legacy_irq(ep, func_no); in ls_pcie_ep_raise_irq() 177 return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in ls_pcie_ep_raise_irq() 179 return dw_pcie_ep_raise_msix_irq_doorbell(ep, func_no, in ls_pcie_ep_raise_irq() 188 u8 func_no) in ls_pcie_ep_func_conf_select() argument 193 WARN_ON(func_no && !pcie->drvdata->func_offset); in ls_pcie_ep_func_conf_select() 194 return pcie->drvdata->func_offset * func_no; in ls_pcie_ep_func_conf_select()
|
D | pcie-designware-plat.c | 44 static int dw_plat_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in dw_plat_pcie_ep_raise_irq() argument 52 return dw_pcie_ep_raise_legacy_irq(ep, func_no); in dw_plat_pcie_ep_raise_irq() 54 return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in dw_plat_pcie_ep_raise_irq() 56 return dw_pcie_ep_raise_msix_irq(ep, func_no, interrupt_num); in dw_plat_pcie_ep_raise_irq()
|
D | pcie-uniphier-ep.c | 241 u8 func_no, u16 interrupt_num) in uniphier_pcie_ep_raise_msi_irq() argument 247 val = FIELD_PREP(PCL_APP_VEN_MSI_TC_MASK, func_no) in uniphier_pcie_ep_raise_msi_irq() 258 static int uniphier_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in uniphier_pcie_ep_raise_irq() argument 268 return uniphier_pcie_ep_raise_msi_irq(ep, func_no, in uniphier_pcie_ep_raise_irq()
|
D | pcie-keembay.c | 291 static int keembay_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in keembay_pcie_ep_raise_irq() argument 303 return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in keembay_pcie_ep_raise_irq() 305 return dw_pcie_ep_raise_msix_irq(ep, func_no, interrupt_num); in keembay_pcie_ep_raise_irq()
|
D | pcie-designware.c | 467 static int __dw_pcie_prog_outbound_atu(struct dw_pcie *pci, u8 func_no, in __dw_pcie_prog_outbound_atu() argument 501 val = type | PCIE_ATU_FUNC_NUM(func_no); in __dw_pcie_prog_outbound_atu() 535 int dw_pcie_prog_ep_outbound_atu(struct dw_pcie *pci, u8 func_no, int index, in dw_pcie_prog_ep_outbound_atu() argument 539 return __dw_pcie_prog_outbound_atu(pci, func_no, index, type, in dw_pcie_prog_ep_outbound_atu() 606 int dw_pcie_prog_ep_inbound_atu(struct dw_pcie *pci, u8 func_no, int index, in dw_pcie_prog_ep_inbound_atu() argument 620 PCIE_ATU_FUNC_NUM(func_no)); in dw_pcie_prog_ep_inbound_atu()
|
D | pcie-artpec6.c | 354 static int artpec6_pcie_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in artpec6_pcie_raise_irq() argument 364 return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in artpec6_pcie_raise_irq()
|
D | pcie-qcom-ep.c | 747 static int qcom_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in qcom_pcie_ep_raise_irq() argument 754 return dw_pcie_ep_raise_legacy_irq(ep, func_no); in qcom_pcie_ep_raise_irq() 756 return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in qcom_pcie_ep_raise_irq()
|
D | pci-imx6.c | 1060 static int imx6_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in imx6_pcie_ep_raise_irq() argument 1068 return dw_pcie_ep_raise_legacy_irq(ep, func_no); in imx6_pcie_ep_raise_irq() 1070 return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in imx6_pcie_ep_raise_irq() 1072 return dw_pcie_ep_raise_msix_irq(ep, func_no, interrupt_num); in imx6_pcie_ep_raise_irq()
|
D | pci-keystone.c | 902 static int ks_pcie_am654_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in ks_pcie_am654_raise_irq() argument 914 dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num); in ks_pcie_am654_raise_irq() 917 dw_pcie_ep_raise_msix_irq(ep, func_no, interrupt_num); in ks_pcie_am654_raise_irq()
|
D | pci-dra7xx.c | 406 static int dra7xx_pcie_raise_irq(struct dw_pcie_ep *ep, u8 func_no, in dra7xx_pcie_raise_irq() argument
|
/linux-6.6.21/include/linux/ |
D | pci-epc.h | 65 int (*write_header)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 67 int (*set_bar)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 69 void (*clear_bar)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 71 int (*map_addr)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 73 void (*unmap_addr)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 75 int (*set_msi)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 77 int (*get_msi)(struct pci_epc *epc, u8 func_no, u8 vfunc_no); 78 int (*set_msix)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, 80 int (*get_msix)(struct pci_epc *epc, u8 func_no, u8 vfunc_no); 81 int (*raise_irq)(struct pci_epc *epc, u8 func_no, u8 vfunc_no, [all …]
|
D | pci-epf.h | 161 u8 func_no; member
|
/linux-6.6.21/drivers/pci/endpoint/functions/ |
D | pci-epf-ntb.c | 89 u8 func_no; member 147 u8 func_no, vfunc_no; in epf_ntb_link_up() local 154 func_no = ntb_epc->func_no; in epf_ntb_link_up() 163 ret = pci_epc_raise_irq(epc, func_no, vfunc_no, irq_type, 1); in epf_ntb_link_up() 243 u8 func_no, vfunc_no; in epf_ntb_configure_mw() local 271 func_no = ntb_epc->func_no; in epf_ntb_configure_mw() 274 ret = pci_epc_map_addr(epc, func_no, vfunc_no, phys_addr, addr, size); in epf_ntb_configure_mw() 302 u8 func_no, vfunc_no; in epf_ntb_teardown_mw() local 316 func_no = ntb_epc->func_no; in epf_ntb_teardown_mw() 319 pci_epc_unmap_addr(epc, func_no, vfunc_no, phys_addr); in epf_ntb_teardown_mw() [all …]
|
D | pci-epf-vntb.c | 205 u8 func_no, vfunc_no; in epf_ntb_configure_mw() local 213 func_no = ntb->epf->func_no; in epf_ntb_configure_mw() 216 ret = pci_epc_map_addr(ntb->epf->epc, func_no, vfunc_no, phys_addr, addr, size); in epf_ntb_configure_mw() 234 ntb->epf->func_no, in epf_ntb_teardown_mw() 348 pci_epc_clear_bar(ntb->epf->epc, ntb->epf->func_no, ntb->epf->vfunc_no, epf_bar); in epf_ntb_config_sspad_bar_clear() 367 u8 func_no, vfunc_no; in epf_ntb_config_sspad_bar_set() local 372 func_no = ntb->epf->func_no; in epf_ntb_config_sspad_bar_set() 377 ret = pci_epc_set_bar(ntb->epf->epc, func_no, vfunc_no, epf_bar); in epf_ntb_config_sspad_bar_set() 422 epf->func_no, in epf_ntb_config_spad_bar_alloc() 492 epc_features = pci_epc_get_features(ntb->epf->epc, ntb->epf->func_no, ntb->epf->vfunc_no); in epf_ntb_configure_interrupt() [all …]
|
D | pci-epf-test.c | 338 ret = pci_epc_map_addr(epc, epf->func_no, epf->vfunc_no, src_phys_addr, in pci_epf_test_copy() 354 ret = pci_epc_map_addr(epc, epf->func_no, epf->vfunc_no, dst_phys_addr, in pci_epf_test_copy() 393 pci_epc_unmap_addr(epc, epf->func_no, epf->vfunc_no, dst_phys_addr); in pci_epf_test_copy() 399 pci_epc_unmap_addr(epc, epf->func_no, epf->vfunc_no, src_phys_addr); in pci_epf_test_copy() 434 ret = pci_epc_map_addr(epc, epf->func_no, epf->vfunc_no, phys_addr, in pci_epf_test_read() 484 pci_epc_unmap_addr(epc, epf->func_no, epf->vfunc_no, phys_addr); in pci_epf_test_read() 518 ret = pci_epc_map_addr(epc, epf->func_no, epf->vfunc_no, phys_addr, in pci_epf_test_write() 575 pci_epc_unmap_addr(epc, epf->func_no, epf->vfunc_no, phys_addr); in pci_epf_test_write() 604 pci_epc_raise_irq(epc, epf->func_no, epf->vfunc_no, in pci_epf_test_raise_irq() 608 count = pci_epc_get_msi(epc, epf->func_no, epf->vfunc_no); in pci_epf_test_raise_irq() [all …]
|
D | pci-epf-mhi.c | 149 ret = pci_epc_map_addr(epc, epf->func_no, epf->vfunc_no, *paddr, in __pci_epf_mhi_alloc_map() 182 pci_epc_unmap_addr(epc, epf->func_no, epf->vfunc_no, paddr - offset); in __pci_epf_mhi_unmap_free() 208 pci_epc_raise_irq(epc, epf->func_no, epf->vfunc_no, PCI_EPC_IRQ_MSI, in pci_epf_mhi_raise_irq() 485 ret = pci_epc_set_bar(epc, epf->func_no, epf->vfunc_no, epf_bar); in pci_epf_mhi_core_init() 491 ret = pci_epc_set_msi(epc, epf->func_no, epf->vfunc_no, in pci_epf_mhi_core_init() 498 ret = pci_epc_write_header(epc, epf->func_no, epf->vfunc_no, in pci_epf_mhi_core_init() 505 epf_mhi->epc_features = pci_epc_get_features(epc, epf->func_no, epf->vfunc_no); in pci_epf_mhi_core_init() 648 pci_epc_clear_bar(epc, epf->func_no, epf->vfunc_no, epf_bar); in pci_epf_mhi_unbind()
|
/linux-6.6.21/drivers/pci/controller/cadence/ |
D | pcie-cadence-ep.c | 270 static int cdns_pcie_ep_get_msix(struct pci_epc *epc, u8 func_no, u8 vfunc_no) in cdns_pcie_ep_get_msix() argument 277 func_no = cdns_pcie_get_fn_from_vfn(pcie, func_no, vfunc_no); in cdns_pcie_ep_get_msix() 280 val = cdns_pcie_ep_fn_readw(pcie, func_no, reg); in cdns_pcie_ep_get_msix() 615 cdns_pcie_ep_get_features(struct pci_epc *epc, u8 func_no, u8 vfunc_no) in cdns_pcie_ep_get_features() argument
|
/linux-6.6.21/drivers/staging/rts5208/ |
D | rtsx_chip.c | 1349 int rtsx_write_cfg_dw(struct rtsx_chip *chip, u8 func_no, u16 addr, u32 mask, in rtsx_write_cfg_dw() argument 1380 ((func_no & 0x03) << 4)); in rtsx_write_cfg_dw() 1396 int rtsx_read_cfg_dw(struct rtsx_chip *chip, u8 func_no, u16 addr, u32 *val) in rtsx_read_cfg_dw() argument 1410 0x80 | ((func_no & 0x03) << 4)); in rtsx_read_cfg_dw() 1736 u8 func_no; in rtsx_handle_pm_dstate() local 1739 func_no = 2; in rtsx_handle_pm_dstate() 1741 func_no = 1; in rtsx_handle_pm_dstate() 1743 rtsx_read_cfg_dw(chip, func_no, 0x84, &ultmp); in rtsx_handle_pm_dstate() 1745 (int)func_no, ultmp); in rtsx_handle_pm_dstate() 1746 rtsx_write_cfg_dw(chip, func_no, 0x84, 0xFF, dstate); in rtsx_handle_pm_dstate()
|
D | rtsx_chip.h | 963 u8 func_no, u16 addr, u32 mask, u32 val); 964 int rtsx_read_cfg_dw(struct rtsx_chip *chip, u8 func_no, u16 addr, u32 *val);
|
/linux-6.6.21/drivers/pci/controller/ |
D | pcie-rcar-ep.c | 195 static int rcar_pcie_ep_set_bar(struct pci_epc *epc, u8 func_no, u8 vfunc_no, in rcar_pcie_ep_set_bar() argument 452 rcar_pcie_ep_get_features(struct pci_epc *epc, u8 func_no, u8 vfunc_no) in rcar_pcie_ep_get_features() argument
|
D | pcie-rockchip-ep.c | 434 cfg |= BIT(epf->func_no); in rockchip_pcie_ep_start() 449 rockchip_pcie_ep_get_features(struct pci_epc *epc, u8 func_no, u8 vfunc_no) in rockchip_pcie_ep_get_features() argument
|