diff mbox

[v2,11/16] iscsi-target: add new offload transport type

Message ID dd151d75ec506c844b6ecb11b9d72d7e38492647.1460204441.git.varun@chelsio.com (mailing list archive)
State Changes Requested, archived
Headers show

Commit Message

Varun Prakash April 9, 2016, 1:11 p.m. UTC
Add new transport type ISCSI_HW_OFFLOAD,
hw offload transport drivers will use
this transport type.

Signed-off-by: Varun Prakash <varun@chelsio.com>
---
 drivers/target/iscsi/iscsi_target_configfs.c | 76 ++++++++++++++++++++++++++++
 include/target/iscsi/iscsi_target_core.h     |  1 +
 2 files changed, 77 insertions(+)

Comments

Sagi Grimberg April 10, 2016, 5:56 p.m. UTC | #1
> +static ssize_t lio_target_np_hw_offload_show(struct config_item *item,
> +					     char *page)
> +{
> +	struct iscsi_tpg_np *tpg_np = to_iscsi_tpg_np(item);
> +	struct iscsi_tpg_np *tpg_np_hw_offload;
> +	ssize_t rb;
> +
> +	tpg_np_hw_offload = iscsit_tpg_locate_child_np(tpg_np,
> +						       ISCSI_HW_OFFLOAD);
> +	if (tpg_np_hw_offload)
> +		rb = sprintf(page, "1\n");
> +	else
> +		rb = sprintf(page, "0\n");
> +
> +	return rb;
> +}
> +
> +static ssize_t lio_target_np_hw_offload_store(struct config_item *item,
> +					      const char *page, size_t count)
> +{
> +	struct iscsi_tpg_np *tpg_np = to_iscsi_tpg_np(item);
> +	struct iscsi_np *np;
> +	struct iscsi_portal_group *tpg;
> +	struct iscsi_tpg_np *tpg_np_hw_offload = NULL;
> +	u32 op;
> +	int rc = 0;
> +
> +	rc = kstrtou32(page, 0, &op);
> +	if (rc)
> +		return rc;
> +
> +	if ((op != 1) && (op != 0)) {
> +		pr_err("Illegal value for tpg_enable: %u\n", op);
> +		return -EINVAL;
> +	}
> +
> +	np = tpg_np->tpg_np;
> +	if (!np) {
> +		pr_err("Unable to locate struct iscsi_np from"
> +		       " struct iscsi_tpg_np\n");
> +		return -EINVAL;
> +	}
> +
> +	tpg = tpg_np->tpg;
> +	if (iscsit_get_tpg(tpg) < 0)
> +		return -EINVAL;
> +
> +	if (op) {
> +		tpg_np_hw_offload = iscsit_tpg_add_network_portal(tpg,
> +				&np->np_sockaddr, tpg_np, ISCSI_HW_OFFLOAD);
> +
> +		if (IS_ERR(tpg_np_hw_offload)) {
> +			rc = PTR_ERR(tpg_np_hw_offload);
> +			goto out;
> +		}
> +	} else {
> +		tpg_np_hw_offload = iscsit_tpg_locate_child_np(tpg_np,
> +				ISCSI_HW_OFFLOAD);
> +
> +		if (tpg_np_hw_offload) {
> +			rc = iscsit_tpg_del_network_portal(tpg,
> +							   tpg_np_hw_offload);
> +			if (rc < 0)
> +				goto out;
> +		}
> +	}
> +
> +	iscsit_put_tpg(tpg);
> +	return count;
> +out:
> +	iscsit_put_tpg(tpg);
> +	return rc;
> +}
> +
>   CONFIGFS_ATTR(lio_target_np_, sctp);
>   CONFIGFS_ATTR(lio_target_np_, iser);
> +CONFIGFS_ATTR(lio_target_np_, hw_offload);

I'd be happy to see new transports being added with some
initiative to reduce the code duplication here (pretty please :))
--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/target/iscsi/iscsi_target_configfs.c b/drivers/target/iscsi/iscsi_target_configfs.c
index 97e5b69..3565e07 100644
--- a/drivers/target/iscsi/iscsi_target_configfs.c
+++ b/drivers/target/iscsi/iscsi_target_configfs.c
@@ -182,12 +182,88 @@  out:
 	return rc;
 }
 
+static ssize_t lio_target_np_hw_offload_show(struct config_item *item,
+					     char *page)
+{
+	struct iscsi_tpg_np *tpg_np = to_iscsi_tpg_np(item);
+	struct iscsi_tpg_np *tpg_np_hw_offload;
+	ssize_t rb;
+
+	tpg_np_hw_offload = iscsit_tpg_locate_child_np(tpg_np,
+						       ISCSI_HW_OFFLOAD);
+	if (tpg_np_hw_offload)
+		rb = sprintf(page, "1\n");
+	else
+		rb = sprintf(page, "0\n");
+
+	return rb;
+}
+
+static ssize_t lio_target_np_hw_offload_store(struct config_item *item,
+					      const char *page, size_t count)
+{
+	struct iscsi_tpg_np *tpg_np = to_iscsi_tpg_np(item);
+	struct iscsi_np *np;
+	struct iscsi_portal_group *tpg;
+	struct iscsi_tpg_np *tpg_np_hw_offload = NULL;
+	u32 op;
+	int rc = 0;
+
+	rc = kstrtou32(page, 0, &op);
+	if (rc)
+		return rc;
+
+	if ((op != 1) && (op != 0)) {
+		pr_err("Illegal value for tpg_enable: %u\n", op);
+		return -EINVAL;
+	}
+
+	np = tpg_np->tpg_np;
+	if (!np) {
+		pr_err("Unable to locate struct iscsi_np from"
+		       " struct iscsi_tpg_np\n");
+		return -EINVAL;
+	}
+
+	tpg = tpg_np->tpg;
+	if (iscsit_get_tpg(tpg) < 0)
+		return -EINVAL;
+
+	if (op) {
+		tpg_np_hw_offload = iscsit_tpg_add_network_portal(tpg,
+				&np->np_sockaddr, tpg_np, ISCSI_HW_OFFLOAD);
+
+		if (IS_ERR(tpg_np_hw_offload)) {
+			rc = PTR_ERR(tpg_np_hw_offload);
+			goto out;
+		}
+	} else {
+		tpg_np_hw_offload = iscsit_tpg_locate_child_np(tpg_np,
+				ISCSI_HW_OFFLOAD);
+
+		if (tpg_np_hw_offload) {
+			rc = iscsit_tpg_del_network_portal(tpg,
+							   tpg_np_hw_offload);
+			if (rc < 0)
+				goto out;
+		}
+	}
+
+	iscsit_put_tpg(tpg);
+	return count;
+out:
+	iscsit_put_tpg(tpg);
+	return rc;
+}
+
 CONFIGFS_ATTR(lio_target_np_, sctp);
 CONFIGFS_ATTR(lio_target_np_, iser);
+CONFIGFS_ATTR(lio_target_np_, hw_offload);
 
 static struct configfs_attribute *lio_target_portal_attrs[] = {
 	&lio_target_np_attr_sctp,
 	&lio_target_np_attr_iser,
+	&lio_target_np_attr_hw_offload,
 	NULL,
 };
 
diff --git a/include/target/iscsi/iscsi_target_core.h b/include/target/iscsi/iscsi_target_core.h
index 01c41f2..110c1fd 100644
--- a/include/target/iscsi/iscsi_target_core.h
+++ b/include/target/iscsi/iscsi_target_core.h
@@ -74,6 +74,7 @@  enum iscsit_transport_type {
 	ISCSI_IWARP_TCP				= 3,
 	ISCSI_IWARP_SCTP			= 4,
 	ISCSI_INFINIBAND			= 5,
+	ISCSI_HW_OFFLOAD			= 6,
 };
 
 /* RFC-3720 7.1.4  Standard Connection State Diagram for a Target */