mirror of
https://github.com/torvalds/linux.git
synced 2026-05-28 00:53:34 +02:00
i40e: Cleanup PTP pins on probe failure
PTP pin structs are allocated early in probe, but never cleaned up.
Fix this by calling i40e_ptp_free_pins in the error path.
To support this, i40e_ptp_free_pins is added to the header and
pin_config is correctly nullified after being freed.
This has been an issue since i40e_ptp_alloc_pins was introduced.
Fixes: 1050713026 ("i40e: add support for PTP external synchronization clock")
Reported-by: Kohei Enju <kohei@enjuk.jp>
Cc: stable@vger.kernel.org
Signed-off-by: Matt Vollrath <tactii@gmail.com>
Reviewed-by: Paul Menzel <pmenzel@molgen.mpg.de>
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
Reviewed-by: Kohei Enju <kohei@enjuk.jp>
Tested-by: Sunitha Mekala <sunithax.d.mekala@intel.com>
Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
Link: https://patch.msgid.link/20260506-jk-iwl-net-2026-05-04-v2-2-a5ea4dc837a9@intel.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
1619553b0a
commit
678b713ece
|
|
@ -1318,6 +1318,7 @@ void i40e_ptp_restore_hw_time(struct i40e_pf *pf);
|
|||
void i40e_ptp_init(struct i40e_pf *pf);
|
||||
void i40e_ptp_stop(struct i40e_pf *pf);
|
||||
int i40e_ptp_alloc_pins(struct i40e_pf *pf);
|
||||
void i40e_ptp_free_pins(struct i40e_pf *pf);
|
||||
int i40e_update_adq_vsi_queues(struct i40e_vsi *vsi, int vsi_offset);
|
||||
int i40e_is_vsi_uplink_mode_veb(struct i40e_vsi *vsi);
|
||||
int i40e_get_partition_bw_setting(struct i40e_pf *pf);
|
||||
|
|
|
|||
|
|
@ -16112,6 +16112,7 @@ static int i40e_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
|
|||
i40e_clear_interrupt_scheme(pf);
|
||||
kfree(pf->vsi);
|
||||
err_switch_setup:
|
||||
i40e_ptp_free_pins(pf);
|
||||
i40e_reset_interrupt_capability(pf);
|
||||
timer_shutdown_sync(&pf->service_timer);
|
||||
err_mac_addr:
|
||||
|
|
|
|||
|
|
@ -940,12 +940,13 @@ int i40e_ptp_hwtstamp_get(struct net_device *netdev,
|
|||
*
|
||||
* Release memory allocated for PTP pins.
|
||||
**/
|
||||
static void i40e_ptp_free_pins(struct i40e_pf *pf)
|
||||
void i40e_ptp_free_pins(struct i40e_pf *pf)
|
||||
{
|
||||
if (i40e_is_ptp_pin_dev(&pf->hw)) {
|
||||
kfree(pf->ptp_pins);
|
||||
kfree(pf->ptp_caps.pin_config);
|
||||
pf->ptp_pins = NULL;
|
||||
pf->ptp_caps.pin_config = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user