[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1222530242-1272-1-git-send-email-avi@redhat.com>
Date: Sat, 27 Sep 2008 18:43:59 +0300
From: Avi Kivity <avi@...hat.com>
To: Andrew Morton <akpm@...ux-foundation.org>
Cc: viro@...IV.linux.org.uk, linux-kernel@...r.kernel.org
Subject: [PATCH 0/3][RFC] ioctl dispatcher
While ioctls are officially ugly, they are the best choice for some use
cases, not to mention compatibility issues. Currently ioctl writers face
the following hurdles:
- if the ioctl uses a data buffer, the ioctl handler must allocate
kernel memory for this buffer
- the memory may be allocated on the heap or on the stack, depending on the
buffer size
- handle any errors from the operation
- copy the data from userspace, if necessary
- handle any errors from the operation
- actually perform the operation
- copy the data back to userspace, if necessary
- handle any errors from the operation
- free the buffer, if allocated from the heap
The first patch automates these operations, only requiring the caller to
supply the ioctl number and a callback in a table.
The second patch addresses another problem with ioctls: they are brittle.
Once written, an ioctl cannot be extended, since the buffer sizes used for
transferring data are encoded in the ioctl number. This is addressed by
allowing the user-supplied size and the kernel-visible size of the data
buffer to be different; the kernel will zero fill or truncate appropriately.
With the new mechanism, it is easy to write forward- and backward- compatible
ioctl handlers.
The third patch demonstrates the effectiveness of the first patch; it
converts some of kvm's ioctl handlers to the new mechanism, removing
around 90 lines in the process.
Comments welcome.
Avi Kivity (3):
ioctl: generic ioctl dispatcher
ioctl: extensible ioctl dispatch
KVM: Convert x86 vcpu ioctls to use dispatch_ioctl_extensible()
arch/x86/kvm/x86.c | 241 ++++++++++++++++---------------------------------
fs/ioctl.c | 139 ++++++++++++++++++++++++++++
include/linux/ioctl.h | 37 ++++++++
3 files changed, 253 insertions(+), 164 deletions(-)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists