diff options
author | Baolin Wang <baolin.wang@linaro.org> | 2018-04-24 15:06:09 +0300 |
---|---|---|
committer | Arnd Bergmann <arnd@arndb.de> | 2019-12-12 00:06:15 +0300 |
commit | a07804cc7472d8aa5db03ea5d75f3d8d80abb687 (patch) | |
tree | 3bbe041cf1244f03fbf2db52876de60486814060 /kernel/fail_function.c | |
parent | fcae40c99fb3d09f4407f549a7f17761abe5e1bc (diff) | |
download | linux-a07804cc7472d8aa5db03ea5d75f3d8d80abb687.tar.xz |
ALSA: Avoid using timespec for struct snd_timer_status
struct snd_timer_status uses 'timespec' type variables to record
timestamp, which will be changed to an incompatible layout with
updated user space using 64-bit time_t.
To handle both the old and the new layout on 32-bit architectures,
this patch introduces 'struct snd_timer_status32' and 'struct snd_timer_status64'
to handle 32bit time_t and 64bit time_t in native mode and compat mode,
which replaces timespec with s64 type.
When glibc changes time_t to 64-bit, any recompiled program will issue
ioctl commands that the kernel does not understand without this patch.
In the public uapi header, snd_timer_status is now guarded by
an #ifndef __KERNEL__ to avoid referencing 'struct timespec'.
The timespec definition will be removed from the kernel to prevent
new y2038 bugs and to avoid the conflict with an incompatible libc
type of the same name.
Signed-off-by: Baolin Wang <baolin.wang@linaro.org>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'kernel/fail_function.c')
0 files changed, 0 insertions, 0 deletions