Commit 079587b4 authored by Kiran Patil's avatar Kiran Patil Committed by Nicholas A. Bellinger

tcm_fc: Invalidation of DDP context for FCoE target in error conditions

Problem: HW DDP context wasn;t invalidated in case of ABORTS, etc...
This leads to the problem where memory pages which are used for DDP
as user descriptor could get reused for some other purpose (such as to
satisfy new memory allocation request either by kernel or user mode threads)
and since HW DDP context was not invalidated, HW continue to write to
those pages, hence causing memory corruption.

Fix: Either on incoming ABORTS or due to exchange time out, allowed the
target to cleanup HW DDP context if it was setup for respective ft_cmd.
Added new function to perform this cleanup, furthur it can be enhanced
for other cleanup activity.

Additinal Notes: To avoid calling ddp_done from multiple places, composed
the functionality in helper function "ft_invl_hw_context" and it is being
called from multiple places. Cleaned up code in function "ft_recv_write_data"
w.r.t DDP.
Signed-off-by: default avatarKiran Patil <kiran.patil@intel.com>
Signed-off-by: default avatarNicholas Bellinger <nab@linux-iscsi.org>
parent bcac364a
...@@ -219,20 +219,17 @@ void ft_recv_write_data(struct ft_cmd *cmd, struct fc_frame *fp) ...@@ -219,20 +219,17 @@ void ft_recv_write_data(struct ft_cmd *cmd, struct fc_frame *fp)
if (cmd->was_ddp_setup) { if (cmd->was_ddp_setup) {
BUG_ON(!ep); BUG_ON(!ep);
BUG_ON(!lport); BUG_ON(!lport);
}
/* /*
* Doesn't expect payload if DDP is setup. Payload * Since DDP (Large Rx offload) was setup for this request,
* is expected to be copied directly to user buffers * payload is expected to be copied directly to user buffers.
* due to DDP (Large Rx offload),
*/ */
buf = fc_frame_payload_get(fp, 1); buf = fc_frame_payload_get(fp, 1);
if (buf) if (buf)
pr_err("%s: xid 0x%x, f_ctl 0x%x, cmd->sg %p, " pr_err("%s: xid 0x%x, f_ctl 0x%x, cmd->sg %p, "
"cmd->sg_cnt 0x%x. DDP was setup" "cmd->sg_cnt 0x%x. DDP was setup"
" hence not expected to receive frame with " " hence not expected to receive frame with "
"payload, Frame will be dropped if " "payload, Frame will be dropped if"
"'Sequence Initiative' bit in f_ctl is " "'Sequence Initiative' bit in f_ctl is"
"not set\n", __func__, ep->xid, f_ctl, "not set\n", __func__, ep->xid, f_ctl,
cmd->sg, cmd->sg_cnt); cmd->sg, cmd->sg_cnt);
/* /*
...@@ -256,6 +253,7 @@ void ft_recv_write_data(struct ft_cmd *cmd, struct fc_frame *fp) ...@@ -256,6 +253,7 @@ void ft_recv_write_data(struct ft_cmd *cmd, struct fc_frame *fp)
goto last_frame; goto last_frame;
else else
goto drop; goto drop;
}
rel_off = ntohl(fh->fh_parm_offset); rel_off = ntohl(fh->fh_parm_offset);
frame_len = fr_len(fp); frame_len = fr_len(fp);
......
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