diff mbox

pci: adjust return values for error cases of IOV functions

Message ID 1375278088-31260-1-git-send-email-sassmann@kpanic.de (mailing list archive)
State New, archived
Delegated to: Bjorn Helgaas
Headers show

Commit Message

Stefan Assmann July 31, 2013, 1:41 p.m. UTC
Changing the return value to -ENOSYS if a device is not physical PCI function.
Also have pci_sriov_get_totalvfs() return 0 in the error cae to make the
behaviour consistent whether CONFIG_PCI_IOV is enabled or not.
Some comment fixes.

Signed-off-by: Stefan Assmann <sassmann@kpanic.de>
---
 drivers/pci/iov.c | 19 +++++++++++--------
 1 file changed, 11 insertions(+), 8 deletions(-)

Comments

Bjorn Helgaas July 31, 2013, 11:31 p.m. UTC | #1
On Wed, Jul 31, 2013 at 7:41 AM, Stefan Assmann <sassmann@kpanic.de> wrote:
> Changing the return value to -ENOSYS if a device is not physical PCI function.
> Also have pci_sriov_get_totalvfs() return 0 in the error cae to make the
> behaviour consistent whether CONFIG_PCI_IOV is enabled or not.
> Some comment fixes.
>
> Signed-off-by: Stefan Assmann <sassmann@kpanic.de>

Applied to pci/misc for v3.12.  Thanks!

