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