aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/be2iscsi/be_mgmt.c
diff options
context:
space:
mode:
authorJayamohan Kallickal <jayamohan.kallickal@emulex.com>2014-05-05 21:41:27 -0400
committerChristoph Hellwig <hch@lst.de>2014-05-28 12:13:15 -0400
commitb3c202dc57607174468b3ea6b4220b7ca5643f05 (patch)
tree243066fdd53267107236aed2387edf01e24ef91f /drivers/scsi/be2iscsi/be_mgmt.c
parent73af08e11c6638e2abd6b1fa13cdab58c2bbdbf8 (diff)
be2iscsi: Fix TCP parameters while connection offloading.
SKH-R adapter, TCP Window Size/Scale parameters are passed in TCP Connection Offload Mbx Command. Signed-off-by: Minh Tran <minhduc.tran@emulex.com> Signed-off-by: John Soni Jose <sony.john-n@emulex.com> Signed-off-by: Jayamohan Kallickal <jayamohan.kallickal@emulex.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'drivers/scsi/be2iscsi/be_mgmt.c')
-rw-r--r--drivers/scsi/be2iscsi/be_mgmt.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/drivers/scsi/be2iscsi/be_mgmt.c b/drivers/scsi/be2iscsi/be_mgmt.c
index 52a36fba1e2b..6045aa78986a 100644
--- a/drivers/scsi/be2iscsi/be_mgmt.c
+++ b/drivers/scsi/be2iscsi/be_mgmt.c
@@ -712,7 +712,7 @@ int mgmt_open_connection(struct beiscsi_hba *phba,
712 struct sockaddr_in6 *daddr_in6 = (struct sockaddr_in6 *)dst_addr; 712 struct sockaddr_in6 *daddr_in6 = (struct sockaddr_in6 *)dst_addr;
713 struct be_ctrl_info *ctrl = &phba->ctrl; 713 struct be_ctrl_info *ctrl = &phba->ctrl;
714 struct be_mcc_wrb *wrb; 714 struct be_mcc_wrb *wrb;
715 struct tcp_connect_and_offload_in *req; 715 struct tcp_connect_and_offload_in_v1 *req;
716 unsigned short def_hdr_id; 716 unsigned short def_hdr_id;
717 unsigned short def_data_id; 717 unsigned short def_data_id;
718 struct phys_addr template_address = { 0, 0 }; 718 struct phys_addr template_address = { 0, 0 };
@@ -745,10 +745,10 @@ int mgmt_open_connection(struct beiscsi_hba *phba,
745 memset(req, 0, sizeof(*req)); 745 memset(req, 0, sizeof(*req));
746 wrb->tag0 |= tag; 746 wrb->tag0 |= tag;
747 747
748 be_wrb_hdr_prepare(wrb, sizeof(*req), false, 1); 748 be_wrb_hdr_prepare(wrb, nonemb_cmd->size, false, 1);
749 be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI, 749 be_cmd_hdr_prepare(&req->hdr, CMD_SUBSYSTEM_ISCSI,
750 OPCODE_COMMON_ISCSI_TCP_CONNECT_AND_OFFLOAD, 750 OPCODE_COMMON_ISCSI_TCP_CONNECT_AND_OFFLOAD,
751 sizeof(*req)); 751 nonemb_cmd->size);
752 if (dst_addr->sa_family == PF_INET) { 752 if (dst_addr->sa_family == PF_INET) {
753 __be32 s_addr = daddr_in->sin_addr.s_addr; 753 __be32 s_addr = daddr_in->sin_addr.s_addr;
754 req->ip_address.ip_type = BE2_IPV4; 754 req->ip_address.ip_type = BE2_IPV4;
@@ -794,6 +794,13 @@ int mgmt_open_connection(struct beiscsi_hba *phba,
794 sge->pa_hi = cpu_to_le32(upper_32_bits(nonemb_cmd->dma)); 794 sge->pa_hi = cpu_to_le32(upper_32_bits(nonemb_cmd->dma));
795 sge->pa_lo = cpu_to_le32(nonemb_cmd->dma & 0xFFFFFFFF); 795 sge->pa_lo = cpu_to_le32(nonemb_cmd->dma & 0xFFFFFFFF);
796 sge->len = cpu_to_le32(nonemb_cmd->size); 796 sge->len = cpu_to_le32(nonemb_cmd->size);
797
798 if (!is_chip_be2_be3r(phba)) {
799 req->hdr.version = MBX_CMD_VER1;
800 req->tcp_window_size = 0;
801 req->tcp_window_scale_count = 2;
802 }
803
797 be_mcc_notify(phba); 804 be_mcc_notify(phba);
798 spin_unlock(&ctrl->mbox_lock); 805 spin_unlock(&ctrl->mbox_lock);
799 return tag; 806 return tag;