qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Stefan Hajnoczi <stefanha@gmail.com>
To: "M. Mohan Kumar" <mohan@in.ibm.com>
Cc: blauwirbel@gmail.com, qemu-devel@nongnu.org
Subject: [Qemu-devel] Re: [V5 PATCH 8/8] virtio-9p: Chroot environment for other functions
Date: Thu, 17 Feb 2011 11:02:03 +0000	[thread overview]
Message-ID: <AANLkTinP06GjhjMgD7783pgAnc2pmagoE2q15OfAz9b1@mail.gmail.com> (raw)
In-Reply-To: <1297858995-24676-9-git-send-email-mohan@in.ibm.com>

On Wed, Feb 16, 2011 at 12:23 PM, M. Mohan Kumar <mohan@in.ibm.com> wrote:
> +/*
> + * Returns file descriptor of dirname(path)
> + * This fd can be used by *at functions
> + */
> +static int get_dirfd(FsContext *fs_ctx, const char *path)
> +{
> +    V9fsFileObjectRequest request;
> +    int fd, error = 0;
> +    char *dpath = qemu_strdup(path);
> +
> +    fill_request(&request, dirname(dpath), NULL);
> +    request.data.type = T_OPEN;
> +    fd = v9fs_request(fs_ctx, &request, &error);
> +    if (fd < 0) {
> +        errno = error;
> +    }

man errno says:
"a function that succeeds is allowed to change errno"

Therefore you can't safely use errno to stash your error value and
call any code outside your control because it may overwrite errno.
Obliging callers to take these precautions is a bad idea because they
will forget.

The main feedback I have for this entire patchset is that these
functions introduce layers and layers of weird error handling.  A
large fraction of the code is just propagating error codes.  Sometimes
errno is used, sometimes an int * argument is used, sometime a
positive errno is returned although QEMU code normally returns a
negative errno.  Then the fd_info struct has a flag to indicate the fd
is invalid when we could just set it to -1 to indicate this.  It's
messy and hard for someone else to modify later without introducing
error handling bugs.

The method that fits most with QEMU's codebase is:
int foo(...) /* returns 0 on success, -errno on failure */

If you can refactor the code to unify error handling it will require
fewer lines and be simpler.

Stefan

      reply	other threads:[~2011-02-17 11:02 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-02-16 12:23 [Qemu-devel] [V5 PATCH 0/8] virtio-9p: Use chroot to safely access files in passthrough security model M. Mohan Kumar
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 1/8] Implement qemu_read_full M. Mohan Kumar
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 2/8] virtio-9p: Provide chroot environment server side interfaces M. Mohan Kumar
2011-02-17  8:54   ` [Qemu-devel] " Stefan Hajnoczi
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 3/8] virtio-9p: Add client side interfaces for chroot environment M. Mohan Kumar
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 4/8] virtio-9p: Add support to open a file in " M. Mohan Kumar
2011-02-17 10:23   ` [Qemu-devel] " Stefan Hajnoczi
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 5/8] virtio-9p: Create support " M. Mohan Kumar
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 6/8] virtio-9p: Support for creating special files M. Mohan Kumar
2011-02-17 10:49   ` [Qemu-devel] " Stefan Hajnoczi
2011-02-18  5:58     ` M. Mohan Kumar
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 7/8] virtio-9p: Move file post creation changes to none security model M. Mohan Kumar
2011-02-16 12:23 ` [Qemu-devel] [V5 PATCH 8/8] virtio-9p: Chroot environment for other functions M. Mohan Kumar
2011-02-17 11:02   ` Stefan Hajnoczi [this message]

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=AANLkTinP06GjhjMgD7783pgAnc2pmagoE2q15OfAz9b1@mail.gmail.com \
    --to=stefanha@gmail.com \
    --cc=blauwirbel@gmail.com \
    --cc=mohan@in.ibm.com \
    --cc=qemu-devel@nongnu.org \
    /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).