1 From 50baa8dd8595566901243a8e7b32c64a230b2e21 Mon Sep 17 00:00:00 2001
2 From: Timo Juhani Lindfors <timo.lindfors@iki.fi>
3 Date: Tue, 5 Mar 2013 10:30:03 +0200
4 Subject: [PATCH] fix crash when sizeof(mode_t) < sizeof(int)
6 On Debian GNU/kfreebsd mode_t is uint16_t. According to GCC this gets
9 installwatch.c:3835:11: warning: 'short unsigned int' is promoted to 'int' when passed through '...' [enabled by default]
10 installwatch.c:3835:11: note: (so you should pass 'int' not 'short unsigned int' to 'va_arg')
11 installwatch.c:3835:11: note: if this code is reached, the program will abort
13 and according to "man va_arg" this indeed is documented to lead to
16 "If there is no next argnument, or if type is not compatible with the
17 type of the actual next argument (as promoted according to the
18 default argument promotions), random errors will occur.
20 This patch simply uses int instead of mode_t and fixes Debian bug
21 702314 (checkinstall aborts with illegal instruction on kFreeBSD). BK 20141220 edited.
23 installwatch/installwatch.c | 6 +++---
24 1 files changed, 3 insertions(+), 3 deletions(-)
26 diff --git installwatch/installwatch.c installwatch/installwatch.c
27 index 8004b5b..f55f7a1 100644
28 --- installwatch/installwatch.c
29 +++ installwatch/installwatch.c
30 @@ -2857,7 +2857,7 @@ int open(const char *pathname, int flags, ...) {
34 - mode = va_arg(ap, mode_t);
35 + mode = va_arg(ap, int /*promoted from mode_t*/);
38 /* We were asked to work in "real" mode */
39 @@ -3644,7 +3644,7 @@ int open64(const char *pathname, int flags, ...) {
43 - mode = va_arg(ap, mode_t);
44 + mode = va_arg(ap, int /*promoted from mode_t*/);
47 /* We were asked to work in "real" mode */
48 @@ -3887,7 +3887,7 @@ int openat (int dirfd, const char *path, int flags, ...) {
52 - mode = va_arg(arg, mode_t);
53 + mode = va_arg(arg, int /*promoted from mode_t*/);