netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21
@ 2013-03-21 15:55 Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 1/5] net/mlx4_core: Fix wrong mask applied on EQ numbers in the wrapper Or Gerlitz
                   ` (5 more replies)
  0 siblings, 6 replies; 8+ messages in thread
From: Or Gerlitz @ 2013-03-21 15:55 UTC (permalink / raw)
  To: davem; +Cc: netdev, amirv, jackm, hadarh, Or Gerlitz

Hi Dave,

Here's a batch of mlx4 driver fixes for 3.9, mostly SRIOV/Flow-steering
related. Series done against the net tree as of commit 5a3da1f
"inet: limit length of fragment queue hash table bucket lists

Or.

Hadar Hen Zion (4):
  net/mlx4_core: Fix wrong order of flow steering resources removal
  net/mlx4_en: Remove ethtool flow steering rules before releasing QPs
  net/mlx4_core: Always use 64 bit resource ID when doing lookup
  net/mlx4_core: Disallow releasing VF QPs which have steering rules

Moshe Lazer (1):
  net/mlx4_core: Fix wrong mask applied on EQ numbers in the wrapper

 drivers/net/ethernet/mellanox/mlx4/en_netdev.c     |   22 +++++-----
 drivers/net/ethernet/mellanox/mlx4/eq.c            |    2 +-
 .../net/ethernet/mellanox/mlx4/resource_tracker.c  |   45 +++++++++++++++----
 3 files changed, 47 insertions(+), 22 deletions(-)

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH net 1/5] net/mlx4_core: Fix wrong mask applied on EQ numbers in the wrapper
  2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
@ 2013-03-21 15:55 ` Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 2/5] net/mlx4_core: Fix wrong order of flow steering resources removal Or Gerlitz
                   ` (4 subsequent siblings)
  5 siblings, 0 replies; 8+ messages in thread
From: Or Gerlitz @ 2013-03-21 15:55 UTC (permalink / raw)
  To: davem; +Cc: netdev, amirv, jackm, hadarh, Moshe Lazer, Or Gerlitz

From: Moshe Lazer <moshel@mellanox.com>

Currently the  mask is wrongly set in the MAP_EQ wrapper, fix that.
Without the fix any EQ number above 511 is mapped to one below 511.

Signed-off-by: Moshe Lazer <moshel@mellanox.com>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
---
 drivers/net/ethernet/mellanox/mlx4/eq.c |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/drivers/net/ethernet/mellanox/mlx4/eq.c b/drivers/net/ethernet/mellanox/mlx4/eq.c
index 251ae2f..8e3123a 100644
--- a/drivers/net/ethernet/mellanox/mlx4/eq.c
+++ b/drivers/net/ethernet/mellanox/mlx4/eq.c
@@ -771,7 +771,7 @@ int mlx4_MAP_EQ_wrapper(struct mlx4_dev *dev, int slave,
 	struct mlx4_slave_event_eq_info *event_eq =
 		priv->mfunc.master.slave_state[slave].event_eq;
 	u32 in_modifier = vhcr->in_modifier;
-	u32 eqn = in_modifier & 0x1FF;
+	u32 eqn = in_modifier & 0x3FF;
 	u64 in_param =  vhcr->in_param;
 	int err = 0;
 	int i;
-- 
1.7.1

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH net 2/5] net/mlx4_core: Fix wrong order of flow steering resources removal
  2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 1/5] net/mlx4_core: Fix wrong mask applied on EQ numbers in the wrapper Or Gerlitz
@ 2013-03-21 15:55 ` Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 3/5] net/mlx4_en: Remove ethtool flow steering rules before releasing QPs Or Gerlitz
                   ` (3 subsequent siblings)
  5 siblings, 0 replies; 8+ messages in thread
From: Or Gerlitz @ 2013-03-21 15:55 UTC (permalink / raw)
  To: davem; +Cc: netdev, amirv, jackm, hadarh, Or Gerlitz

From: Hadar Hen Zion <hadarh@mellanox.com>

On the resource tracker cleanup flow, the DMFS rules must be deleted before we
destroy the QPs, else the HW may attempt doing packet steering to non existent QPs.

Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
---
 .../net/ethernet/mellanox/mlx4/resource_tracker.c  |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
index 2995687..0d1d967 100644
--- a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
+++ b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
@@ -3806,6 +3806,7 @@ void mlx4_delete_all_resources_for_slave(struct mlx4_dev *dev, int slave)
 	mutex_lock(&priv->mfunc.master.res_tracker.slave_list[slave].mutex);
 	/*VLAN*/
 	rem_slave_macs(dev, slave);
+	rem_slave_fs_rule(dev, slave);
 	rem_slave_qps(dev, slave);
 	rem_slave_srqs(dev, slave);
 	rem_slave_cqs(dev, slave);
@@ -3814,6 +3815,5 @@ void mlx4_delete_all_resources_for_slave(struct mlx4_dev *dev, int slave)
 	rem_slave_mtts(dev, slave);
 	rem_slave_counters(dev, slave);
 	rem_slave_xrcdns(dev, slave);
-	rem_slave_fs_rule(dev, slave);
 	mutex_unlock(&priv->mfunc.master.res_tracker.slave_list[slave].mutex);
 }
-- 
1.7.1

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH net 3/5] net/mlx4_en: Remove ethtool flow steering rules before releasing QPs
  2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 1/5] net/mlx4_core: Fix wrong mask applied on EQ numbers in the wrapper Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 2/5] net/mlx4_core: Fix wrong order of flow steering resources removal Or Gerlitz
@ 2013-03-21 15:55 ` Or Gerlitz
  2013-03-21 18:28   ` Sergei Shtylyov
  2013-03-21 15:55 ` [PATCH net 4/5] net/mlx4_core: Always use 64 bit resource ID when doing lookup Or Gerlitz
                   ` (2 subsequent siblings)
  5 siblings, 1 reply; 8+ messages in thread
From: Or Gerlitz @ 2013-03-21 15:55 UTC (permalink / raw)
  To: davem; +Cc: netdev, amirv, jackm, hadarh, Or Gerlitz

From: Hadar Hen Zion <hadarh@mellanox.com>

Fix the ethtool flow steering rules cleanup to be carried out before
releasing the RX QPs.

Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
---
 drivers/net/ethernet/mellanox/mlx4/en_netdev.c |   22 +++++++++++-----------
 1 files changed, 11 insertions(+), 11 deletions(-)

diff --git a/drivers/net/ethernet/mellanox/mlx4/en_netdev.c b/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
index 995d4b6..f278b10 100644
--- a/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
+++ b/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
@@ -1637,6 +1637,17 @@ void mlx4_en_stop_port(struct net_device *dev, int detach)
 	/* Flush multicast filter */
 	mlx4_SET_MCAST_FLTR(mdev->dev, priv->port, 0, 1, MLX4_MCAST_CONFIG);
 
+	/* Remove flow steering rules for the port*/
+	if (mdev->dev->caps.steering_mode ==
+	    MLX4_STEERING_MODE_DEVICE_MANAGED) {
+		ASSERT_RTNL();
+		list_for_each_entry_safe(flow, tmp_flow,
+					 &priv->ethtool_list, list) {
+			mlx4_flow_detach(mdev->dev, flow->id);
+			list_del(&flow->list);
+		}
+	}
+
 	mlx4_en_destroy_drop_qp(priv);
 
 	/* Free TX Rings */
@@ -1657,17 +1668,6 @@ void mlx4_en_stop_port(struct net_device *dev, int detach)
 	if (!(mdev->dev->caps.flags2 & MLX4_DEV_CAP_FLAGS2_REASSIGN_MAC_EN))
 		mdev->mac_removed[priv->port] = 1;
 
-	/* Remove flow steering rules for the port*/
-	if (mdev->dev->caps.steering_mode ==
-	    MLX4_STEERING_MODE_DEVICE_MANAGED) {
-		ASSERT_RTNL();
-		list_for_each_entry_safe(flow, tmp_flow,
-					 &priv->ethtool_list, list) {
-			mlx4_flow_detach(mdev->dev, flow->id);
-			list_del(&flow->list);
-		}
-	}
-
 	/* Free RX Rings */
 	for (i = 0; i < priv->rx_ring_num; i++) {
 		mlx4_en_deactivate_rx_ring(priv, &priv->rx_ring[i]);
-- 
1.7.1

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH net 4/5] net/mlx4_core: Always use 64 bit resource ID when doing lookup
  2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
                   ` (2 preceding siblings ...)
  2013-03-21 15:55 ` [PATCH net 3/5] net/mlx4_en: Remove ethtool flow steering rules before releasing QPs Or Gerlitz
@ 2013-03-21 15:55 ` Or Gerlitz
  2013-03-21 15:55 ` [PATCH net 5/5] net/mlx4_core: Disallow releasing VF QPs which have steering rules Or Gerlitz
  2013-03-21 16:05 ` [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 David Miller
  5 siblings, 0 replies; 8+ messages in thread
From: Or Gerlitz @ 2013-03-21 15:55 UTC (permalink / raw)
  To: davem; +Cc: netdev, amirv, jackm, hadarh, Or Gerlitz

From: Hadar Hen Zion <hadarh@mellanox.com>

One of the resource tracker code paths was wrongly using int and not u64
for resource tracking IDs, fix it.

Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
---
 .../net/ethernet/mellanox/mlx4/resource_tracker.c  |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
index 0d1d967..b0ccdb5 100644
--- a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
+++ b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
@@ -355,7 +355,7 @@ static int mpt_mask(struct mlx4_dev *dev)
 	return dev->caps.num_mpts - 1;
 }
 
