]> git.ipfire.org Git - thirdparty/kmod.git/commitdiff
shared/util.c: assert_cc() can only be used inside functions
authorThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Sat, 3 Jun 2017 15:03:22 +0000 (17:03 +0200)
committerLucas De Marchi <lucas.demarchi@intel.com>
Mon, 5 Jun 2017 17:07:00 +0000 (10:07 -0700)
shared/macro.h has two versions of assert_cc, one that uses gcc
_Static_assert(), which requires recent enough gcc versions, and one
that uses a fake array to trigger a build error. The latter can only
work inside functions, so assert_cc() should only be used inside
functions.

Fixes the following build failure when building kmod with old gcc
versions such as gcc 4.3.x:

shared/util.c:52: error: expected identifier or '(' before 'do'
shared/util.c:52: error: expected identifier or '(' before 'while'

Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
shared/util.c

index 9de080aabb18db3fd46dccc84f3e0e61e10df47c..fd2028df5a603007ee4233f2bdf850c6e4224e6d 100644 (file)
@@ -49,8 +49,6 @@ static const struct kmod_ext {
        { }
 };
 
-assert_cc(EAGAIN == EWOULDBLOCK);
-
 /* string handling functions and memory allocations                         */
 /* ************************************************************************ */
 
@@ -201,6 +199,8 @@ ssize_t read_str_safe(int fd, char *buf, size_t buflen)
        size_t todo = buflen - 1;
        size_t done = 0;
 
+       assert_cc(EAGAIN == EWOULDBLOCK);
+
        do {
                ssize_t r = read(fd, buf + done, todo);
 
@@ -226,6 +226,8 @@ ssize_t write_str_safe(int fd, const char *buf, size_t buflen)
        size_t todo = buflen;
        size_t done = 0;
 
+       assert_cc(EAGAIN == EWOULDBLOCK);
+
        do {
                ssize_t r = write(fd, buf + done, todo);