xref: /openbmc/linux/drivers/net/ethernet/sfc/ef100_sriov.c (revision 78a9b3c47befde80a4896a8c5172990b60c58af4)
1*78a9b3c4SPieter Jansen van Vuuren // SPDX-License-Identifier: GPL-2.0-only
2*78a9b3c4SPieter Jansen van Vuuren /****************************************************************************
3*78a9b3c4SPieter Jansen van Vuuren  * Driver for Solarflare network controllers and boards
4*78a9b3c4SPieter Jansen van Vuuren  * Copyright 2019 Solarflare Communications Inc.
5*78a9b3c4SPieter Jansen van Vuuren  * Copyright 2020-2022 Xilinx Inc.
6*78a9b3c4SPieter Jansen van Vuuren  *
7*78a9b3c4SPieter Jansen van Vuuren  * This program is free software; you can redistribute it and/or modify it
8*78a9b3c4SPieter Jansen van Vuuren  * under the terms of the GNU General Public License version 2 as published
9*78a9b3c4SPieter Jansen van Vuuren  * by the Free Software Foundation, incorporated herein by reference.
10*78a9b3c4SPieter Jansen van Vuuren  */
11*78a9b3c4SPieter Jansen van Vuuren 
12*78a9b3c4SPieter Jansen van Vuuren #include "ef100_sriov.h"
13*78a9b3c4SPieter Jansen van Vuuren #include "ef100_nic.h"
14*78a9b3c4SPieter Jansen van Vuuren 
15*78a9b3c4SPieter Jansen van Vuuren static int efx_ef100_pci_sriov_enable(struct efx_nic *efx, int num_vfs)
16*78a9b3c4SPieter Jansen van Vuuren {
17*78a9b3c4SPieter Jansen van Vuuren 	struct pci_dev *dev = efx->pci_dev;
18*78a9b3c4SPieter Jansen van Vuuren 	int rc;
19*78a9b3c4SPieter Jansen van Vuuren 
20*78a9b3c4SPieter Jansen van Vuuren 	efx->vf_count = num_vfs;
21*78a9b3c4SPieter Jansen van Vuuren 	rc = pci_enable_sriov(dev, num_vfs);
22*78a9b3c4SPieter Jansen van Vuuren 	if (rc)
23*78a9b3c4SPieter Jansen van Vuuren 		goto fail;
24*78a9b3c4SPieter Jansen van Vuuren 
25*78a9b3c4SPieter Jansen van Vuuren 	return 0;
26*78a9b3c4SPieter Jansen van Vuuren 
27*78a9b3c4SPieter Jansen van Vuuren fail:
28*78a9b3c4SPieter Jansen van Vuuren 	netif_err(efx, probe, efx->net_dev, "Failed to enable SRIOV VFs\n");
29*78a9b3c4SPieter Jansen van Vuuren 	efx->vf_count = 0;
30*78a9b3c4SPieter Jansen van Vuuren 	return rc;
31*78a9b3c4SPieter Jansen van Vuuren }
32*78a9b3c4SPieter Jansen van Vuuren 
33*78a9b3c4SPieter Jansen van Vuuren int efx_ef100_pci_sriov_disable(struct efx_nic *efx)
34*78a9b3c4SPieter Jansen van Vuuren {
35*78a9b3c4SPieter Jansen van Vuuren 	struct pci_dev *dev = efx->pci_dev;
36*78a9b3c4SPieter Jansen van Vuuren 	unsigned int vfs_assigned;
37*78a9b3c4SPieter Jansen van Vuuren 
38*78a9b3c4SPieter Jansen van Vuuren 	vfs_assigned = pci_vfs_assigned(dev);
39*78a9b3c4SPieter Jansen van Vuuren 	if (vfs_assigned) {
40*78a9b3c4SPieter Jansen van Vuuren 		netif_info(efx, drv, efx->net_dev, "VFs are assigned to guests; "
41*78a9b3c4SPieter Jansen van Vuuren 			   "please detach them before disabling SR-IOV\n");
42*78a9b3c4SPieter Jansen van Vuuren 		return -EBUSY;
43*78a9b3c4SPieter Jansen van Vuuren 	}
44*78a9b3c4SPieter Jansen van Vuuren 
45*78a9b3c4SPieter Jansen van Vuuren 	pci_disable_sriov(dev);
46*78a9b3c4SPieter Jansen van Vuuren 
47*78a9b3c4SPieter Jansen van Vuuren 	return 0;
48*78a9b3c4SPieter Jansen van Vuuren }
49*78a9b3c4SPieter Jansen van Vuuren 
50*78a9b3c4SPieter Jansen van Vuuren int efx_ef100_sriov_configure(struct efx_nic *efx, int num_vfs)
51*78a9b3c4SPieter Jansen van Vuuren {
52*78a9b3c4SPieter Jansen van Vuuren 	if (num_vfs == 0)
53*78a9b3c4SPieter Jansen van Vuuren 		return efx_ef100_pci_sriov_disable(efx);
54*78a9b3c4SPieter Jansen van Vuuren 	else
55*78a9b3c4SPieter Jansen van Vuuren 		return efx_ef100_pci_sriov_enable(efx, num_vfs);
56*78a9b3c4SPieter Jansen van Vuuren }
57