linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Chris Wright <chrisw@osdl.org>
To: Mike Christie <michaelc@cs.wisc.edu>
Cc: linux-kernel@vger.kernel.org,
	linux-scsi <linux-scsi@vger.kernel.org>,
	netdev <netdev@oss.sgi.com>
Subject: Re: [PATCH 3/3] add open iscsi netlink interface to iscsi transport class
Date: Wed, 4 May 2005 22:38:24 -0700	[thread overview]
Message-ID: <20050505053824.GV23013@shell0.pdx.osdl.net> (raw)
In-Reply-To: <42798ADD.5070803@cs.wisc.edu>

* Mike Christie (michaelc@cs.wisc.edu) wrote:

> +static int
> +iscsi_if_recv_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
> +{
> +	int err = 0;
> +	struct iscsi_uevent *ev = NLMSG_DATA(nlh);
> +	struct iscsi_transport *transport = iscsi_ptr(ev->transport_handle);
> +
> +	if (nlh->nlmsg_type != ISCSI_UEVENT_TRANS_LIST &&
> +	    iscsi_if_transport_lookup(transport) < 0)
> +		return -EEXIST;
> +
> +	daemon_pid = NETLINK_CREDS(skb)->pid;
> +

Are any of these message types privileged operations?  I didn't notice
any real credential check.

> +	switch (nlh->nlmsg_type) {
> +	case ISCSI_UEVENT_TRANS_LIST: {
> +		int i;
> +
> +		for (i = 0; i < ISCSI_TRANSPORT_MAX; i++) {
> +			if (transport_table[i]) {
> +				ev->r.t_list.elements[i].trans_handle =
> +					iscsi_handle(transport_table[i]);
> +				strncpy(ev->r.t_list.elements[i].name,
> +					transport_table[i]->name,
> +					ISCSI_TRANSPORT_NAME_MAXLEN);
> +			} else
> +				ev->r.t_list.elements[i].trans_handle =
> +					iscsi_handle(NULL);
> +		}
> +	      } break;
> +	case ISCSI_UEVENT_CREATE_SESSION:
> +		err = iscsi_if_create_snx(transport, ev);
> +		break;
> +	case ISCSI_UEVENT_DESTROY_SESSION:
> +		err = iscsi_if_destroy_snx(transport, ev);
> +		break;
> +	case ISCSI_UEVENT_CREATE_CNX:
> +		err = iscsi_if_create_cnx(transport, ev);
> +		break;
> +	case ISCSI_UEVENT_DESTROY_CNX:
> +		err = iscsi_if_destroy_cnx(transport, ev);
> +		break;
> +	case ISCSI_UEVENT_BIND_CNX:
> +		if (!iscsi_if_find_cnx(ev->u.b_cnx.cnx_handle, H_TYPE_TRANS))
> +			return -EEXIST;
> +		ev->r.retcode = transport->bind_cnx(
> +			ev->u.b_cnx.session_handle,
> +			ev->u.b_cnx.cnx_handle,
> +			ev->u.b_cnx.transport_fd,
> +			ev->u.b_cnx.is_leading);
> +		break;
> +	case ISCSI_UEVENT_SET_PARAM:
> +		if (!iscsi_if_find_cnx(ev->u.set_param.cnx_handle,
> +				       H_TYPE_TRANS))
> +			return -EEXIST;
> +		ev->r.retcode = transport->set_param(
> +			ev->u.set_param.cnx_handle,
> +			ev->u.set_param.param, ev->u.set_param.value);
> +		break;
> +	case ISCSI_UEVENT_START_CNX:
> +		if (!iscsi_if_find_cnx(ev->u.start_cnx.cnx_handle,
> +				       H_TYPE_TRANS))
> +			return -EEXIST;
> +		ev->r.retcode = transport->start_cnx(
> +			ev->u.start_cnx.cnx_handle);
> +		break;
> +	case ISCSI_UEVENT_STOP_CNX:
> +		if (!iscsi_if_find_cnx(ev->u.stop_cnx.cnx_handle, H_TYPE_TRANS))
> +			return -EEXIST;
> +		transport->stop_cnx(ev->u.stop_cnx.cnx_handle,
> +			ev->u.stop_cnx.flag);
> +		break;
> +	case ISCSI_UEVENT_SEND_PDU:
> +		if (!iscsi_if_find_cnx(ev->u.send_pdu.cnx_handle,
> +				       H_TYPE_TRANS))
> +			return -EEXIST;
> +		ev->r.retcode = transport->send_pdu(
> +		       ev->u.send_pdu.cnx_handle,
> +		       (struct iscsi_hdr*)((char*)ev + sizeof(*ev)),
> +		       (char*)ev + sizeof(*ev) + ev->u.send_pdu.hdr_size,
> +			ev->u.send_pdu.data_size);
> +		break;
> +	case ISCSI_UEVENT_GET_STATS: {
> +		struct iscsi_stats *stats;
> +		struct sk_buff *skbstat;
> +		struct iscsi_if_cnx *cnx;
> +		struct nlmsghdr	*nlhstat;
> +		struct iscsi_uevent *evstat;
> +		int len = NLMSG_SPACE(sizeof(*ev) +
> +				sizeof(struct iscsi_stats) +
> +                                sizeof(struct iscsi_stats_custom) *
> +                                                ISCSI_STATS_CUSTOM_MAX);
> +		int err;
> +
> +		cnx = iscsi_if_find_cnx(ev->u.get_stats.cnx_handle,
> +					H_TYPE_TRANS);
> +		if (!cnx)
> +			return -EEXIST;
> +
> +		do {
> +			int actual_size;
> +
> +			skbstat = mempool_zone_get_skb(&cnx->z_pdu);
> +			if (!skbstat) {
> +				printk("iscsi%d: can not deliver stats: OOM\n",
> +				       cnx->host->host_no);
> +				return -ENOMEM;
> +			}
> +
> +			nlhstat = __nlmsg_put(skbstat, daemon_pid, 0, 0,
> +						(len - sizeof(*nlhstat)));
> +			evstat = NLMSG_DATA(nlhstat);
> +			memset(evstat, 0, sizeof(*evstat));
> +			evstat->transport_handle = iscsi_handle(cnx->transport);
> +			evstat->type = nlh->nlmsg_type;
> +			if (cnx->z_pdu.allocated >= cnx->z_pdu.hiwat)
> +				evstat->iferror = -ENOMEM;
> +			evstat->u.get_stats.cnx_handle =
> +					ev->u.get_stats.cnx_handle;
> +			stats = (struct iscsi_stats *)
> +					((char*)evstat + sizeof(*evstat));
> +			memset(stats, 0, sizeof(*stats));
> +
> +			transport->get_stats(ev->u.get_stats.cnx_handle, stats);
> +			actual_size = NLMSG_SPACE(sizeof(struct iscsi_uevent) +
> +					sizeof(struct iscsi_stats) +
> +                                	sizeof(struct iscsi_stats_custom) *
> +						stats->custom_length);
> +			actual_size -= sizeof(*nlhstat);
> +			actual_size = NLMSG_LENGTH(actual_size);
> +			skb_trim(skb, NLMSG_ALIGN(actual_size));
> +			nlhstat->nlmsg_len = actual_size;
> +
> +			err = iscsi_unicast_skb(&cnx->z_pdu, skbstat);
> +		} while (err < 0 && err != -ECONNREFUSED);
> +		} break;
> +	default:
> +		err = -EINVAL;
> +		break;
> +	}
> +
> +	return err;
> +}

  reply	other threads:[~2005-05-05  5:40 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-05-05  2:54 [PATCH 3/3] add open iscsi netlink interface to iscsi transport class Mike Christie
2005-05-05  5:38 ` Chris Wright [this message]
2005-05-05 11:37 ` Christoph Hellwig
2005-05-15 19:30 Mike Christie

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20050505053824.GV23013@shell0.pdx.osdl.net \
    --to=chrisw@osdl.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-scsi@vger.kernel.org \
    --cc=michaelc@cs.wisc.edu \
    --cc=netdev@oss.sgi.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).