From: Max Reitz <mreitz@redhat.com>
To: Fam Zheng <famz@redhat.com>, qemu-devel@nongnu.org
Cc: Kevin Wolf <kwolf@redhat.com>, Jeff Cody <jcody@redhat.com>,
Markus Armbruster <armbru@redhat.com>,
Eric Blake <eblake@redhat.com>, John Snow <jsnow@redhat.com>,
qemu-block@nongnu.org, berrange@redhat.com, pbonzini@redhat.com,
den@openvz.org, stefanha@redhat.com
Subject: Re: [Qemu-devel] [PATCH v5 08/27] osdep: Add qemu_lock_fd and qemu_unlock_fd
Date: Tue, 24 May 2016 18:42:55 +0200 [thread overview]
Message-ID: <d12fc778-bc1b-36e9-8084-870c0107d709@redhat.com> (raw)
In-Reply-To: <1463470536-8981-9-git-send-email-famz@redhat.com>
[-- Attachment #1: Type: text/plain, Size: 2326 bytes --]
On 17.05.2016 09:35, Fam Zheng wrote:
> They are wrappers of POSIX fcntl "file private locking".
>
> Signed-off-by: Fam Zheng <famz@redhat.com>
> ---
> include/qemu/osdep.h | 2 ++
> util/osdep.c | 31 +++++++++++++++++++++++++++++++
> 2 files changed, 33 insertions(+)
>
> diff --git a/include/qemu/osdep.h b/include/qemu/osdep.h
> index 1e3221c..81913a7 100644
> --- a/include/qemu/osdep.h
> +++ b/include/qemu/osdep.h
> @@ -265,6 +265,8 @@ int qemu_madvise(void *addr, size_t len, int advice);
>
> int qemu_open(const char *name, int flags, ...);
> int qemu_close(int fd);
> +int qemu_lock_fd(int fd, int64_t start, int64_t len, bool exclusive);
> +int qemu_unlock_fd(int fd, int64_t start, int64_t len);
>
> #if defined(__HAIKU__) && defined(__i386__)
> #define FMT_pid "%ld"
> diff --git a/util/osdep.c b/util/osdep.c
> index d56d071..9e5d7fa 100644
> --- a/util/osdep.c
> +++ b/util/osdep.c
> @@ -236,6 +236,37 @@ int qemu_close(int fd)
> return close(fd);
> }
>
> +static int qemu_lock_fcntl(int fd, int64_t start, int64_t len, int fl_type)
> +{
> +#ifdef F_OFD_SETLK
> + struct flock fl = (struct flock) {
The (struct flock) can be omitted here (since this is an
initialization), but that's up to you.
> + .l_whence = SEEK_SET,
One space too many?
> + /* Locking byte 1 avoids interfereing with virtlockd. */
*interfering or *interference
But apart from that: This comment seems completely misplaced here. I
guess it's supposed to be in raw-posix.c instead (or just wherever
you're calling qemu_{un,}lock_fd()).
> + .l_start = start,
> + .l_len = len,
> + .l_type = fl_type,
> + };
> + if (fcntl(fd, F_OFD_SETLK, &fl) == -1) {
> + return -errno;
> + } else {
> + return 0;
> + }
> +#else
> + return -ENOTSUP;
> +#endif
> +}
> +
> +int qemu_lock_fd(int fd, int64_t start, int64_t len, bool exclusive)
> +{
> +
Superfluous empty line.
Max
> + return qemu_lock_fcntl(fd, start, len, exclusive ? F_WRLCK : F_RDLCK);
> +}
> +
> +int qemu_unlock_fd(int fd, int64_t start, int64_t len)
> +{
> + return qemu_lock_fcntl(fd, start, len, F_UNLCK);
> +}
> +
> /*
> * A variant of write(2) which handles partial write.
> *
>
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 473 bytes --]
next prev parent reply other threads:[~2016-05-24 16:43 UTC|newest]
Thread overview: 71+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-17 7:35 [Qemu-devel] [PATCH v5 00/27] block: Lock images when opening Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 01/27] block: Add flag bits for image locking Fam Zheng
2016-05-24 12:14 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 02/27] qapi: Add lock-mode in blockdev-add options Fam Zheng
2016-05-24 12:15 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 03/27] blockdev: Add and parse "lock-mode" option for image locking Fam Zheng
2016-05-24 12:17 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 04/27] block: Introduce image file locking Fam Zheng
2016-05-24 16:01 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 05/27] block: Add bdrv_image_locked Fam Zheng
2016-05-24 16:04 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 06/27] block: Make bdrv_reopen_{commit, abort} private functions Fam Zheng
2016-05-24 16:09 ` Max Reitz
2016-05-27 7:42 ` Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 07/27] block: Handle image locking during reopen Fam Zheng
2016-05-24 16:28 ` Max Reitz
2016-05-27 7:48 ` Fam Zheng
2016-05-27 9:57 ` Max Reitz
2016-05-27 12:36 ` Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 08/27] osdep: Add qemu_lock_fd and qemu_unlock_fd Fam Zheng
2016-05-24 16:42 ` Max Reitz [this message]
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 09/27] osdep: Introduce qemu_dup Fam Zheng
2016-05-24 16:52 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 10/27] raw-posix: Use qemu_dup Fam Zheng
2016-05-24 16:55 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 11/27] raw-posix: Implement .bdrv_lockf Fam Zheng
2016-05-24 17:09 ` Max Reitz
2016-05-27 7:50 ` Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 12/27] gluster: " Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 13/27] qemu-io: Add "-L" option for BDRV_O_NO_LOCK Fam Zheng
2016-05-24 17:21 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 14/27] qemu-img: Add "-L" option to sub commands Fam Zheng
2016-05-24 18:06 ` Max Reitz
2016-06-01 5:34 ` Fam Zheng
2016-06-02 11:30 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 15/27] qemu-img: Update documentation of "-L" option Fam Zheng
2016-05-24 18:09 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 16/27] qemu-nbd: Add "--no-lock/-L" option Fam Zheng
2016-05-24 18:12 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 17/27] block: Don't lock drive-backup target image in none mode Fam Zheng
2016-05-24 18:16 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 18/27] mirror: Disable image locking on target backing chain Fam Zheng
2016-05-24 18:20 ` Max Reitz
2016-06-03 6:32 ` Fam Zheng
2016-06-03 13:24 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 19/27] qemu-iotests: 140: Disable image lock for qemu-io access Fam Zheng
2016-05-25 13:16 ` Max Reitz
2016-06-03 6:34 ` Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 20/27] qemu-iotests: 046: Move version detection out from verify_io Fam Zheng
2016-05-25 13:23 ` Max Reitz
2016-06-03 6:43 ` Fam Zheng
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 21/27] qemu-iotests: Wait for QEMU processes before checking image in 091 Fam Zheng
2016-05-25 13:28 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 22/27] qemu-iotests: 030: Disable image lock when checking test image Fam Zheng
2016-05-25 13:30 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 23/27] iotests: 087: Disable image lock in cases where file is shared Fam Zheng
2016-05-25 13:41 ` Max Reitz
2016-05-25 13:41 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 24/27] iotests: Disable image locking in 085 Fam Zheng
2016-05-25 13:52 ` Max Reitz
2016-06-03 7:18 ` Fam Zheng
2016-06-03 14:41 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 25/27] tests: Use null-co:// instead of /dev/null Fam Zheng
2016-05-25 13:57 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 26/27] block: Turn on image locking by default Fam Zheng
2016-05-25 13:57 ` Max Reitz
2016-05-17 7:35 ` [Qemu-devel] [PATCH v5 27/27] qemu-iotests: Add test case 153 for image locking Fam Zheng
2016-05-25 14:20 ` Max Reitz
2016-05-24 11:48 ` [Qemu-devel] [PATCH v5 00/27] block: Lock images when opening Richard W.M. Jones
2016-05-24 12:46 ` Kevin Wolf
2016-05-24 12:58 ` Richard W.M. Jones
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=d12fc778-bc1b-36e9-8084-870c0107d709@redhat.com \
--to=mreitz@redhat.com \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=den@openvz.org \
--cc=eblake@redhat.com \
--cc=famz@redhat.com \
--cc=jcody@redhat.com \
--cc=jsnow@redhat.com \
--cc=kwolf@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.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).