Home
last modified time | relevance | path

Searched refs:pf (Results 1 – 25 of 591) sorted by relevance

12345678910>>...24

/linux-6.15/drivers/net/ethernet/netronome/nfp/
H A Dnfp_net_main.c303 pf->app = nfp_app_alloc(pf, nfp_net_pf_get_app_id(pf)); in nfp_net_pf_app_init()
350 nfp_net_pf_free_vnic(pf, pf->ctrl_vnic); in nfp_net_pf_app_clean()
368 err = nfp_net_pf_init_vnic(pf, pf->ctrl_vnic, 0); in nfp_net_pf_app_start_ctrl()
379 nfp_net_pf_clean_vnic(pf, pf->ctrl_vnic); in nfp_net_pf_app_start_ctrl()
388 nfp_net_pf_clean_vnic(pf, pf->ctrl_vnic); in nfp_net_pf_app_stop_ctrl()
399 err = nfp_app_start(pf->app, pf->ctrl_vnic); in nfp_net_pf_app_start()
404 err = nfp_app_sriov_enable(pf->app, pf->num_vfs); in nfp_net_pf_app_start()
492 pf->dev_info->qc_area_sz, &pf->qc_area); in nfp_net_pci_map_mem()
658 struct nfp_pf *pf = port->app->pf; in nfp_net_refresh_port_table() local
662 queue_work(pf->wq, &pf->port_refresh_work); in nfp_net_refresh_port_table()
[all …]
H A Dnfp_main.c167 n = nfp_rtsym_read(pf->cpp, pf->mbox, NFP_MBOX_DATA, in nfp_mbox_cmd()
215 pf->hwinfo = nfp_hwinfo_read(pf->cpp); in nfp_pf_board_state_wait()
593 pf->eth_tbl = __nfp_eth_read_ports(pf->cpp, nsp); in nfp_nsp_init_ports()
609 pf->eth_tbl = __nfp_eth_read_ports(pf->cpp, nsp); in nfp_nsp_init_ports()
816 pf->hwinfo = nfp_hwinfo_read(pf->cpp); in nfp_pci_probe()
833 pf->mip = nfp_mip_open(pf->cpp); in nfp_pci_probe()
834 pf->rtbl = __nfp_rtsym_table_read(pf->cpp, pf->mip); in nfp_pci_probe()
841 pf->dumpspec = nfp_net_dump_load_dumpspec(pf->cpp, pf->rtbl); in nfp_pci_probe()
848 if (pf->num_vfs > pf->limit_vfs) { in nfp_pci_probe()
851 pf->num_vfs, pf->limit_vfs); in nfp_pci_probe()
[all …]
/linux-6.15/drivers/net/ethernet/marvell/octeontx2/nic/
H A Dotx2_pf.c112 devm_kfree(pf->dev, pf->flr_wrk); in otx2_flr_wq_destroy()
118 struct otx2_nic *pf = flrwork->pf; in otx2_flr_handler() local
290 pf->flr_wrk[vf].pf = pf; in otx2_pf_flr_init()
1544 pf->rbsize = otx2_get_rbuf_size(pf, pf->netdev->mtu); in otx2_init_hw_resources()
1844 pf->hw.non_qos_queues = pf->hw.tx_queues + pf->hw.xdp_queues; in otx2_alloc_queue_mem()
1845 pf->hw.cint_cnt = max3(pf->hw.rx_queues, pf->hw.tx_queues, in otx2_alloc_queue_mem()
1848 pf->qset.cq_cnt = pf->hw.rx_queues + otx2_get_total_tx_queues(pf); in otx2_alloc_queue_mem()
2925 pf->vf_configs = devm_kcalloc(pf->dev, pf->total_vfs, in otx2_sriov_vfcfg_init()
2932 pf->vf_configs[i].pf = pf; in otx2_sriov_vfcfg_init()
3024 qmem_free(pf->dev, pf->dync_lmt); in otx2_init_rsrc()
[all …]
H A Dotx2_dmac_flt.c17 mutex_lock(&pf->mbox.lock); in otx2_dmacflt_do_add()
21 mutex_unlock(&pf->mbox.lock); in otx2_dmacflt_do_add()
32 mutex_unlock(&pf->mbox.lock); in otx2_dmacflt_do_add()
39 mutex_unlock(&pf->mbox.lock); in otx2_dmacflt_do_add()
49 mutex_lock(&pf->mbox.lock); in otx2_dmacflt_add_pfmac()
53 mutex_unlock(&pf->mbox.lock); in otx2_dmacflt_add_pfmac()
75 mutex_unlock(&pf->mbox.lock); in otx2_dmacflt_add_pfmac()
120 mutex_lock(&pf->mbox.lock); in otx2_dmacflt_remove_pfmac()
130 mutex_unlock(&pf->mbox.lock); in otx2_dmacflt_remove_pfmac()
155 mutex_lock(&pf->mbox.lock); in otx2_dmacflt_get_max_cnt()
[all …]
H A Dcn10k_ipsec.c54 mutex_lock(&pf->mbox.lock); in cn10k_outb_cptlf_attach()
76 mutex_lock(&pf->mbox.lock); in cn10k_outb_cptlf_detach()
97 mutex_lock(&pf->mbox.lock); in cn10k_outb_cptlf_alloc()
116 mutex_lock(&pf->mbox.lock); in cn10k_outb_cptlf_free()
281 otx2_write64(pf, CN10K_CPT_LF_Q_BASE, pf->ipsec.iq.dma_addr); in cn10k_outb_cptlf_iq_init()
333 pf->ipsec.io_addr = (__force u64)otx2_get_regaddr(pf, in cn10k_outb_cpt_init()
526 struct otx2_nic *pf; in cn10k_outb_prepare_sa() local
672 struct otx2_nic *pf; in cn10k_ipsec_outb_add_state() local
681 err = qmem_alloc(pf->dev, &sa_info, pf->ipsec.sa_size, OTX2_ALIGN); in cn10k_ipsec_outb_add_state()
717 struct otx2_nic *pf; in cn10k_ipsec_del_state() local
[all …]
/linux-6.15/drivers/net/ethernet/intel/ice/
H A Dice_irq.c27 if (!pf->virt_irq_tracker.bm) in ice_init_virt_irq_tracker()
121 ice_deinit_irq_tracker(pf); in ice_clear_interrupt_scheme()
135 if (!pf->msix.min) in ice_init_interrupt_scheme()
138 if (!pf->msix.max) in ice_init_interrupt_scheme()
143 pf->msix.rest = total_vectors - pf->msix.max; in ice_init_interrupt_scheme()
146 vectors = pf->msix.min; in ice_init_interrupt_scheme()
148 vectors = pf->msix.max; in ice_init_interrupt_scheme()
150 vectors = pci_alloc_irq_vectors(pf->pdev, pf->msix.min, vectors, in ice_init_interrupt_scheme()
155 ice_init_irq_tracker(pf, pf->msix.max, vectors); in ice_init_interrupt_scheme()
157 return ice_init_virt_irq_tracker(pf, pf->msix.max, pf->msix.rest); in ice_init_interrupt_scheme()
[all …]
H A Dice_ptp.c62 return !pf->adapter ? NULL : pf->adapter->ctrl_pf; in ice_get_ctrl_pf()
1698 ice_ptp_cfg_extts(pf, &pf->ptp.extts_rqs[i], in ice_ptp_disable_all_extts()
1714 ice_ptp_cfg_extts(pf, &pf->ptp.extts_rqs[i], in ice_ptp_enable_all_extts()
1868 ice_ptp_cfg_perout(pf, &pf->ptp.perout_rqs[i], in ice_ptp_disable_all_perout()
1885 ice_ptp_cfg_perout(pf, &pf->ptp.perout_rqs[i], in ice_ptp_enable_all_perout()
2271 pf = ctx->pf; in ice_capture_crosststamp()
2348 .pf = pf, in ice_ptp_getcrosststamp()
2522 pf->ptp.info.pin_config = pf->ptp.pin_desc; in ice_ptp_setup_pin_cfg()
3011 ice_ptp_release_tx_tracker(pf, &pf->ptp.port.tx); in ice_ptp_prepare_for_reset()
3144 pf->adapter->ctrl_pf = pf; in ice_ptp_setup_adapter()
[all …]
H A Dice_dpll.c135 struct ice_pf *pf = d->pf; in ice_dpll_frequency_set() local
223 struct ice_pf *pf = d->pf; in ice_dpll_frequency_get() local
553 struct ice_pf *pf = d->pf; in ice_dpll_lock_status_get() local
581 struct ice_pf *pf = d->pf; in ice_dpll_mode_get() local
615 struct ice_pf *pf = d->pf; in ice_dpll_pin_state_set() local
723 struct ice_pf *pf = d->pf; in ice_dpll_pin_state_get() local
818 struct ice_pf *pf = d->pf; in ice_dpll_input_prio_get() local
2012 d->pf = pf; in ice_dpll_init_dpll()
2123 pins[i].pf = pf; in ice_dpll_init_info_pins_generic()
2220 pins[i].pf = pf; in ice_dpll_init_info_direct_pins()
[all …]
H A Dice_eswitch.c296 dev_err(ice_pf_to_dev(pf), in ice_eswitch_enable_switchdev()
314 ice_eswitch_release_env(pf); in ice_eswitch_enable_switchdev()
325 ice_eswitch_release_env(pf); in ice_eswitch_disable_switchdev()
345 if (ice_has_vfs(pf)) { in ice_eswitch_mode_set()
354 pf->hw.pf_id); in ice_eswitch_mode_set()
367 pf->hw.pf_id); in ice_eswitch_mode_set()
377 pf->eswitch_mode = mode; in ice_eswitch_mode_set()
390 *mode = pf->eswitch_mode; in ice_eswitch_mode_get()
462 ice_eswitch_stop_reprs(pf); in ice_eswitch_attach()
478 ice_eswitch_start_reprs(pf); in ice_eswitch_attach()
[all …]
H A Dice_main.c722 if (pf->lag && pf->lag->bonded) { in ice_reset_subtask()
3376 ice_free_irq(pf, pf->ll_ts_irq); in ice_free_irq_msix_ll_ts()
3397 ice_free_irq(pf, pf->oicr_irq); in ice_free_irq_msix_misc()
3473 pf->int_name, pf); in ice_req_irq_msix_misc()
3477 ice_free_irq(pf, pf->oicr_irq); in ice_req_irq_msix_misc()
3491 pf->int_name_ll_ts, pf); in ice_req_irq_msix_misc()
3495 ice_free_irq(pf, pf->ll_ts_irq); in ice_req_irq_msix_misc()
4411 pf->vsi[pf->ctrl_vsi_idx] = NULL; in ice_init_fdir()
4427 pf->vsi[pf->ctrl_vsi_idx] = NULL; in ice_deinit_fdir()
4935 pf->first_sw->pf = pf; in ice_init_pf_sw()
[all …]
H A Dice_idc.c22 adev = pf->adev; in ice_get_auxiliary_drv()
43 if (!pf->adev) in ice_send_event_to_aux()
73 dev = ice_pf_to_dev(pf); in ice_add_rdma_qset()
148 if (WARN_ON(!pf)) in ice_rdma_request_reset()
181 if (WARN_ON(!pf)) in ice_rdma_update_vsi_filter()
256 ice_free_irq(pf, map); in ice_free_rdma_qvector()
293 iadev->pf = pf; in ice_plug_aux_dev()
313 pf->adev = adev; in ice_plug_aux_dev()
327 adev = pf->adev; in ice_unplug_aux_dev()
328 pf->adev = NULL; in ice_unplug_aux_dev()
[all …]
H A Dice_dcb_nl.c35 struct ice_pf *pf; in ice_dcbnl_getets() local
73 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_setets()
178 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_setdcbx()
274 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_setpfc()
341 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_set_pfc_cfg()
402 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_setstate()
479 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_set_pg_tc_cfg_tx()
538 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_set_pg_bwg_cfg_tx()
763 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_setapp()
879 if (pf->lag && pf->lag->bonded) { in ice_dcbnl_delapp()
[all …]
H A Dice_gnss.c91 struct ice_pf *pf; in ice_gnss_read() local
98 pf = gnss->back; in ice_gnss_read()
99 if (!pf || !test_bit(ICE_FLAG_GNSS, pf->flags)) in ice_gnss_read()
102 hw = &pf->hw; in ice_gnss_read()
181 gnss->back = pf; in ice_gnss_struct_init()
211 if (!pf) in ice_gnss_open()
237 if (!pf) in ice_gnss_close()
268 if (!pf) in ice_gnss_write()
333 if (pf->gnss_dev) { in ice_gnss_deregister()
348 pf->gnss_serial = ice_gnss_struct_init(pf); in ice_gnss_init()
[all …]
H A Dice_sriov.c50 struct ice_pf *pf = vf->pf; in ice_free_vf_res() local
90 struct ice_pf *pf = vf->pf; in ice_dis_vf_mappings() local
199 struct ice_pf *pf = vf->pf; in ice_vf_vsi_setup() local
233 struct ice_pf *pf = vf->pf; in ice_ena_vf_msix_mappings() local
439 struct ice_pf *pf = vf->pf; in ice_init_vf_vsi_res() local
551 struct ice_pf *pf = vf->pf; in ice_sriov_clear_mbx_register() local
566 struct ice_pf *pf = vf->pf; in ice_sriov_trigger_reset_register() local
613 struct ice_pf *pf = vf->pf; in ice_sriov_poll_reset_status() local
704 vf->pf = pf; in ice_create_vf_entries()
1743 struct ice_pf *pf = vf->pf; in ice_print_vf_rx_mdd_event() local
[all …]
/linux-6.15/drivers/net/ethernet/intel/i40e/
H A Di40e_ptp.c683 if (!test_bit(I40E_FLAG_PTP_ENA, pf->flags) || !pf->ptp_rx) in i40e_ptp_rx_hang()
736 if (!test_bit(I40E_FLAG_PTP_ENA, pf->flags) || !pf->ptp_tx) in i40e_ptp_tx_hang()
774 if (!test_bit(I40E_FLAG_PTP_ENA, pf->flags) || !pf->ptp_tx) in i40e_ptp_tx_hwtstamp()
821 if (!test_bit(I40E_FLAG_PTP_ENA, pf->flags) || !pf->ptp_rx) in i40e_ptp_rx_hwtstamp()
824 hw = &pf->hw; in i40e_ptp_rx_hwtstamp()
1131 pf->ptp_pins = in i40e_ptp_alloc_pins()
1263 if (pf->ptp_tx) in i40e_ptp_set_timestamp_mode()
1344 pf->ptp_caps.pin_config = kcalloc(pf->ptp_caps.n_pins, in i40e_init_pin_config()
1399 pf->ptp_clock = ptp_clock_register(&pf->ptp_caps, &pf->pdev->dev); in i40e_ptp_create_clock()
1457 i40e_ptp_settime(&pf->ptp_caps, &pf->ptp_prev_hw_time); in i40e_ptp_restore_hw_time()
[all …]
H A Di40e_dcb_nl.c118 pf->tmp_cfg = *old_cfg; in i40e_dcbnl_ieee_setets()
134 ret = i40e_hw_dcb_config(pf, &pf->tmp_cfg); in i40e_dcbnl_ieee_setets()
139 i40e_aq_str(&pf->hw, pf->hw.aq.asq_last_status)); in i40e_dcbnl_ieee_setets()
173 ret = i40e_hw_dcb_config(pf, &pf->tmp_cfg); in i40e_dcbnl_ieee_setpfc()
178 i40e_aq_str(&pf->hw, pf->hw.aq.asq_last_status)); in i40e_dcbnl_ieee_setpfc()
222 pf->tmp_cfg.app[pf->tmp_cfg.numapps++] = new_app; in i40e_dcbnl_ieee_setapp()
224 ret = i40e_hw_dcb_config(pf, &pf->tmp_cfg); in i40e_dcbnl_ieee_setapp()
229 i40e_aq_str(&pf->hw, pf->hw.aq.asq_last_status)); in i40e_dcbnl_ieee_setapp()
289 ret = i40e_hw_dcb_config(pf, &pf->tmp_cfg); in i40e_dcbnl_ieee_delapp()
294 i40e_aq_str(&pf->hw, pf->hw.aq.asq_last_status)); in i40e_dcbnl_ieee_delapp()
[all …]
H A Di40e_debugfs.c109 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
126 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
135 pf->hw.mac.addr, in i40e_dbg_dump_vsi_seid()
148 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
154 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
160 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
164 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
169 dev_info(&pf->pdev->dev, in i40e_dbg_dump_vsi_seid()
720 vf = &pf->vf[vf_id]; in i40e_dbg_dump_vf()
1806 debugfs_create_file("command", 0600, pf->i40e_dbg_pf, pf, in i40e_dbg_pf_init()
[all …]
H A Di40e_main.c778 struct i40e_pf *pf = veb->pf; in i40e_update_veb_stats() local
4610 pf->int_name, pf); in i40e_vsi_request_irq()
4613 pf->int_name, pf); in i40e_vsi_request_irq()
9912 pf = veb->pf; in i40e_veb_link_event()
12251 pf->int_name, pf); in i40e_setup_misc_vector_for_recovery_mode()
14630 veb->pf = pf; in i40e_veb_mem_alloc()
14712 pf = veb->pf; in i40e_veb_release()
14917 veb->pf = pf; in i40e_setup_pf_switch_element()
15219 pf->num_lan_qps, pf->alloc_rss_size, pf->num_req_vfs, in i40e_determine_queue_usage()
15220 pf->num_vf_qps, pf->num_vmdq_vsis, pf->num_vmdq_qps, in i40e_determine_queue_usage()
[all …]
H A Di40e_client.c147 struct i40e_pf *pf = ldev->pf; in i40e_client_release_qvlist() local
344 cdev->lan_info.pf = (void *)pf; in i40e_client_add_instance()
464 if (ldev->pf == pf) { in i40e_lan_add_device()
474 ldev->pf = pf; in i40e_lan_add_device()
511 if (ldev->pf == pf) { in i40e_lan_del_device()
539 struct i40e_pf *pf = ldev->pf; in i40e_client_virtchnl_send() local
564 struct i40e_pf *pf = ldev->pf; in i40e_client_setup_qvlist() local
633 struct i40e_pf *pf = ldev->pf; in i40e_client_request_reset() local
669 struct i40e_pf *pf = ldev->pf; in i40e_client_update_vsi_ctxt() local
723 struct i40e_pf *pf = ldev->pf; in i40e_client_device_register() local
[all …]
H A Di40e_virtchnl_pf.c113 struct i40e_pf *pf = vf->pf; in i40e_vc_notify_vf_link_state() local
221 struct i40e_pf *pf = vf->pf; in i40e_vc_reset_vf() local
262 struct i40e_pf *pf = vf->pf; in i40e_vc_isvalid_vsi_id() local
279 struct i40e_pf *pf = vf->pf; in i40e_vc_isvalid_queue_id() local
294 struct i40e_pf *pf = vf->pf; in i40e_vc_isvalid_vector_id() local
312 struct i40e_pf *pf = vf->pf; in i40e_vc_get_pf_queue_id() local
374 struct i40e_pf *pf = vf->pf; in i40e_config_irq_link_list() local
478 struct i40e_pf *pf = vf->pf; in i40e_release_rdma_qvlist() local
530 struct i40e_pf *pf = vf->pf; in i40e_config_rdma_qvlist() local
1844 vfs[i].pf = pf; in i40e_alloc_vfs()
[all …]
/linux-6.15/drivers/net/ethernet/freescale/enetc/
H A Denetc_pf_common.c183 pf->mdio = bus; in enetc_mdio_probe()
190 if (pf->mdio) in enetc_mdio_remove()
230 phylink_pcs = pf->ops->create_pcs(pf, bus); in enetc_imdio_create()
237 pf->imdio = bus; in enetc_imdio_create()
238 pf->pcs = phylink_pcs; in enetc_imdio_create()
251 if (pf->pcs && pf->ops->destroy_pcs) in enetc_imdio_remove()
252 pf->ops->destroy_pcs(pf->pcs); in enetc_imdio_remove()
254 if (pf->imdio) { in enetc_imdio_remove()
296 enetc_mdio_remove(pf); in enetc_mdiobus_destroy()
297 enetc_imdio_remove(pf); in enetc_mdiobus_destroy()
[all …]
H A Denetc4_pf.c68 pf->si = si; in enetc4_pf_struct_init()
70 pf->ops = &enetc4_pf_ops; in enetc4_pf_struct_init()
72 enetc4_get_port_caps(pf); in enetc4_pf_struct_init()
98 if (pf->caps.num_rx_bdr < ENETC_SI_MAX_RING_NUM + pf->caps.num_vsi) in enetc4_default_rings_allocation()
99 num_rx_bdr = pf->caps.num_rx_bdr - pf->caps.num_vsi; in enetc4_default_rings_allocation()
103 if (pf->caps.num_tx_bdr < ENETC_SI_MAX_RING_NUM + pf->caps.num_vsi) in enetc4_default_rings_allocation()
104 num_tx_bdr = pf->caps.num_tx_bdr - pf->caps.num_vsi; in enetc4_default_rings_allocation()
260 enetc4_enable_trx(pf); in enetc4_configure_port()
293 return pf->pcs; in enetc4_pl_mac_select_pcs()
696 struct enetc_pf *pf; in enetc4_pf_probe() local
[all …]
/linux-6.15/net/lapb/
H A Dlapb_in.c47 lapb->dev, frame->pf); in lapb_state0_machine()
52 lapb->dev, frame->pf); in lapb_state0_machine()
72 lapb->dev, frame->pf); in lapb_state0_machine()
87 lapb->dev, frame->pf); in lapb_state0_machine()
152 if (frame->pf) { in lapb_state1_machine()
168 if (frame->pf) { in lapb_state1_machine()
206 if (frame->pf) { in lapb_state2_machine()
217 if (frame->pf) { in lapb_state2_machine()
233 if (frame->pf) in lapb_state2_machine()
417 if (frame->pf) in lapb_state3_machine()
[all …]
/linux-6.15/tools/perf/util/
H A Dprobe-finder.c467 &pf->sp_die, pf, pf->tvar); in convert_variable()
477 pf->pvar->field, &pf->tvar->ref, in convert_variable()
500 pf->tvar->name = strdup(pf->pvar->name); in find_variable()
599 if (!die_find_realfunc(&pf->cu_die, pf->addr, &pf->sp_die)) { in call_probe_finder()
600 if (die_find_tailfunc(&pf->cu_die, pf->addr, &pf->sp_die)) { in call_probe_finder()
631 ret = pf->callback(sc_die, pf); in call_probe_finder()
707 cu_walk_functions_at(&pf->cu_die, pf->addr, in find_best_scope()
1140 if (pf->cfi_eh || pf->cfi_dbg) in debuginfo__find_probes()
1181 struct probe_finder *pf = vf->pf; in copy_variables_cb() local
1190 vf->pf->fb_ops, &pf->sp_die, in copy_variables_cb()
[all …]
/linux-6.15/drivers/net/ethernet/intel/ice/devlink/
H A Dport.c348 if (pf->hw.pf_id == 0) in ice_devlink_create_pf_port()
359 pf->hw.pf_id, err); in ice_devlink_create_pf_port()
419 struct ice_pf *pf; in ice_devlink_port_set_vf_fn_mac() local
449 struct ice_pf *pf; in ice_devlink_create_vf_port() local
452 pf = vf->pf; in ice_devlink_create_vf_port()
461 attrs.pci_vf.pf = pf->hw.pf_id; in ice_devlink_create_vf_port()
585 struct ice_pf *pf = dyn_port->pf; in ice_dealloc_dynamic_port() local
864 struct ice_pf *pf; in ice_devlink_create_sf_port() local
867 pf = dyn_port->pf; in ice_devlink_create_sf_port()
872 attrs.pci_sf.pf = pf->hw.pf_id; in ice_devlink_create_sf_port()
[all …]

12345678910>>...24