> ---
>  drivers/pci/iov.c | 19 +++++++++++--------
>  1 file changed, 11 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/pci/iov.c b/drivers/pci/iov.c
> index de8ffac..1fc9942 100644
> --- a/drivers/pci/iov.c
> +++ b/drivers/pci/iov.c
> @@ -324,7 +324,7 @@ static int sriov_enable(struct pci_dev *dev, int nr_virtfn)
>
>                 if (!pdev->is_physfn) {
>                         pci_dev_put(pdev);
> -                       return -ENODEV;
> +                       return -ENOSYS;
>                 }
>
>                 rc = sysfs_create_link(&dev->dev.kobj,
> @@ -662,7 +662,7 @@ int pci_enable_sriov(struct pci_dev *dev, int nr_virtfn)
>         might_sleep();
>
>         if (!dev->is_physfn)
> -               return -ENODEV;
> +               return -ENOSYS;
>
>         return sriov_enable(dev, nr_virtfn);
>  }
> @@ -722,7 +722,7 @@ EXPORT_SYMBOL_GPL(pci_num_vf);
>   * @dev: the PCI device
>   *
>   * Returns number of VFs belonging to this device that are assigned to a guest.
> - * If device is not a physical function returns -ENODEV.
> + * If device is not a physical function returns 0.
>   */
>  int pci_vfs_assigned(struct pci_dev *dev)
>  {
> @@ -767,12 +767,15 @@ EXPORT_SYMBOL_GPL(pci_vfs_assigned);
>   * device's mutex held.
>   *
>   * Returns 0 if PF is an SRIOV-capable device and
> - * value of numvfs valid. If not a PF with VFS, return -EINVAL;
> + * value of numvfs valid. If not a PF return -ENOSYS;
> + * if numvfs is invalid return -EINVAL;
>   * if VFs already enabled, return -EBUSY.
>   */
>  int pci_sriov_set_totalvfs(struct pci_dev *dev, u16 numvfs)
>  {
> -       if (!dev->is_physfn || (numvfs > dev->sriov->total_VFs))
> +       if (!dev->is_physfn)
> +               return -ENOSYS;
> +       if (numvfs > dev->sriov->total_VFs)
>                 return -EINVAL;
>
>         /* Shouldn't change if VFs already enabled */
> @@ -786,17 +789,17 @@ int pci_sriov_set_totalvfs(struct pci_dev *dev, u16 numvfs)
>  EXPORT_SYMBOL_GPL(pci_sriov_set_totalvfs);
>
>  /**
> - * pci_sriov_get_totalvfs -- get total VFs supported on this devic3
> + * pci_sriov_get_totalvfs -- get total VFs supported on this device
>   * @dev: the PCI PF device
>   *
>   * For a PCIe device with SRIOV support, return the PCIe
>   * SRIOV capability value of TotalVFs or the value of driver_max_VFs
> - * if the driver reduced it.  Otherwise, -EINVAL.
> + * if the driver reduced it.  Otherwise 0.
>   */
>  int pci_sriov_get_totalvfs(struct pci_dev *dev)
>  {
>         if (!dev->is_physfn)
> -               return -EINVAL;
> +               return 0;
>
>         if (dev->sriov->driver_max_VFs)
>                 return dev->sriov->driver_max_VFs;
> --
> 1.8.3.1
>
--
To unsubscribe from this list: send the line "unsubscribe linux-pci" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/pci/iov.c b/drivers/pci/iov.c
index de8ffac..1fc9942 100644
--- a/drivers/pci/iov.c
+++ b/drivers/pci/iov.c
@@ -324,7 +324,7 @@  static int sriov_enable(struct pci_dev *dev, int nr_virtfn)
 
 		if (!pdev->is_physfn) {
 			pci_dev_put(pdev);
-			return -ENODEV;
+			return -ENOSYS;
 		}
 
 		rc = sysfs_create_link(&dev->dev.kobj,
@@ -662,7 +662,7 @@  int pci_enable_sriov(struct pci_dev *dev, int nr_virtfn)
 	might_sleep();
 
 	if (!dev->is_physfn)
-		return -ENODEV;
+		return -ENOSYS;
 
 	return sriov_enable(dev, nr_virtfn);
 }
@@ -722,7 +722,7 @@  EXPORT_SYMBOL_GPL(pci_num_vf);
  * @dev: the PCI device
  *
  * Returns number of VFs belonging to this device that are assigned to a guest.
- * If device is not a physical function returns -ENODEV.
+ * If device is not a physical function returns 0.
  */
 int pci_vfs_assigned(struct pci_dev *dev)
 {
@@ -767,12 +767,15 @@  EXPORT_SYMBOL_GPL(pci_vfs_assigned);
  * device's mutex held.
  *
  * Returns 0 if PF is an SRIOV-capable device and
- * value of numvfs valid. If not a PF with VFS, return -EINVAL;
+ * value of numvfs valid. If not a PF return -ENOSYS;
+ * if numvfs is invalid return -EINVAL;
  * if VFs already enabled, return -EBUSY.
  */
 int pci_sriov_set_totalvfs(struct pci_dev *dev, u16 numvfs)
 {
-	if (!dev->is_physfn || (numvfs > dev->sriov->total_VFs))
+	if (!dev->is_physfn)
+		return -ENOSYS;
+	if (numvfs > dev->sriov->total_VFs)
 		return -EINVAL;
 
 	/* Shouldn't change if VFs already enabled */
@@ -786,17 +789,17 @@  int pci_sriov_set_totalvfs(struct pci_dev *dev, u16 numvfs)
 EXPORT_SYMBOL_GPL(pci_sriov_set_totalvfs);
 
 /**
- * pci_sriov_get_totalvfs -- get total VFs supported on this devic3
+ * pci_sriov_get_totalvfs -- get total VFs supported on this device
  * @dev: the PCI PF device
  *
  * For a PCIe device with SRIOV support, return the PCIe
  * SRIOV capability value of TotalVFs or the value of driver_max_VFs
- * if the driver reduced it.  Otherwise, -EINVAL.
+ * if the driver reduced it.  Otherwise 0.
  */
 int pci_sriov_get_totalvfs(struct pci_dev *dev)
 {
 	if (!dev->is_physfn)
-		return -EINVAL;
+		return 0;
 
 	if (dev->sriov->driver_max_VFs)
 		return dev->sriov->driver_max_VFs;