diff options
author | Thierry MERLE <thierry.merle@free.fr> | 2008-07-08 07:01:45 +0200 |
---|---|---|
committer | Thierry MERLE <thierry.merle@free.fr> | 2008-07-08 07:01:45 +0200 |
commit | 4e748efa7677d0762f4b1738cd8869df5eb106b6 (patch) | |
tree | 5fd82dfff141de82cd4932244fca3d9ff7829219 /v4l2-apps/lib/libv4l/libv4l1/libv4l1.c | |
parent | ab715d2e8eb29998b60fa3bbc1ad95441cfb69b3 (diff) | |
download | mediapointer-dvb-s2-4e748efa7677d0762f4b1738cd8869df5eb106b6.tar.gz mediapointer-dvb-s2-4e748efa7677d0762f4b1738cd8869df5eb106b6.tar.bz2 |
v4l2-library: libv4l-really-sync-with-0.3.4.patch
From: Hans de Goede <j.w.r.degoede@hhs.nl>
* The mmap64 support in 0.3.3, has caused a bug in libv4l1 when running on
32 bit systems (who uses those now a days?), this bug caused v4l1
compatibility to not work at all, this release fixes this
* Some apps (xawtv, kopete) use an ioctl wrapper internally for various
reasons. This wrappers request argument is an int, but the real ioctl's
request argument is an unsigned long. Passing the VIDIOC_xxx defines through
to the wrapper, and then to the real ioctl, causes the request to get sign
extended on 64 bit args. The kernel seems to ignore the upper 32 bits,
causing the sign extension to not make a difference. libv4l now also
ignores the upper 32 bits of the libv4lx_ioctl request argument on 64 bit
archs
* Add a bugfix patch for kopete in the appl-patches dir, currently it assumes
that it got the width and height it asked for when doing a S_FMT, which is a
wrong assumption
Signed-off-by: Hans de Goede <j.w.r.degoede@hhs.nl>
Signed-off-by: Thierry MERLE <thierry.merle@free.fr>
Diffstat (limited to 'v4l2-apps/lib/libv4l/libv4l1/libv4l1.c')
-rw-r--r-- | v4l2-apps/lib/libv4l/libv4l1/libv4l1.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/v4l2-apps/lib/libv4l/libv4l1/libv4l1.c b/v4l2-apps/lib/libv4l/libv4l1/libv4l1.c index 4a54047df..40e4b2aa1 100644 --- a/v4l2-apps/lib/libv4l/libv4l1/libv4l1.c +++ b/v4l2-apps/lib/libv4l/libv4l1/libv4l1.c @@ -454,6 +454,11 @@ int v4l1_ioctl (int fd, unsigned long int request, ...) if ((index = v4l1_get_index(fd)) == -1) return syscall(SYS_ioctl, fd, request, arg); + /* Appearantly the kernel and / or glibc ignore the 32 most significant bits + when long = 64 bits, and some applications pass an int holding the req to + ioctl, causing it to get sign extended, depending upon this behavior */ + request = (unsigned int)request; + /* do we need to take the stream lock for this ioctl? */ switch (request) { case VIDIOCSPICT: |