* [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).