-static void *find_res(struct mlx4_dev *dev, int res_id,
+static void *find_res(struct mlx4_dev *dev, u64 res_id,
 		      enum mlx4_resource type)
 {
 	struct mlx4_priv *priv = mlx4_priv(dev);
-- 
1.7.1

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH net 5/5] net/mlx4_core: Disallow releasing VF QPs which have steering rules
  2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
                   ` (3 preceding siblings ...)
  2013-03-21 15:55 ` [PATCH net 4/5] net/mlx4_core: Always use 64 bit resource ID when doing lookup Or Gerlitz
@ 2013-03-21 15:55 ` Or Gerlitz
  2013-03-21 16:05 ` [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 David Miller
  5 siblings, 0 replies; 8+ messages in thread
From: Or Gerlitz @ 2013-03-21 15:55 UTC (permalink / raw)
  To: davem; +Cc: netdev, amirv, jackm, hadarh, Or Gerlitz

From: Hadar Hen Zion <hadarh@mellanox.com>

VF QPs must not be released when they have steering rules attached to them.

For that end, introduce a reference count field to the QP object in the
SRIOV resource tracker which is incremented/decremented when steering rules
are attached/detached to it. QPs can be released by VF only when their
ref count is zero.

Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
---
 .../net/ethernet/mellanox/mlx4/resource_tracker.c  |   41 ++++++++++++++++----
 1 files changed, 33 insertions(+), 8 deletions(-)

diff --git a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
index b0ccdb5..1391b52 100644
--- a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
+++ b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c
@@ -99,6 +99,7 @@ struct res_qp {
 	struct list_head	mcg_list;
 	spinlock_t		mcg_spl;
 	int			local_qpn;
+	atomic_t		ref_count;
 };
 
 enum res_mtt_states {
@@ -197,6 +198,7 @@ enum res_fs_rule_states {
 
 struct res_fs_rule {
 	struct res_common	com;
+	int			qpn;
 };
 
 static void *res_tracker_lookup(struct rb_root *root, u64 res_id)
@@ -447,6 +449,7 @@ static struct res_common *alloc_qp_tr(int id)
 	ret->local_qpn = id;
 	INIT_LIST_HEAD(&ret->mcg_list);
 	spin_lock_init(&ret->mcg_spl);
+	atomic_set(&ret->ref_count, 0);
 
 	return &ret->com;
 }
@@ -554,7 +557,7 @@ static struct res_common *alloc_xrcdn_tr(int id)
 	return &ret->com;
 }
 
-static struct res_common *alloc_fs_rule_tr(u64 id)
+static struct res_common *alloc_fs_rule_tr(u64 id, int qpn)
 {
 	struct res_fs_rule *ret;
 
@@ -564,7 +567,7 @@ static struct res_common *alloc_fs_rule_tr(u64 id)
 
 	ret->com.res_id = id;
 	ret->com.state = RES_FS_RULE_ALLOCATED;
-
+	ret->qpn = qpn;
 	return &ret->com;
 }
 
@@ -602,7 +605,7 @@ static struct res_common *alloc_tr(u64 id, enum mlx4_resource type, int slave,
 		ret = alloc_xrcdn_tr(id);
 		break;
 	case RES_FS_RULE:
-		ret = alloc_fs_rule_tr(id);
+		ret = alloc_fs_rule_tr(id, extra);
 		break;
 	default:
 		return NULL;
@@ -671,10 +674,14 @@ undo:
 
 static int remove_qp_ok(struct res_qp *res)
 {
-	if (res->com.state == RES_QP_BUSY)
+	if (res->com.state == RES_QP_BUSY || atomic_read(&res->ref_count) ||
+	    !list_empty(&res->mcg_list)) {
+		pr_err("resource tracker: fail to remove qp, state %d, ref_count %d\n",
+		       res->com.state, atomic_read(&res->ref_count));
 		return -EBUSY;
-	else if (res->com.state != RES_QP_RESERVED)
+	} else if (res->com.state != RES_QP_RESERVED) {
 		return -EPERM;
+	}
 
 	return 0;
 }
@@ -3124,6 +3131,7 @@ int mlx4_QP_FLOW_STEERING_ATTACH_wrapper(struct mlx4_dev *dev, int slave,
 	struct list_head *rlist = &tracker->slave_list[slave].res_list[RES_MAC];
 	int err;
 	int qpn;
+	struct res_qp *rqp;
 	struct mlx4_net_trans_rule_hw_ctrl *ctrl;
 	struct _rule_hw  *rule_header;
 	int header_id;
@@ -3134,7 +3142,7 @@ int mlx4_QP_FLOW_STEERING_ATTACH_wrapper(struct mlx4_dev *dev, int slave,
 
 	ctrl = (struct mlx4_net_trans_rule_hw_ctrl *)inbox->buf;
 	qpn = be32_to_cpu(ctrl->qpn) & 0xffffff;
-	err = get_res(dev, slave, qpn, RES_QP, NULL);
+	err = get_res(dev, slave, qpn, RES_QP, &rqp);
 	if (err) {
 		pr_err("Steering rule with qpn 0x%x rejected.\n", qpn);
 		return err;
@@ -3175,14 +3183,16 @@ int mlx4_QP_FLOW_STEERING_ATTACH_wrapper(struct mlx4_dev *dev, int slave,
 	if (err)
 		goto err_put;
 
-	err = add_res_range(dev, slave, vhcr->out_param, 1, RES_FS_RULE, 0);
+	err = add_res_range(dev, slave, vhcr->out_param, 1, RES_FS_RULE, qpn);
 	if (err) {
 		mlx4_err(dev, "Fail to add flow steering resources.\n ");
 		/* detach rule*/
 		mlx4_cmd(dev, vhcr->out_param, 0, 0,
 			 MLX4_QP_FLOW_STEERING_DETACH, MLX4_CMD_TIME_CLASS_A,
 			 MLX4_CMD_NATIVE);
+		goto err_put;
 	}
+	atomic_inc(&rqp->ref_count);
 err_put:
 	put_res(dev, slave, qpn, RES_QP);
 	return err;
@@ -3195,20 +3205,35 @@ int mlx4_QP_FLOW_STEERING_DETACH_wrapper(struct mlx4_dev *dev, int slave,
 					 struct mlx4_cmd_info *cmd)
 {
 	int err;
+	struct res_qp *rqp;
+	struct res_fs_rule *rrule;
 
 	if (dev->caps.steering_mode !=
 	    MLX4_STEERING_MODE_DEVICE_MANAGED)
 		return -EOPNOTSUPP;
 
+	err = get_res(dev, slave, vhcr->in_param, RES_FS_RULE, &rrule);
+	if (err)
+		return err;
+	/* Release the rule form busy state before removal */
+	put_res(dev, slave, vhcr->in_param, RES_FS_RULE);
+	err = get_res(dev, slave, rrule->qpn, RES_QP, &rqp);
+	if (err)
+		return err;
+
 	err = rem_res_range(dev, slave, vhcr->in_param, 1, RES_FS_RULE, 0);
 	if (err) {
 		mlx4_err(dev, "Fail to remove flow steering resources.\n ");
-		return err;
+		goto out;
 	}
 
 	err = mlx4_cmd(dev, vhcr->in_param, 0, 0,
 		       MLX4_QP_FLOW_STEERING_DETACH, MLX4_CMD_TIME_CLASS_A,
 		       MLX4_CMD_NATIVE);
+	if (!err)
+		atomic_dec(&rqp->ref_count);
+out:
+	put_res(dev, slave, rrule->qpn, RES_QP);
 	return err;
 }
 
-- 
1.7.1

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21
  2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
                   ` (4 preceding siblings ...)
  2013-03-21 15:55 ` [PATCH net 5/5] net/mlx4_core: Disallow releasing VF QPs which have steering rules Or Gerlitz
@ 2013-03-21 16:05 ` David Miller
  5 siblings, 0 replies; 8+ messages in thread
From: David Miller @ 2013-03-21 16:05 UTC (permalink / raw)
  To: ogerlitz; +Cc: netdev, amirv, jackm, hadarh

From: Or Gerlitz <ogerlitz@mellanox.com>
Date: Thu, 21 Mar 2013 17:55:50 +0200

> Here's a batch of mlx4 driver fixes for 3.9, mostly SRIOV/Flow-steering
> related. Series done against the net tree as of commit 5a3da1f
> "inet: limit length of fragment queue hash table bucket lists

Series applied, thanks.

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH net 3/5] net/mlx4_en: Remove ethtool flow steering rules before releasing QPs
  2013-03-21 15:55 ` [PATCH net 3/5] net/mlx4_en: Remove ethtool flow steering rules before releasing QPs Or Gerlitz
@ 2013-03-21 18:28   ` Sergei Shtylyov
  0 siblings, 0 replies; 8+ messages in thread
From: Sergei Shtylyov @ 2013-03-21 18:28 UTC (permalink / raw)
  To: Or Gerlitz; +Cc: davem, netdev, amirv, jackm, hadarh

Hello.

On 03/21/2013 06:55 PM, Or Gerlitz wrote:

> From: Hadar Hen Zion <hadarh@mellanox.com>
>
> Fix the ethtool flow steering rules cleanup to be carried out before
> releasing the RX QPs.
>
> Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
> Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
> ---
>   drivers/net/ethernet/mellanox/mlx4/en_netdev.c |   22 +++++++++++-----------
>   1 files changed, 11 insertions(+), 11 deletions(-)
>
> diff --git a/drivers/net/ethernet/mellanox/mlx4/en_netdev.c b/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
> index 995d4b6..f278b10 100644
> --- a/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
> +++ b/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
> @@ -1637,6 +1637,17 @@ void mlx4_en_stop_port(struct net_device *dev, int detach)
>   	/* Flush multicast filter */
>   	mlx4_SET_MCAST_FLTR(mdev->dev, priv->port, 0, 1, MLX4_MCAST_CONFIG);
>   
> +	/* Remove flow steering rules for the port*/

    Could you add a space before */, despite it was missing before?

WBR, Sergei

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2013-03-21 17:26 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-03-21 15:55 [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 Or Gerlitz
2013-03-21 15:55 ` [PATCH net 1/5] net/mlx4_core: Fix wrong mask applied on EQ numbers in the wrapper Or Gerlitz
2013-03-21 15:55 ` [PATCH net 2/5] net/mlx4_core: Fix wrong order of flow steering resources removal Or Gerlitz
2013-03-21 15:55 ` [PATCH net 3/5] net/mlx4_en: Remove ethtool flow steering rules before releasing QPs Or Gerlitz
2013-03-21 18:28   ` Sergei Shtylyov
2013-03-21 15:55 ` [PATCH net 4/5] net/mlx4_core: Always use 64 bit resource ID when doing lookup Or Gerlitz
2013-03-21 15:55 ` [PATCH net 5/5] net/mlx4_core: Disallow releasing VF QPs which have steering rules Or Gerlitz
2013-03-21 16:05 ` [PATCH net 0/5] Mellanox Core and Ethernet driver fixes 2013-03-21 David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).