diff options
-rw-r--r-- | drivers/scsi/iscsi_tcp.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/scsi/iscsi_tcp.c b/drivers/scsi/iscsi_tcp.c index edebdf27af9b..e5be5fd4ef58 100644 --- a/drivers/scsi/iscsi_tcp.c +++ b/drivers/scsi/iscsi_tcp.c | |||
@@ -1774,12 +1774,12 @@ iscsi_conn_set_param(struct iscsi_cls_conn *cls_conn, enum iscsi_param param, | |||
1774 | break; | 1774 | break; |
1775 | case ISCSI_PARAM_MAX_R2T: | 1775 | case ISCSI_PARAM_MAX_R2T: |
1776 | sscanf(buf, "%d", &value); | 1776 | sscanf(buf, "%d", &value); |
1777 | if (session->max_r2t == roundup_pow_of_two(value)) | 1777 | if (value <= 0 || !is_power_of_2(value)) |
1778 | return -EINVAL; | ||
1779 | if (session->max_r2t == value) | ||
1778 | break; | 1780 | break; |
1779 | iscsi_r2tpool_free(session); | 1781 | iscsi_r2tpool_free(session); |
1780 | iscsi_set_param(cls_conn, param, buf, buflen); | 1782 | iscsi_set_param(cls_conn, param, buf, buflen); |
1781 | if (session->max_r2t & (session->max_r2t - 1)) | ||
1782 | session->max_r2t = roundup_pow_of_two(session->max_r2t); | ||
1783 | if (iscsi_r2tpool_alloc(session)) | 1783 | if (iscsi_r2tpool_alloc(session)) |
1784 | return -ENOMEM; | 1784 | return -ENOMEM; |
1785 | break; | 1785 | break; |