Skip to content

Commit 32f16e1

Browse files
committed
Merge branch 'mlx5-fixes'
Saeed Mahameed says: ==================== Mellanox 100G mlx5 fixes 2016-12-04 Some bug fixes for mlx5 core and mlx5e driver. v1->v2: - replace "uint" with "unsigned int" ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
2 parents f85de66 + c0f1147 commit 32f16e1

8 files changed

Lines changed: 53 additions & 42 deletions

File tree

drivers/net/ethernet/mellanox/mlx5/core/cmd.c

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -268,11 +268,6 @@ static void dump_buf(void *buf, int size, int data_only, int offset)
268268
pr_debug("\n");
269269
}
270270

271-
enum {
272-
MLX5_DRIVER_STATUS_ABORTED = 0xfe,
273-
MLX5_DRIVER_SYND = 0xbadd00de,
274-
};
275-
276271
static int mlx5_internal_err_ret_value(struct mlx5_core_dev *dev, u16 op,
277272
u32 *synd, u8 *status)
278273
{

drivers/net/ethernet/mellanox/mlx5/core/en.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -241,7 +241,7 @@ struct mlx5e_tstamp {
241241
};
242242

243243
enum {
244-
MLX5E_RQ_STATE_FLUSH,
244+
MLX5E_RQ_STATE_ENABLED,
245245
MLX5E_RQ_STATE_UMR_WQE_IN_PROGRESS,
246246
MLX5E_RQ_STATE_AM,
247247
};
@@ -394,7 +394,7 @@ struct mlx5e_sq_dma {
394394
};
395395

396396
enum {
397-
MLX5E_SQ_STATE_FLUSH,
397+
MLX5E_SQ_STATE_ENABLED,
398398
MLX5E_SQ_STATE_BF_ENABLE,
399399
};
400400

drivers/net/ethernet/mellanox/mlx5/core/en_main.c

Lines changed: 9 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -759,6 +759,7 @@ static int mlx5e_open_rq(struct mlx5e_channel *c,
759759
if (err)
760760
goto err_destroy_rq;
761761

762+
set_bit(MLX5E_RQ_STATE_ENABLED, &rq->state);
762763
err = mlx5e_modify_rq_state(rq, MLX5_RQC_STATE_RST, MLX5_RQC_STATE_RDY);
763764
if (err)
764765
goto err_disable_rq;
@@ -773,6 +774,7 @@ static int mlx5e_open_rq(struct mlx5e_channel *c,
773774
return 0;
774775

775776
err_disable_rq:
777+
clear_bit(MLX5E_RQ_STATE_ENABLED, &rq->state);
776778
mlx5e_disable_rq(rq);
777779
err_destroy_rq:
778780
mlx5e_destroy_rq(rq);
@@ -782,7 +784,7 @@ static int mlx5e_open_rq(struct mlx5e_channel *c,
782784

783785
static void mlx5e_close_rq(struct mlx5e_rq *rq)
784786
{
785-
set_bit(MLX5E_RQ_STATE_FLUSH, &rq->state);
787+
clear_bit(MLX5E_RQ_STATE_ENABLED, &rq->state);
786788
napi_synchronize(&rq->channel->napi); /* prevent mlx5e_post_rx_wqes */
787789
cancel_work_sync(&rq->am.work);
788790

@@ -1006,7 +1008,6 @@ static int mlx5e_enable_sq(struct mlx5e_sq *sq, struct mlx5e_sq_param *param)
10061008
MLX5_SET(sqc, sqc, min_wqe_inline_mode, sq->min_inline_mode);
10071009
MLX5_SET(sqc, sqc, state, MLX5_SQC_STATE_RST);
10081010
MLX5_SET(sqc, sqc, tis_lst_sz, param->type == MLX5E_SQ_ICO ? 0 : 1);
1009-
MLX5_SET(sqc, sqc, flush_in_error_en, 1);
10101011

10111012
MLX5_SET(wq, wq, wq_type, MLX5_WQ_TYPE_CYCLIC);
10121013
MLX5_SET(wq, wq, uar_page, sq->uar.index);
@@ -1083,6 +1084,7 @@ static int mlx5e_open_sq(struct mlx5e_channel *c,
10831084
if (err)
10841085
goto err_destroy_sq;
10851086

1087+
set_bit(MLX5E_SQ_STATE_ENABLED, &sq->state);
10861088
err = mlx5e_modify_sq(sq, MLX5_SQC_STATE_RST, MLX5_SQC_STATE_RDY,
10871089
false, 0);
10881090
if (err)
@@ -1096,6 +1098,7 @@ static int mlx5e_open_sq(struct mlx5e_channel *c,
10961098
return 0;
10971099

10981100
err_disable_sq:
1101+
clear_bit(MLX5E_SQ_STATE_ENABLED, &sq->state);
10991102
mlx5e_disable_sq(sq);
11001103
err_destroy_sq:
11011104
mlx5e_destroy_sq(sq);
@@ -1112,7 +1115,7 @@ static inline void netif_tx_disable_queue(struct netdev_queue *txq)
11121115

11131116
static void mlx5e_close_sq(struct mlx5e_sq *sq)
11141117
{
1115-
set_bit(MLX5E_SQ_STATE_FLUSH, &sq->state);
1118+
clear_bit(MLX5E_SQ_STATE_ENABLED, &sq->state);
11161119
/* prevent netif_tx_wake_queue */
11171120
napi_synchronize(&sq->channel->napi);
11181121

@@ -3092,7 +3095,7 @@ static void mlx5e_tx_timeout(struct net_device *dev)
30923095
if (!netif_xmit_stopped(netdev_get_tx_queue(dev, i)))
30933096
continue;
30943097
sched_work = true;
3095-
set_bit(MLX5E_SQ_STATE_FLUSH, &sq->state);
3098+
clear_bit(MLX5E_SQ_STATE_ENABLED, &sq->state);
30963099
netdev_err(dev, "TX timeout on queue: %d, SQ: 0x%x, CQ: 0x%x, SQ Cons: 0x%x SQ Prod: 0x%x\n",
30973100
i, sq->sqn, sq->cq.mcq.cqn, sq->cc, sq->pc);
30983101
}
@@ -3147,13 +3150,13 @@ static int mlx5e_xdp_set(struct net_device *netdev, struct bpf_prog *prog)
31473150
for (i = 0; i < priv->params.num_channels; i++) {
31483151
struct mlx5e_channel *c = priv->channel[i];
31493152

3150-
set_bit(MLX5E_RQ_STATE_FLUSH, &c->rq.state);
3153+
clear_bit(MLX5E_RQ_STATE_ENABLED, &c->rq.state);
31513154
napi_synchronize(&c->napi);
31523155
/* prevent mlx5e_poll_rx_cq from accessing rq->xdp_prog */
31533156

31543157
old_prog = xchg(&c->rq.xdp_prog, prog);
31553158

3156-
clear_bit(MLX5E_RQ_STATE_FLUSH, &c->rq.state);
3159+
set_bit(MLX5E_RQ_STATE_ENABLED, &c->rq.state);
31573160
/* napi_schedule in case we have missed anything */
31583161
set_bit(MLX5E_CHANNEL_NAPI_SCHED, &c->flags);
31593162
napi_schedule(&c->napi);

drivers/net/ethernet/mellanox/mlx5/core/en_rx.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -340,7 +340,7 @@ static inline void mlx5e_post_umr_wqe(struct mlx5e_rq *rq, u16 ix)
340340
while ((pi = (sq->pc & wq->sz_m1)) > sq->edge) {
341341
sq->db.ico_wqe[pi].opcode = MLX5_OPCODE_NOP;
342342
sq->db.ico_wqe[pi].num_wqebbs = 1;
343-
mlx5e_send_nop(sq, true);
343+
mlx5e_send_nop(sq, false);
344344
}
345345

346346
wqe = mlx5_wq_cyc_get_wqe(wq, pi);
@@ -412,7 +412,7 @@ void mlx5e_post_rx_mpwqe(struct mlx5e_rq *rq)
412412

413413
clear_bit(MLX5E_RQ_STATE_UMR_WQE_IN_PROGRESS, &rq->state);
414414

415-
if (unlikely(test_bit(MLX5E_RQ_STATE_FLUSH, &rq->state))) {
415+
if (unlikely(!test_bit(MLX5E_RQ_STATE_ENABLED, &rq->state))) {
416416
mlx5e_free_rx_mpwqe(rq, &rq->mpwqe.info[wq->head]);
417417
return;
418418
}
@@ -445,7 +445,7 @@ void mlx5e_dealloc_rx_mpwqe(struct mlx5e_rq *rq, u16 ix)
445445
}
446446

447447
#define RQ_CANNOT_POST(rq) \
448-
(test_bit(MLX5E_RQ_STATE_FLUSH, &rq->state) || \
448+
(!test_bit(MLX5E_RQ_STATE_ENABLED, &rq->state) || \
449449
test_bit(MLX5E_RQ_STATE_UMR_WQE_IN_PROGRESS, &rq->state))
450450

451451
bool mlx5e_post_rx_wqes(struct mlx5e_rq *rq)
@@ -924,7 +924,7 @@ int mlx5e_poll_rx_cq(struct mlx5e_cq *cq, int budget)
924924
struct mlx5e_sq *xdp_sq = &rq->channel->xdp_sq;
925925
int work_done = 0;
926926

927-
if (unlikely(test_bit(MLX5E_RQ_STATE_FLUSH, &rq->state)))
927+
if (unlikely(!test_bit(MLX5E_RQ_STATE_ENABLED, &rq->state)))
928928
return 0;
929929

930930
if (cq->decmprs_left)

drivers/net/ethernet/mellanox/mlx5/core/en_tx.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -409,7 +409,7 @@ bool mlx5e_poll_tx_cq(struct mlx5e_cq *cq, int napi_budget)
409409

410410
sq = container_of(cq, struct mlx5e_sq, cq);
411411

412-
if (unlikely(test_bit(MLX5E_SQ_STATE_FLUSH, &sq->state)))
412+
if (unlikely(!test_bit(MLX5E_SQ_STATE_ENABLED, &sq->state)))
413413
return false;
414414

415415
npkts = 0;

drivers/net/ethernet/mellanox/mlx5/core/en_txrx.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -56,7 +56,7 @@ static void mlx5e_poll_ico_cq(struct mlx5e_cq *cq)
5656
struct mlx5_cqe64 *cqe;
5757
u16 sqcc;
5858

59-
if (unlikely(test_bit(MLX5E_SQ_STATE_FLUSH, &sq->state)))
59+
if (unlikely(!test_bit(MLX5E_SQ_STATE_ENABLED, &sq->state)))
6060
return;
6161

6262
cqe = mlx5e_get_cqe(cq);
@@ -113,7 +113,7 @@ static inline bool mlx5e_poll_xdp_tx_cq(struct mlx5e_cq *cq)
113113

114114
sq = container_of(cq, struct mlx5e_sq, cq);
115115

116-
if (unlikely(test_bit(MLX5E_SQ_STATE_FLUSH, &sq->state)))
116+
if (unlikely(!test_bit(MLX5E_SQ_STATE_ENABLED, &sq->state)))
117117
return false;
118118

119119
/* sq->cc must be updated only after mlx5_cqwq_update_db_record(),

drivers/net/ethernet/mellanox/mlx5/core/main.c

Lines changed: 25 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -62,13 +62,13 @@ MODULE_DESCRIPTION("Mellanox Connect-IB, ConnectX-4 core driver");
6262
MODULE_LICENSE("Dual BSD/GPL");
6363
MODULE_VERSION(DRIVER_VERSION);
6464

65-
int mlx5_core_debug_mask;
66-
module_param_named(debug_mask, mlx5_core_debug_mask, int, 0644);
65+
unsigned int mlx5_core_debug_mask;
66+
module_param_named(debug_mask, mlx5_core_debug_mask, uint, 0644);
6767
MODULE_PARM_DESC(debug_mask, "debug mask: 1 = dump cmd data, 2 = dump cmd exec time, 3 = both. Default=0");
6868

6969
#define MLX5_DEFAULT_PROF 2
70-
static int prof_sel = MLX5_DEFAULT_PROF;
71-
module_param_named(prof_sel, prof_sel, int, 0444);
70+
static unsigned int prof_sel = MLX5_DEFAULT_PROF;
71+
module_param_named(prof_sel, prof_sel, uint, 0444);
7272
MODULE_PARM_DESC(prof_sel, "profile selector. Valid range 0 - 2");
7373

7474
enum {
@@ -732,13 +732,15 @@ static int mlx5_core_set_issi(struct mlx5_core_dev *dev)
732732
u8 status;
733733

734734
mlx5_cmd_mbox_status(query_out, &status, &syndrome);
735-
if (status == MLX5_CMD_STAT_BAD_OP_ERR) {
736-
pr_debug("Only ISSI 0 is supported\n");
737-
return 0;
735+
if (!status || syndrome == MLX5_DRIVER_SYND) {
736+
mlx5_core_err(dev, "Failed to query ISSI err(%d) status(%d) synd(%d)\n",
737+
err, status, syndrome);
738+
return err;
738739
}
739740

740-
pr_err("failed to query ISSI err(%d)\n", err);
741-
return err;
741+
mlx5_core_warn(dev, "Query ISSI is not supported by FW, ISSI is 0\n");
742+
dev->issi = 0;
743+
return 0;
742744
}
743745

744746
sup_issi = MLX5_GET(query_issi_out, query_out, supported_issi_dw0);
@@ -752,7 +754,8 @@ static int mlx5_core_set_issi(struct mlx5_core_dev *dev)
752754
err = mlx5_cmd_exec(dev, set_in, sizeof(set_in),
753755
set_out, sizeof(set_out));
754756
if (err) {
755-
pr_err("failed to set ISSI=1 err(%d)\n", err);
757+
mlx5_core_err(dev, "Failed to set ISSI to 1 err(%d)\n",
758+
err);
756759
return err;
757760
}
758761

@@ -1227,13 +1230,6 @@ static int init_one(struct pci_dev *pdev,
12271230

12281231
dev->pdev = pdev;
12291232
dev->event = mlx5_core_event;
1230-
1231-
if (prof_sel < 0 || prof_sel >= ARRAY_SIZE(profile)) {
1232-
mlx5_core_warn(dev,
1233-
"selected profile out of range, selecting default (%d)\n",
1234-
MLX5_DEFAULT_PROF);
1235-
prof_sel = MLX5_DEFAULT_PROF;
1236-
}
12371233
dev->profile = &profile[prof_sel];
12381234

12391235
INIT_LIST_HEAD(&priv->ctx_list);
@@ -1450,10 +1446,22 @@ static struct pci_driver mlx5_core_driver = {
14501446
.sriov_configure = mlx5_core_sriov_configure,
14511447
};
14521448

1449+
static void mlx5_core_verify_params(void)
1450+
{
1451+
if (prof_sel >= ARRAY_SIZE(profile)) {
1452+
pr_warn("mlx5_core: WARNING: Invalid module parameter prof_sel %d, valid range 0-%zu, changing back to default(%d)\n",
1453+
prof_sel,
1454+
ARRAY_SIZE(profile) - 1,
1455+
MLX5_DEFAULT_PROF);
1456+
prof_sel = MLX5_DEFAULT_PROF;
1457+
}
1458+
}
1459+
14531460
static int __init init(void)
14541461
{
14551462
int err;
14561463

1464+
mlx5_core_verify_params();
14571465
mlx5_register_debugfs();
14581466

14591467
err = pci_register_driver(&mlx5_core_driver);

drivers/net/ethernet/mellanox/mlx5/core/mlx5_core.h

Lines changed: 10 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -44,11 +44,11 @@
4444

4545
#define MLX5_TOTAL_VPORTS(mdev) (1 + pci_sriov_get_totalvfs(mdev->pdev))
4646

47-
extern int mlx5_core_debug_mask;
47+
extern uint mlx5_core_debug_mask;
4848

4949
#define mlx5_core_dbg(__dev, format, ...) \
50-
dev_dbg(&(__dev)->pdev->dev, "%s:%s:%d:(pid %d): " format, \
51-
(__dev)->priv.name, __func__, __LINE__, current->pid, \
50+
dev_dbg(&(__dev)->pdev->dev, "%s:%d:(pid %d): " format, \
51+
__func__, __LINE__, current->pid, \
5252
##__VA_ARGS__)
5353

5454
#define mlx5_core_dbg_mask(__dev, mask, format, ...) \
@@ -63,8 +63,8 @@ do { \
6363
##__VA_ARGS__)
6464

6565
#define mlx5_core_warn(__dev, format, ...) \
66-
dev_warn(&(__dev)->pdev->dev, "%s:%s:%d:(pid %d): " format, \
67-
(__dev)->priv.name, __func__, __LINE__, current->pid, \
66+
dev_warn(&(__dev)->pdev->dev, "%s:%d:(pid %d): " format, \
67+
__func__, __LINE__, current->pid, \
6868
##__VA_ARGS__)
6969

7070
#define mlx5_core_info(__dev, format, ...) \
@@ -75,6 +75,11 @@ enum {
7575
MLX5_CMD_TIME, /* print command execution time */
7676
};
7777

78+
enum {
79+
MLX5_DRIVER_STATUS_ABORTED = 0xfe,
80+
MLX5_DRIVER_SYND = 0xbadd00de,
81+
};
82+
7883
int mlx5_query_hca_caps(struct mlx5_core_dev *dev);
7984
int mlx5_query_board_id(struct mlx5_core_dev *dev);
8085
int mlx5_cmd_init_hca(struct mlx5_core_dev *dev);

0 commit comments

Comments
 (0)