diff options
Diffstat (limited to 'drivers/net/ethernet/mellanox/mlx4/pd.c')
| -rw-r--r-- | drivers/net/ethernet/mellanox/mlx4/pd.c | 19 | 
1 files changed, 14 insertions, 5 deletions
diff --git a/drivers/net/ethernet/mellanox/mlx4/pd.c b/drivers/net/ethernet/mellanox/mlx4/pd.c index 260ed259ce9..5c9a54df17a 100644 --- a/drivers/net/ethernet/mellanox/mlx4/pd.c +++ b/drivers/net/ethernet/mellanox/mlx4/pd.c @@ -31,6 +31,7 @@   * SOFTWARE.   */ +#include <linux/init.h>  #include <linux/errno.h>  #include <linux/export.h>  #include <linux/io-mapping.h> @@ -51,7 +52,8 @@ int mlx4_pd_alloc(struct mlx4_dev *dev, u32 *pdn)  	*pdn = mlx4_bitmap_alloc(&priv->pd_bitmap);  	if (*pdn == -1)  		return -ENOMEM; - +	if (mlx4_is_mfunc(dev)) +		*pdn |= (dev->caps.function + 1) << NOT_MASKED_PD_BITS;  	return 0;  }  EXPORT_SYMBOL_GPL(mlx4_pd_alloc); @@ -85,7 +87,8 @@ int mlx4_init_pd_table(struct mlx4_dev *dev)  	struct mlx4_priv *priv = mlx4_priv(dev);  	return mlx4_bitmap_init(&priv->pd_bitmap, dev->caps.num_pds, -				(1 << 24) - 1, dev->caps.reserved_pds, 0); +				(1 << NOT_MASKED_PD_BITS) - 1, +				 dev->caps.reserved_pds, 0);  }  void mlx4_cleanup_pd_table(struct mlx4_dev *dev) @@ -108,13 +111,19 @@ void mlx4_cleanup_xrcd_table(struct mlx4_dev *dev)  int mlx4_uar_alloc(struct mlx4_dev *dev, struct mlx4_uar *uar)  { +	int offset; +  	uar->index = mlx4_bitmap_alloc(&mlx4_priv(dev)->uar_table.bitmap);  	if (uar->index == -1)  		return -ENOMEM; -	uar->pfn = (pci_resource_start(dev->pdev, 2) >> PAGE_SHIFT) + uar->index; +	if (mlx4_is_slave(dev)) +		offset = uar->index % ((int) pci_resource_len(dev->pdev, 2) / +				       dev->caps.uar_page_size); +	else +		offset = uar->index; +	uar->pfn = (pci_resource_start(dev->pdev, 2) >> PAGE_SHIFT) + offset;  	uar->map = NULL; -  	return 0;  }  EXPORT_SYMBOL_GPL(mlx4_uar_alloc); @@ -232,7 +241,7 @@ int mlx4_init_uar_table(struct mlx4_dev *dev)  	return mlx4_bitmap_init(&mlx4_priv(dev)->uar_table.bitmap,  				dev->caps.num_uars, dev->caps.num_uars - 1, -				max(128, dev->caps.reserved_uars), 0); +				dev->caps.reserved_uars, 0);  }  void mlx4_cleanup_uar_table(struct mlx4_dev *dev)  |