Commit 73bc06b7 authored by Sagi Grimberg's avatar Sagi Grimberg Committed by Roland Dreier

IB/iser: Replace fastreg descriptor valid bool with indicators container

In T10-PI support we will have memory keys for protection buffers and
signature transactions.  We prefer to compact indicators rather than
keeping multiple bools.

This commit does not change any functionality.
Signed-off-by: default avatarSagi Grimberg <sagig@mellanox.com>
Signed-off-by: default avatarAlex Tabachnik <alext@mellanox.com>
Signed-off-by: default avatarRoland Dreier <roland@purestorage.com>
parent 65198d6b
...@@ -280,13 +280,17 @@ struct iser_device { ...@@ -280,13 +280,17 @@ struct iser_device {
enum iser_data_dir cmd_dir); enum iser_data_dir cmd_dir);
}; };
enum iser_reg_indicator {
ISER_DATA_KEY_VALID = 1 << 0,
};
struct fast_reg_descriptor { struct fast_reg_descriptor {
struct list_head list; struct list_head list;
/* For fast registration - FRWR */ /* For fast registration - FRWR */
struct ib_mr *data_mr; struct ib_mr *data_mr;
struct ib_fast_reg_page_list *data_frpl; struct ib_fast_reg_page_list *data_frpl;
/* Valid for fast registration flag */ /* registration indicators container */
bool valid; u8 reg_indicators;
}; };
struct iser_conn { struct iser_conn {
......
...@@ -479,7 +479,7 @@ static int iser_fast_reg_mr(struct iscsi_iser_task *iser_task, ...@@ -479,7 +479,7 @@ static int iser_fast_reg_mr(struct iscsi_iser_task *iser_task,
return -EINVAL; return -EINVAL;
} }
if (!desc->valid) { if (!(desc->reg_indicators & ISER_DATA_KEY_VALID)) {
memset(&inv_wr, 0, sizeof(inv_wr)); memset(&inv_wr, 0, sizeof(inv_wr));
inv_wr.wr_id = ISER_FASTREG_LI_WRID; inv_wr.wr_id = ISER_FASTREG_LI_WRID;
inv_wr.opcode = IB_WR_LOCAL_INV; inv_wr.opcode = IB_WR_LOCAL_INV;
...@@ -514,7 +514,7 @@ static int iser_fast_reg_mr(struct iscsi_iser_task *iser_task, ...@@ -514,7 +514,7 @@ static int iser_fast_reg_mr(struct iscsi_iser_task *iser_task,
iser_err("fast registration failed, ret:%d\n", ret); iser_err("fast registration failed, ret:%d\n", ret);
return ret; return ret;
} }
desc->valid = false; desc->reg_indicators &= ~ISER_DATA_KEY_VALID;
sge->lkey = desc->data_mr->lkey; sge->lkey = desc->data_mr->lkey;
sge->addr = desc->data_frpl->page_list[0] + offset; sge->addr = desc->data_frpl->page_list[0] + offset;
......
...@@ -296,7 +296,7 @@ iser_create_fastreg_desc(struct ib_device *ib_device, struct ib_pd *pd, ...@@ -296,7 +296,7 @@ iser_create_fastreg_desc(struct ib_device *ib_device, struct ib_pd *pd,
} }
iser_info("Create fr_desc %p page_list %p\n", iser_info("Create fr_desc %p page_list %p\n",
desc, desc->data_frpl->page_list); desc, desc->data_frpl->page_list);
desc->valid = true; desc->reg_indicators |= ISER_DATA_KEY_VALID;
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment