提交 c93f50c4 编写于 作者: L Lang Cheng 提交者: Zheng Zengkai

RDMA/hns: Add hr_reg_write_bool()

mainline inclusion
from mainline-v5.12-rc1
commit a762fe65
category: bugfix
bugzilla: 174002
CVE:NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=a762fe656b1d59a3d597c0556aa6c029c569364a

----------------------------------------------------------------------

In order to avoid to do bitwise operations on a boolean value, add a new
register interface to avoid sparse comlaint about "dubious: x & !y" when
calling hr_reg_write(ctx, field, !!val).

Fixes: dc504774 ("RDMA/hns: Use new interface to set MPT related fields")
Fixes: 495c2480 ("RDMA/hns: Add XRC subtype in QPC and XRC type in SRQC")
Link: https://lore.kernel.org/r/1624262443-24528-4-git-send-email-liweihang@huawei.comSigned-off-by: NLang Cheng <chenglang@huawei.com>
Signed-off-by: NWeihang Li <liweihang@huawei.com>
Signed-off-by: NJason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Nwangsirong <wangsirong@huawei.com>
Reviewed-by: NChunZhi Hu <huchunzhi@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 fb94f260
...@@ -77,6 +77,14 @@ ...@@ -77,6 +77,14 @@
#define hr_reg_clear(ptr, field) _hr_reg_clear(ptr, field) #define hr_reg_clear(ptr, field) _hr_reg_clear(ptr, field)
#define _hr_reg_write_bool(ptr, field_type, field_h, field_l, val) \
({ \
(val) ? _hr_reg_enable(ptr, field_type, field_h, field_l) : \
_hr_reg_clear(ptr, field_type, field_h, field_l); \
})
#define hr_reg_write_bool(ptr, field, val) _hr_reg_write_bool(ptr, field, val)
#define _hr_reg_write(ptr, field_type, field_h, field_l, val) \ #define _hr_reg_write(ptr, field_type, field_h, field_l, val) \
({ \ ({ \
_hr_reg_clear(ptr, field_type, field_h, field_l); \ _hr_reg_clear(ptr, field_type, field_h, field_l); \
......
...@@ -3091,16 +3091,16 @@ static int hns_roce_v2_write_mtpt(struct hns_roce_dev *hr_dev, ...@@ -3091,16 +3091,16 @@ static int hns_roce_v2_write_mtpt(struct hns_roce_dev *hr_dev,
hr_reg_write(mpt_entry, MPT_PD, mr->pd); hr_reg_write(mpt_entry, MPT_PD, mr->pd);
hr_reg_enable(mpt_entry, MPT_L_INV_EN); hr_reg_enable(mpt_entry, MPT_L_INV_EN);
hr_reg_write(mpt_entry, MPT_BIND_EN, hr_reg_write_bool(mpt_entry, MPT_BIND_EN,
!!(mr->access & IB_ACCESS_MW_BIND)); mr->access & IB_ACCESS_MW_BIND);
hr_reg_write(mpt_entry, MPT_ATOMIC_EN, hr_reg_write_bool(mpt_entry, MPT_ATOMIC_EN,
!!(mr->access & IB_ACCESS_REMOTE_ATOMIC)); mr->access & IB_ACCESS_REMOTE_ATOMIC);
hr_reg_write(mpt_entry, MPT_RR_EN, hr_reg_write_bool(mpt_entry, MPT_RR_EN,
!!(mr->access & IB_ACCESS_REMOTE_READ)); mr->access & IB_ACCESS_REMOTE_READ);
hr_reg_write(mpt_entry, MPT_RW_EN, hr_reg_write_bool(mpt_entry, MPT_RW_EN,
!!(mr->access & IB_ACCESS_REMOTE_WRITE)); mr->access & IB_ACCESS_REMOTE_WRITE);
hr_reg_write(mpt_entry, MPT_LW_EN, hr_reg_write_bool(mpt_entry, MPT_LW_EN,
!!((mr->access & IB_ACCESS_LOCAL_WRITE))); mr->access & IB_ACCESS_LOCAL_WRITE);
mpt_entry->len_l = cpu_to_le32(lower_32_bits(mr->size)); mpt_entry->len_l = cpu_to_le32(lower_32_bits(mr->size));
mpt_entry->len_h = cpu_to_le32(upper_32_bits(mr->size)); mpt_entry->len_h = cpu_to_le32(upper_32_bits(mr->size));
...@@ -5697,8 +5697,8 @@ static int hns_roce_v2_write_srqc(struct hns_roce_srq *srq, void *mb_buf) ...@@ -5697,8 +5697,8 @@ static int hns_roce_v2_write_srqc(struct hns_roce_srq *srq, void *mb_buf)
} }
hr_reg_write(ctx, SRQC_SRQ_ST, 1); hr_reg_write(ctx, SRQC_SRQ_ST, 1);
hr_reg_write(ctx, SRQC_SRQ_TYPE, hr_reg_write_bool(ctx, SRQC_SRQ_TYPE,
!!(srq->ibsrq.srq_type == IB_SRQT_XRC)); srq->ibsrq.srq_type == IB_SRQT_XRC);
hr_reg_write(ctx, SRQC_PD, to_hr_pd(srq->ibsrq.pd)->pdn); hr_reg_write(ctx, SRQC_PD, to_hr_pd(srq->ibsrq.pd)->pdn);
hr_reg_write(ctx, SRQC_SRQN, srq->srqn); hr_reg_write(ctx, SRQC_SRQN, srq->srqn);
hr_reg_write(ctx, SRQC_XRCD, srq->xrcdn); hr_reg_write(ctx, SRQC_XRCD, srq->xrcdn);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册