Commit ff2005a4 authored by Wei Yang's avatar Wei Yang Committed by Greg Kroah-Hartman

mlx4_core: Stash PCI ID driver_data in mlx4_priv structure

[ No upstream commit, this is a cherry picked backport enabler. ]

From: Roland Dreier <roland@purestorage.com>

That way we can check flags later on, when we've finished with the
pci_device_id structure.  Also convert the "is VF" flag to an enum:
"Never do in the preprocessor what can be done in C."
Signed-off-by: default avatarRoland Dreier <roland@purestorage.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3309a975
...@@ -92,8 +92,6 @@ MODULE_PARM_DESC(log_num_mgm_entry_size, "log mgm size, that defines the num" ...@@ -92,8 +92,6 @@ MODULE_PARM_DESC(log_num_mgm_entry_size, "log mgm size, that defines the num"
" 10 gives 248.range: 9<=" " 10 gives 248.range: 9<="
" log_num_mgm_entry_size <= 12"); " log_num_mgm_entry_size <= 12");
#define MLX4_VF (1 << 0)
#define HCA_GLOBAL_CAP_MASK 0 #define HCA_GLOBAL_CAP_MASK 0
#define PF_CONTEXT_BEHAVIOUR_MASK 0 #define PF_CONTEXT_BEHAVIOUR_MASK 0
...@@ -1731,7 +1729,7 @@ static void mlx4_free_ownership(struct mlx4_dev *dev) ...@@ -1731,7 +1729,7 @@ static void mlx4_free_ownership(struct mlx4_dev *dev)
iounmap(owner); iounmap(owner);
} }
static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id) static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data)
{ {
struct mlx4_priv *priv; struct mlx4_priv *priv;
struct mlx4_dev *dev; struct mlx4_dev *dev;
...@@ -1754,12 +1752,11 @@ static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id) ...@@ -1754,12 +1752,11 @@ static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
/* /*
* Check for BARs. * Check for BARs.
*/ */
if (((id == NULL) || !(id->driver_data & MLX4_VF)) && if (!(pci_dev_data & MLX4_PCI_DEV_IS_VF) &&
!(pci_resource_flags(pdev, 0) & IORESOURCE_MEM)) { !(pci_resource_flags(pdev, 0) & IORESOURCE_MEM)) {
dev_err(&pdev->dev, "Missing DCS, aborting." dev_err(&pdev->dev, "Missing DCS, aborting."
"(id == 0X%p, id->driver_data: 0x%lx," "(driver_data: 0x%x, pci_resource_flags(pdev, 0):0x%lx)\n",
" pci_resource_flags(pdev, 0):0x%lx)\n", id, pci_dev_data, pci_resource_flags(pdev, 0));
id ? id->driver_data : 0, pci_resource_flags(pdev, 0));
err = -ENODEV; err = -ENODEV;
goto err_disable_pdev; goto err_disable_pdev;
} }
...@@ -1824,7 +1821,7 @@ static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id) ...@@ -1824,7 +1821,7 @@ static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
dev->rev_id = pdev->revision; dev->rev_id = pdev->revision;
/* Detect if this device is a virtual function */ /* Detect if this device is a virtual function */
if (id && id->driver_data & MLX4_VF) { if (pci_dev_data & MLX4_PCI_DEV_IS_VF) {
/* When acting as pf, we normally skip vfs unless explicitly /* When acting as pf, we normally skip vfs unless explicitly
* requested to probe them. */ * requested to probe them. */
if (num_vfs && extended_func_num(pdev) > probe_vf) { if (num_vfs && extended_func_num(pdev) > probe_vf) {
...@@ -1970,6 +1967,7 @@ static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id) ...@@ -1970,6 +1967,7 @@ static int __mlx4_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
mlx4_sense_init(dev); mlx4_sense_init(dev);
mlx4_start_sense(dev); mlx4_start_sense(dev);
priv->pci_dev_data = pci_dev_data;
pci_set_drvdata(pdev, dev); pci_set_drvdata(pdev, dev);
return 0; return 0;
...@@ -2039,7 +2037,7 @@ static int __devinit mlx4_init_one(struct pci_dev *pdev, ...@@ -2039,7 +2037,7 @@ static int __devinit mlx4_init_one(struct pci_dev *pdev,
{ {
printk_once(KERN_INFO "%s", mlx4_version); printk_once(KERN_INFO "%s", mlx4_version);
return __mlx4_init_one(pdev, id); return __mlx4_init_one(pdev, id->driver_data);
} }
static void mlx4_remove_one(struct pci_dev *pdev) static void mlx4_remove_one(struct pci_dev *pdev)
...@@ -2108,8 +2106,13 @@ static void mlx4_remove_one(struct pci_dev *pdev) ...@@ -2108,8 +2106,13 @@ static void mlx4_remove_one(struct pci_dev *pdev)
int mlx4_restart_one(struct pci_dev *pdev) int mlx4_restart_one(struct pci_dev *pdev)
{ {
struct mlx4_dev *dev = pci_get_drvdata(pdev);
struct mlx4_priv *priv = mlx4_priv(dev);
int pci_dev_data;
pci_dev_data = priv->pci_dev_data;
mlx4_remove_one(pdev); mlx4_remove_one(pdev);
return __mlx4_init_one(pdev, NULL); return __mlx4_init_one(pdev, pci_dev_data);
} }
static DEFINE_PCI_DEVICE_TABLE(mlx4_pci_table) = { static DEFINE_PCI_DEVICE_TABLE(mlx4_pci_table) = {
...@@ -2138,11 +2141,11 @@ static DEFINE_PCI_DEVICE_TABLE(mlx4_pci_table) = { ...@@ -2138,11 +2141,11 @@ static DEFINE_PCI_DEVICE_TABLE(mlx4_pci_table) = {
/* MT26478 ConnectX2 40GigE PCIe gen2 */ /* MT26478 ConnectX2 40GigE PCIe gen2 */
{ PCI_VDEVICE(MELLANOX, 0x676e), 0 }, { PCI_VDEVICE(MELLANOX, 0x676e), 0 },
/* MT25400 Family [ConnectX-2 Virtual Function] */ /* MT25400 Family [ConnectX-2 Virtual Function] */
{ PCI_VDEVICE(MELLANOX, 0x1002), MLX4_VF }, { PCI_VDEVICE(MELLANOX, 0x1002), MLX4_PCI_DEV_IS_VF },
/* MT27500 Family [ConnectX-3] */ /* MT27500 Family [ConnectX-3] */
{ PCI_VDEVICE(MELLANOX, 0x1003), 0 }, { PCI_VDEVICE(MELLANOX, 0x1003), 0 },
/* MT27500 Family [ConnectX-3 Virtual Function] */ /* MT27500 Family [ConnectX-3 Virtual Function] */
{ PCI_VDEVICE(MELLANOX, 0x1004), MLX4_VF }, { PCI_VDEVICE(MELLANOX, 0x1004), MLX4_PCI_DEV_IS_VF },
{ PCI_VDEVICE(MELLANOX, 0x1005), 0 }, /* MT27510 Family */ { PCI_VDEVICE(MELLANOX, 0x1005), 0 }, /* MT27510 Family */
{ PCI_VDEVICE(MELLANOX, 0x1006), 0 }, /* MT27511 Family */ { PCI_VDEVICE(MELLANOX, 0x1006), 0 }, /* MT27511 Family */
{ PCI_VDEVICE(MELLANOX, 0x1007), 0 }, /* MT27520 Family */ { PCI_VDEVICE(MELLANOX, 0x1007), 0 }, /* MT27520 Family */
......
...@@ -711,6 +711,10 @@ struct mlx4_steer { ...@@ -711,6 +711,10 @@ struct mlx4_steer {
struct list_head steer_entries[MLX4_NUM_STEERS]; struct list_head steer_entries[MLX4_NUM_STEERS];
}; };
enum {
MLX4_PCI_DEV_IS_VF = 1 << 0,
};
struct mlx4_priv { struct mlx4_priv {
struct mlx4_dev dev; struct mlx4_dev dev;
...@@ -718,6 +722,8 @@ struct mlx4_priv { ...@@ -718,6 +722,8 @@ struct mlx4_priv {
struct list_head ctx_list; struct list_head ctx_list;
spinlock_t ctx_lock; spinlock_t ctx_lock;
int pci_dev_data;
struct list_head pgdir_list; struct list_head pgdir_list;
struct mutex pgdir_mutex; struct mutex pgdir_mutex;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment