Re: [RFC-v3 03/12] iscsi-target: Add TCM v4 compatiable ConfigFS control plane

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 17 Mar 2011, Nicholas A. Bellinger wrote:

> From: Nicholas Bellinger <nab@xxxxxxxxxxxxxxx>
> 
> This patch adds support for /sys/kernel/config/target/iscsi using
> TCM v4.0 compatiable calls following target_core_fabric_configfs.c
> 
> This includes a number of iSCSI fabric dependent attributes upon
> target_core_fabric_configfs.c provided struct config_item_types from
> include/target/target_core_configfs.hstruct target_fabric_configfs_template
> 
> It also includes iscsi_target_nodeattrib.[c,h] for handling the
> lio_target_nacl_attrib_attrs[] store/show for iSCSI fabric dependent
> attributes.
> 
> Signed-off-by: Nicholas A. Bellinger <nab@xxxxxxxxxxxxxxx>
> ---
>  drivers/target/iscsi/iscsi_target_configfs.c   | 1593 ++++++++++++++++++++++++
>  drivers/target/iscsi/iscsi_target_configfs.h   |    7 +
>  drivers/target/iscsi/iscsi_target_nodeattrib.c |  264 ++++
>  drivers/target/iscsi/iscsi_target_nodeattrib.h |   14 +
>  4 files changed, 1878 insertions(+), 0 deletions(-)
>  create mode 100644 drivers/target/iscsi/iscsi_target_configfs.c
>  create mode 100644 drivers/target/iscsi/iscsi_target_configfs.h
>  create mode 100644 drivers/target/iscsi/iscsi_target_nodeattrib.c
>  create mode 100644 drivers/target/iscsi/iscsi_target_nodeattrib.h
> 
> diff --git a/drivers/target/iscsi/iscsi_target_configfs.c b/drivers/target/iscsi/iscsi_target_configfs.c
> new file mode 100644
> index 0000000..ae88092
> --- /dev/null
> +++ b/drivers/target/iscsi/iscsi_target_configfs.c
> @@ -0,0 +1,1593 @@
> +/*******************************************************************************
> + * This file contains the configfs implementation for iSCSI Target mode
> + * from the LIO-Target Project.
> + *
> + * ?? Copyright 2007-2011 RisingTide Systems LLC.

"??" ?
You have this in other files as well - what's the point of those two 
question marks?


> +struct se_tpg_np *lio_target_call_addnptotpg(
> +	struct se_portal_group *se_tpg,
> +	struct config_group *group,
> +	const char *name)
> +{
> +	struct iscsi_portal_group *tpg;
> +	struct iscsi_tpg_np *tpg_np;
> +	char *str, *str2, *end_ptr, *ip_str, *port_str;
> +	struct iscsi_np_addr np_addr;
> +	u32 ipv4 = 0;
> +	int ret;
> +	char buf[MAX_PORTAL_LEN + 1];
> +
> +	if (strlen(name) > MAX_PORTAL_LEN) {
> +		printk(KERN_ERR "strlen(name): %d exceeds MAX_PORTAL_LEN: %d\n",
> +			(int)strlen(name), MAX_PORTAL_LEN);
> +		return ERR_PTR(-EOVERFLOW);
> +	}
> +	memset(buf, 0, MAX_PORTAL_LEN);

memset(buf, 0, MAX_PORTAL_LEN + 1);


> +#define DEF_NACL_ATTRIB(name)						\
> +static ssize_t iscsi_nacl_attrib_show_##name(				\
> +	struct se_node_acl *se_nacl,					\
> +	char *page)							\
> +{									\
> +	struct iscsi_node_acl *nacl = container_of(se_nacl, struct iscsi_node_acl, \
> +					se_node_acl);			\
> +	ssize_t rb;							\
> +									\
> +	rb = sprintf(page, "%u\n", ISCSI_NODE_ATTRIB(nacl)->name);	\
> +	return rb;							\

Why the 'rb' variable? Why not just

return sprintf(page, "%u\n", ISCSI_NODE_ATTRIB(nacl)->name);

?


> +#define __DEF_NACL_AUTH_STR(prefix, name, flags)			\
> +static ssize_t __iscsi_##prefix##_show_##name(				\
> +	struct iscsi_node_acl *nacl,					\
> +	char *page)							\
> +{									\
> +	struct iscsi_node_auth *auth = &nacl->node_auth;		\
> +	ssize_t rb;							\
> +									\
> +	if (!capable(CAP_SYS_ADMIN))					\
> +		return -EPERM;						\
> +	rb = snprintf(page, PAGE_SIZE, "%s\n", auth->name);		\
> +	return rb;							\

Kill 'rb' and just 

  return snprintf(page, PAGE_SIZE, "%s\n", auth->name);

I'd say.


> +#define __DEF_NACL_AUTH_INT(prefix, name)				\
> +static ssize_t __iscsi_##prefix##_show_##name(				\
> +	struct iscsi_node_acl *nacl,					\
> +	char *page)							\
> +{									\
> +	struct iscsi_node_auth *auth = &nacl->node_auth;		\
> +	ssize_t rb;							\
> +									\
> +	if (!capable(CAP_SYS_ADMIN))					\
> +		return -EPERM;						\
> +									\
> +	rb = snprintf(page, PAGE_SIZE, "%d\n", auth->name);		\
> +	return rb;							\

Just kill that pointless 'rb' variable..


> +static ssize_t lio_target_nacl_show_info(
> +	struct se_node_acl *se_nacl,
> +	char *page)
> +{
> +	struct iscsi_session *sess;
> +	struct iscsi_conn *conn;
> +	struct se_session *se_sess;
> +	unsigned char *ip, buf_ipv4[IPV4_BUF_SIZE];
> +	ssize_t rb = 0;
> +
> +	spin_lock_bh(&se_nacl->nacl_sess_lock);
> +	se_sess = se_nacl->nacl_sess;
> +	if (!se_sess) {
> +		rb += sprintf(page+rb, "No active iSCSI Session for Initiator"
> +			" Endpoint: %s\n", se_nacl->initiatorname);
> +	} else {
> +		sess = (struct iscsi_session *)se_sess->fabric_sess_ptr;
> +

Is this cast needed?


> +static ssize_t iscsi_tpg_param_store_##name(				\
> +	struct se_portal_group *se_tpg,				\
> +	const char *page,						\
> +	size_t count)							\
> +{									\
> +	struct iscsi_portal_group *tpg = container_of(se_tpg,		\
> +			struct iscsi_portal_group, tpg_se_tpg);		\
> +	char *buf;							\
> +	int ret;							\
> +									\
> +	buf = kzalloc(PAGE_SIZE, GFP_KERNEL);				\
> +	if (!buf)							\
> +		return -ENOMEM;						\
> +	snprintf(buf, PAGE_SIZE, "%s=%s", __stringify(name), page);	\
> +	buf[strlen(buf)-1] = '\0'; /* Kill newline */			\
> +									\
> +	if (iscsi_get_tpg(tpg) < 0)					\
> +		return -EINVAL;						\

You just leaked "buf".


-- 
Jesper Juhl <jj@xxxxxxxxxxxxx>            http://www.chaosbits.net/
Don't top-post http://www.catb.org/~esr/jargon/html/T/top-post.html
Plain text mails only, please.

--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux