]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - drivers/scsi/libiscsi.c
[SCSI] libiscsi: Exporting new attrs for iscsi session and connection in sysfs
[karo-tx-linux.git] / drivers / scsi / libiscsi.c
index ae69dfcc7834c51b8d0e57bd9c7db17dd5a7d029..86153e087e8106ee9ba1546d0b0053b416ad9b06 100644 (file)
@@ -2812,6 +2812,8 @@ void iscsi_session_teardown(struct iscsi_cls_session *cls_session)
        kfree(session->boot_nic);
        kfree(session->boot_target);
        kfree(session->ifacename);
+       kfree(session->portal_type);
+       kfree(session->discovery_parent_type);
 
        iscsi_destroy_session(cls_session);
        iscsi_host_dec_session_cnt(shost);
@@ -3257,6 +3259,11 @@ int iscsi_set_param(struct iscsi_cls_conn *cls_conn,
                return iscsi_switch_str_param(&session->boot_nic, buf);
        case ISCSI_PARAM_BOOT_TARGET:
                return iscsi_switch_str_param(&session->boot_target, buf);
+       case ISCSI_PARAM_PORTAL_TYPE:
+               return iscsi_switch_str_param(&session->portal_type, buf);
+       case ISCSI_PARAM_DISCOVERY_PARENT_TYPE:
+               return iscsi_switch_str_param(&session->discovery_parent_type,
+                                             buf);
        default:
                return -ENOSYS;
        }
@@ -3343,6 +3350,51 @@ int iscsi_session_get_param(struct iscsi_cls_session *cls_session,
                break;
        case ISCSI_PARAM_BOOT_TARGET:
                len = sprintf(buf, "%s\n", session->boot_target);
+       case ISCSI_PARAM_AUTO_SND_TGT_DISABLE:
+               len = sprintf(buf, "%u\n", session->auto_snd_tgt_disable);
+               break;
+       case ISCSI_PARAM_DISCOVERY_SESS:
+               len = sprintf(buf, "%u\n", session->discovery_sess);
+               break;
+       case ISCSI_PARAM_PORTAL_TYPE:
+               len = sprintf(buf, "%s\n", session->portal_type);
+               break;
+       case ISCSI_PARAM_CHAP_AUTH_EN:
+               len = sprintf(buf, "%u\n", session->chap_auth_en);
+               break;
+       case ISCSI_PARAM_DISCOVERY_LOGOUT_EN:
+               len = sprintf(buf, "%u\n", session->discovery_logout_en);
+               break;
+       case ISCSI_PARAM_BIDI_CHAP_EN:
+               len = sprintf(buf, "%u\n", session->bidi_chap_en);
+               break;
+       case ISCSI_PARAM_DISCOVERY_AUTH_OPTIONAL:
+               len = sprintf(buf, "%u\n", session->discovery_auth_optional);
+               break;
+       case ISCSI_PARAM_DEF_TIME2WAIT:
+               len = sprintf(buf, "%d\n", session->time2wait);
+               break;
+       case ISCSI_PARAM_DEF_TIME2RETAIN:
+               len = sprintf(buf, "%d\n", session->time2retain);
+               break;
+       case ISCSI_PARAM_TSID:
+               len = sprintf(buf, "%u\n", session->tsid);
+               break;
+       case ISCSI_PARAM_ISID:
+               len = sprintf(buf, "%02x%02x%02x%02x%02x%02x\n",
+                             session->isid[0], session->isid[1],
+                             session->isid[2], session->isid[3],
+                             session->isid[4], session->isid[5]);
+               break;
+       case ISCSI_PARAM_DISCOVERY_PARENT_IDX:
+               len = sprintf(buf, "%u\n", session->discovery_parent_idx);
+               break;
+       case ISCSI_PARAM_DISCOVERY_PARENT_TYPE:
+               if (session->discovery_parent_type)
+                       len = sprintf(buf, "%s\n",
+                                     session->discovery_parent_type);
+               else
+                       len = sprintf(buf, "\n");
                break;
        default:
                return -ENOSYS;
@@ -3433,6 +3485,51 @@ int iscsi_conn_get_param(struct iscsi_cls_conn *cls_conn,
        case ISCSI_PARAM_PERSISTENT_ADDRESS:
                len = sprintf(buf, "%s\n", conn->persistent_address);
                break;
+       case ISCSI_PARAM_STATSN:
+               len = sprintf(buf, "%u\n", conn->statsn);
+               break;
+       case ISCSI_PARAM_MAX_SEGMENT_SIZE:
+               len = sprintf(buf, "%u\n", conn->max_segment_size);
+               break;
+       case ISCSI_PARAM_KEEPALIVE_TMO:
+               len = sprintf(buf, "%u\n", conn->keepalive_tmo);
+               break;
+       case ISCSI_PARAM_LOCAL_PORT:
+               len = sprintf(buf, "%u\n", conn->local_port);
+               break;
+       case ISCSI_PARAM_TCP_TIMESTAMP_STAT:
+               len = sprintf(buf, "%u\n", conn->tcp_timestamp_stat);
+               break;
+       case ISCSI_PARAM_TCP_NAGLE_DISABLE:
+               len = sprintf(buf, "%u\n", conn->tcp_nagle_disable);
+               break;
+       case ISCSI_PARAM_TCP_WSF_DISABLE:
+               len = sprintf(buf, "%u\n", conn->tcp_wsf_disable);
+               break;
+       case ISCSI_PARAM_TCP_TIMER_SCALE:
+               len = sprintf(buf, "%u\n", conn->tcp_timer_scale);
+               break;
+       case ISCSI_PARAM_TCP_TIMESTAMP_EN:
+               len = sprintf(buf, "%u\n", conn->tcp_timestamp_en);
+               break;
+       case ISCSI_PARAM_IP_FRAGMENT_DISABLE:
+               len = sprintf(buf, "%u\n", conn->fragment_disable);
+               break;
+       case ISCSI_PARAM_IPV4_TOS:
+               len = sprintf(buf, "%u\n", conn->ipv4_tos);
+               break;
+       case ISCSI_PARAM_IPV6_TC:
+               len = sprintf(buf, "%u\n", conn->ipv6_traffic_class);
+               break;
+       case ISCSI_PARAM_IS_FW_ASSIGNED_IPV6:
+               len = sprintf(buf, "%u\n", conn->is_fw_assigned_ipv6);
+               break;
+       case ISCSI_PARAM_TCP_XMIT_WSF:
+               len = sprintf(buf, "%u\n", conn->tcp_xmit_wsf);
+               break;
+       case ISCSI_PARAM_TCP_RECV_WSF:
+               len = sprintf(buf, "%u\n", conn->tcp_recv_wsf);
+               break;
        default:
                return -ENOSYS;
        }