diff options
author | Jayamohan Kallickal <jayamohan.kallickal@emulex.com> | 2014-05-05 21:41:27 -0400 |
---|---|---|
committer | Christoph Hellwig <hch@lst.de> | 2014-05-28 12:13:15 -0400 |
commit | b3c202dc57607174468b3ea6b4220b7ca5643f05 (patch) | |
tree | 243066fdd53267107236aed2387edf01e24ef91f /drivers/scsi/be2iscsi/be_mgmt.c | |
parent | 73af08e11c6638e2abd6b1fa13cdab58c2bbdbf8 (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.c | 13 |
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; |