aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/qla4xxx
diff options
context:
space:
mode:
authorVikas Chaudhary <vikas.chaudhary@qlogic.com>2011-08-01 06:26:19 -0400
committerJames Bottomley <JBottomley@Parallels.com>2011-08-27 10:36:40 -0400
commit2ada7fc5d4c4ddeb15bb624045fa3b36ddc025e6 (patch)
treeddcdc95c2ebcf8b528fd3da472218aec15304026 /drivers/scsi/qla4xxx
parentfcb5124e03c8158cfe06cb204e1633149edc5f88 (diff)
[SCSI] qla4xxx: added support to update initiator iscsi port
Signed-off-by: Vikas Chaudhary <vikas.chaudhary@qlogic.com> Reviewed-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi/qla4xxx')
-rw-r--r--drivers/scsi/qla4xxx/ql4_def.h2
-rw-r--r--drivers/scsi/qla4xxx/ql4_mbx.c2
-rw-r--r--drivers/scsi/qla4xxx/ql4_os.c19
3 files changed, 23 insertions, 0 deletions
diff --git a/drivers/scsi/qla4xxx/ql4_def.h b/drivers/scsi/qla4xxx/ql4_def.h
index 17a29ceb04e8..c3190eb31141 100644
--- a/drivers/scsi/qla4xxx/ql4_def.h
+++ b/drivers/scsi/qla4xxx/ql4_def.h
@@ -344,6 +344,8 @@ struct ipaddress_config {
344 struct in6_addr ipv6_addr1; 344 struct in6_addr ipv6_addr1;
345 struct in6_addr ipv6_default_router_addr; 345 struct in6_addr ipv6_default_router_addr;
346 uint16_t eth_mtu_size; 346 uint16_t eth_mtu_size;
347 uint16_t ipv4_port;
348 uint16_t ipv6_port;
347}; 349};
348 350
349#define QL4_CHAP_MAX_NAME_LEN 256 351#define QL4_CHAP_MAX_NAME_LEN 256
diff --git a/drivers/scsi/qla4xxx/ql4_mbx.c b/drivers/scsi/qla4xxx/ql4_mbx.c
index 011c822f5ff6..e843758da3d4 100644
--- a/drivers/scsi/qla4xxx/ql4_mbx.c
+++ b/drivers/scsi/qla4xxx/ql4_mbx.c
@@ -335,6 +335,7 @@ qla4xxx_update_local_ip(struct scsi_qla_host *ha,
335 le16_to_cpu(init_fw_cb->ipv4_addr_state); 335 le16_to_cpu(init_fw_cb->ipv4_addr_state);
336 ha->ip_config.eth_mtu_size = 336 ha->ip_config.eth_mtu_size =
337 le16_to_cpu(init_fw_cb->eth_mtu_size); 337 le16_to_cpu(init_fw_cb->eth_mtu_size);
338 ha->ip_config.ipv4_port = le16_to_cpu(init_fw_cb->ipv4_port);
338 339
339 if (ha->acb_version == ACB_SUPPORTED) { 340 if (ha->acb_version == ACB_SUPPORTED) {
340 ha->ip_config.ipv6_options = le16_to_cpu(init_fw_cb->ipv6_opts); 341 ha->ip_config.ipv6_options = le16_to_cpu(init_fw_cb->ipv6_opts);
@@ -384,6 +385,7 @@ qla4xxx_update_local_ip(struct scsi_qla_host *ha,
384 sizeof(init_fw_cb->ipv6_dflt_rtr_addr))); 385 sizeof(init_fw_cb->ipv6_dflt_rtr_addr)));
385 ha->ip_config.ipv6_vlan_tag = 386 ha->ip_config.ipv6_vlan_tag =
386 be16_to_cpu(init_fw_cb->ipv6_vlan_tag); 387 be16_to_cpu(init_fw_cb->ipv6_vlan_tag);
388 ha->ip_config.ipv6_port = le16_to_cpu(init_fw_cb->ipv6_port);
387 } 389 }
388} 390}
389 391
diff --git a/drivers/scsi/qla4xxx/ql4_os.c b/drivers/scsi/qla4xxx/ql4_os.c
index 58a270b74b2a..489d7cd5e0ce 100644
--- a/drivers/scsi/qla4xxx/ql4_os.c
+++ b/drivers/scsi/qla4xxx/ql4_os.c
@@ -231,6 +231,7 @@ static mode_t ql4_attr_is_visible(int param_type, int param)
231 case ISCSI_NET_PARAM_VLAN_PRIORITY: 231 case ISCSI_NET_PARAM_VLAN_PRIORITY:
232 case ISCSI_NET_PARAM_VLAN_ENABLED: 232 case ISCSI_NET_PARAM_VLAN_ENABLED:
233 case ISCSI_NET_PARAM_MTU: 233 case ISCSI_NET_PARAM_MTU:
234 case ISCSI_NET_PARAM_PORT:
234 return S_IRUGO; 235 return S_IRUGO;
235 default: 236 default:
236 return 0; 237 return 0;
@@ -339,6 +340,12 @@ static int qla4xxx_get_iface_param(struct iscsi_iface *iface,
339 case ISCSI_NET_PARAM_MTU: 340 case ISCSI_NET_PARAM_MTU:
340 len = sprintf(buf, "%d\n", ha->ip_config.eth_mtu_size); 341 len = sprintf(buf, "%d\n", ha->ip_config.eth_mtu_size);
341 break; 342 break;
343 case ISCSI_NET_PARAM_PORT:
344 if (iface->iface_type == ISCSI_IFACE_TYPE_IPV4)
345 len = sprintf(buf, "%d\n", ha->ip_config.ipv4_port);
346 else if (iface->iface_type == ISCSI_IFACE_TYPE_IPV6)
347 len = sprintf(buf, "%d\n", ha->ip_config.ipv6_port);
348 break;
342 default: 349 default:
343 len = -ENOSYS; 350 len = -ENOSYS;
344 } 351 }
@@ -726,6 +733,14 @@ static void qla4xxx_set_ipv6(struct scsi_qla_host *ha,
726 init_fw_cb->eth_mtu_size = 733 init_fw_cb->eth_mtu_size =
727 cpu_to_le16(*(uint16_t *)iface_param->value); 734 cpu_to_le16(*(uint16_t *)iface_param->value);
728 break; 735 break;
736 case ISCSI_NET_PARAM_PORT:
737 /* Autocfg applies to even interface */
738 if (iface_param->iface_num & 0x1)
739 break;
740
741 init_fw_cb->ipv6_port =
742 cpu_to_le16(*(uint16_t *)iface_param->value);
743 break;
729 default: 744 default:
730 ql4_printk(KERN_ERR, ha, "Unknown IPv6 param = %d\n", 745 ql4_printk(KERN_ERR, ha, "Unknown IPv6 param = %d\n",
731 iface_param->param); 746 iface_param->param);
@@ -790,6 +805,10 @@ static void qla4xxx_set_ipv4(struct scsi_qla_host *ha,
790 init_fw_cb->eth_mtu_size = 805 init_fw_cb->eth_mtu_size =
791 cpu_to_le16(*(uint16_t *)iface_param->value); 806 cpu_to_le16(*(uint16_t *)iface_param->value);
792 break; 807 break;
808 case ISCSI_NET_PARAM_PORT:
809 init_fw_cb->ipv4_port =
810 cpu_to_le16(*(uint16_t *)iface_param->value);
811 break;
793 default: 812 default:
794 ql4_printk(KERN_ERR, ha, "Unknown IPv4 param = %d\n", 813 ql4_printk(KERN_ERR, ha, "Unknown IPv4 param = %d\n",
795 iface_param->param); 814 iface_param->param);