Skip to content

Commit bf656b0

Browse files
Yixing Liujgunthorpe
authored andcommitted
RDMA/hns: Adjust definition of FRMR fields
FRMR is not well-supported on HIP08, it is re-designed for HIP09 and the position of related fields is changed. Then the ULPs should be forbidden to use FRMR on older hardwares. Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Yixing Liu <[email protected]> Signed-off-by: Weihang Li <[email protected]> Signed-off-by: Jason Gunthorpe <[email protected]>
1 parent 5e9914c commit bf656b0

File tree

3 files changed

+34
-26
lines changed

3 files changed

+34
-26
lines changed

drivers/infiniband/hw/hns/hns_roce_hw_v2.c

Lines changed: 26 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -99,16 +99,16 @@ static void set_frmr_seg(struct hns_roce_v2_rc_send_wqe *rc_sq_wqe,
9999
u64 pbl_ba;
100100

101101
/* use ib_access_flags */
102-
roce_set_bit(rc_sq_wqe->byte_4, V2_RC_FRMR_WQE_BYTE_4_BIND_EN_S,
103-
wr->access & IB_ACCESS_MW_BIND ? 1 : 0);
104-
roce_set_bit(rc_sq_wqe->byte_4, V2_RC_FRMR_WQE_BYTE_4_ATOMIC_S,
105-
wr->access & IB_ACCESS_REMOTE_ATOMIC ? 1 : 0);
106-
roce_set_bit(rc_sq_wqe->byte_4, V2_RC_FRMR_WQE_BYTE_4_RR_S,
107-
wr->access & IB_ACCESS_REMOTE_READ ? 1 : 0);
108-
roce_set_bit(rc_sq_wqe->byte_4, V2_RC_FRMR_WQE_BYTE_4_RW_S,
109-
wr->access & IB_ACCESS_REMOTE_WRITE ? 1 : 0);
110-
roce_set_bit(rc_sq_wqe->byte_4, V2_RC_FRMR_WQE_BYTE_4_LW_S,
111-
wr->access & IB_ACCESS_LOCAL_WRITE ? 1 : 0);
102+
roce_set_bit(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_BIND_EN_S,
103+
!!(wr->access & IB_ACCESS_MW_BIND));
104+
roce_set_bit(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_ATOMIC_S,
105+
!!(wr->access & IB_ACCESS_REMOTE_ATOMIC));
106+
roce_set_bit(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_RR_S,
107+
!!(wr->access & IB_ACCESS_REMOTE_READ));
108+
roce_set_bit(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_RW_S,
109+
!!(wr->access & IB_ACCESS_REMOTE_WRITE));
110+
roce_set_bit(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_LW_S,
111+
!!(wr->access & IB_ACCESS_LOCAL_WRITE));
112112

113113
/* Data structure reuse may lead to confusion */
114114
pbl_ba = mr->pbl_mtr.hem_cfg.root_ba;
@@ -121,12 +121,10 @@ static void set_frmr_seg(struct hns_roce_v2_rc_send_wqe *rc_sq_wqe,
121121
rc_sq_wqe->va = cpu_to_le64(wr->mr->iova);
122122

123123
fseg->pbl_size = cpu_to_le32(mr->npages);
124-
roce_set_field(fseg->mode_buf_pg_sz,
125-
V2_RC_FRMR_WQE_BYTE_40_PBL_BUF_PG_SZ_M,
124+
roce_set_field(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_PBL_BUF_PG_SZ_M,
126125
V2_RC_FRMR_WQE_BYTE_40_PBL_BUF_PG_SZ_S,
127126
to_hr_hw_page_shift(mr->pbl_mtr.hem_cfg.buf_pg_shift));
128-
roce_set_bit(fseg->mode_buf_pg_sz,
129-
V2_RC_FRMR_WQE_BYTE_40_BLK_MODE_S, 0);
127+
roce_set_bit(fseg->byte_40, V2_RC_FRMR_WQE_BYTE_40_BLK_MODE_S, 0);
130128
}
131129

132130
static void set_atomic_seg(const struct ib_send_wr *wr,
@@ -522,10 +520,12 @@ static inline int set_ud_wqe(struct hns_roce_qp *qp,
522520
return 0;
523521
}
524522

525-
static int set_rc_opcode(struct hns_roce_v2_rc_send_wqe *rc_sq_wqe,
523+
static int set_rc_opcode(struct hns_roce_dev *hr_dev,
524+
struct hns_roce_v2_rc_send_wqe *rc_sq_wqe,
526525
const struct ib_send_wr *wr)
527526
{
528527
u32 ib_op = wr->opcode;
528+
int ret = 0;
529529

530530
rc_sq_wqe->immtdata = get_immtdata(wr);
531531

@@ -545,7 +545,10 @@ static int set_rc_opcode(struct hns_roce_v2_rc_send_wqe *rc_sq_wqe,
545545
rc_sq_wqe->va = cpu_to_le64(atomic_wr(wr)->remote_addr);
546546
break;
547547
case IB_WR_REG_MR:
548-
set_frmr_seg(rc_sq_wqe, reg_wr(wr));
548+
if (hr_dev->pci_dev->revision >= PCI_REVISION_ID_HIP09)
549+
set_frmr_seg(rc_sq_wqe, reg_wr(wr));
550+
else
551+
ret = -EOPNOTSUPP;
549552
break;
550553
case IB_WR_LOCAL_INV:
551554
roce_set_bit(rc_sq_wqe->byte_4, V2_RC_SEND_WQE_BYTE_4_SO_S, 1);
@@ -554,19 +557,23 @@ static int set_rc_opcode(struct hns_roce_v2_rc_send_wqe *rc_sq_wqe,
554557
rc_sq_wqe->inv_key = cpu_to_le32(wr->ex.invalidate_rkey);
555558
break;
556559
default:
557-
return -EINVAL;
560+
ret = -EINVAL;
558561
}
559562

563+
if (unlikely(ret))
564+
return ret;
565+
560566
roce_set_field(rc_sq_wqe->byte_4, V2_RC_SEND_WQE_BYTE_4_OPCODE_M,
561567
V2_RC_SEND_WQE_BYTE_4_OPCODE_S, to_hr_opcode(ib_op));
562568

563-
return 0;
569+
return ret;
564570
}
565571
static inline int set_rc_wqe(struct hns_roce_qp *qp,
566572
const struct ib_send_wr *wr,
567573
void *wqe, unsigned int *sge_idx,
568574
unsigned int owner_bit)
569575
{
576+
struct hns_roce_dev *hr_dev = to_hr_dev(qp->ibqp.device);
570577
struct hns_roce_v2_rc_send_wqe *rc_sq_wqe = wqe;
571578
unsigned int curr_idx = *sge_idx;
572579
unsigned int valid_num_sge;
@@ -577,7 +584,7 @@ static inline int set_rc_wqe(struct hns_roce_qp *qp,
577584

578585
rc_sq_wqe->msg_len = cpu_to_le32(msg_len);
579586

580-
ret = set_rc_opcode(rc_sq_wqe, wr);
587+
ret = set_rc_opcode(hr_dev, rc_sq_wqe, wr);
581588
if (WARN_ON(ret))
582589
return ret;
583590

drivers/infiniband/hw/hns/hns_roce_hw_v2.h

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1255,15 +1255,15 @@ struct hns_roce_v2_rc_send_wqe {
12551255

12561256
#define V2_RC_SEND_WQE_BYTE_4_INLINE_S 12
12571257

1258-
#define V2_RC_FRMR_WQE_BYTE_4_BIND_EN_S 19
1258+
#define V2_RC_FRMR_WQE_BYTE_40_BIND_EN_S 10
12591259

1260-
#define V2_RC_FRMR_WQE_BYTE_4_ATOMIC_S 20
1260+
#define V2_RC_FRMR_WQE_BYTE_40_ATOMIC_S 11
12611261

1262-
#define V2_RC_FRMR_WQE_BYTE_4_RR_S 21
1262+
#define V2_RC_FRMR_WQE_BYTE_40_RR_S 12
12631263

1264-
#define V2_RC_FRMR_WQE_BYTE_4_RW_S 22
1264+
#define V2_RC_FRMR_WQE_BYTE_40_RW_S 13
12651265

1266-
#define V2_RC_FRMR_WQE_BYTE_4_LW_S 23
1266+
#define V2_RC_FRMR_WQE_BYTE_40_LW_S 14
12671267

12681268
#define V2_RC_SEND_WQE_BYTE_4_FLAG_S 31
12691269

@@ -1280,7 +1280,7 @@ struct hns_roce_v2_rc_send_wqe {
12801280

12811281
struct hns_roce_wqe_frmr_seg {
12821282
__le32 pbl_size;
1283-
__le32 mode_buf_pg_sz;
1283+
__le32 byte_40;
12841284
};
12851285

12861286
#define V2_RC_FRMR_WQE_BYTE_40_PBL_BUF_PG_SZ_S 4

drivers/infiniband/hw/hns/hns_roce_main.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -201,7 +201,8 @@ static int hns_roce_query_device(struct ib_device *ib_dev,
201201
props->max_srq_sge = hr_dev->caps.max_srq_sges;
202202
}
203203

204-
if (hr_dev->caps.flags & HNS_ROCE_CAP_FLAG_FRMR) {
204+
if (hr_dev->caps.flags & HNS_ROCE_CAP_FLAG_FRMR &&
205+
hr_dev->pci_dev->revision >= PCI_REVISION_ID_HIP09) {
205206
props->device_cap_flags |= IB_DEVICE_MEM_MGT_EXTENSIONS;
206207
props->max_fast_reg_page_list_len = HNS_ROCE_FRMR_MAX_PA;
207208
}

0 commit comments

Comments
 (0)