Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 10 Jun 2003 03:58:29 -0700
From:      Terry Lambert <tlambert2@mindspring.com>
To:        Ian Freislich <ianf@za.uu.net>
Cc:        freebsd-current@freebsd.org
Subject:   Re: New Kernel Breaks IPFW
Message-ID:  <3EE5B9D5.8FE3E6EF@mindspring.com>
References:  <3EE4EEF7.1010208@tcoip.com.br> <2556.1055239930@mci.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Ian Freislich wrote:
> Alas make buildworld fails for the past few days:
> ===> usr.sbin/config
> <snip>
> In file included from config.c:1:
> /usr/include/stdlib.h:102: conflicting types for `restrict'
> /usr/include/stdlib.h:102: previous declaration of `restrict'
> /usr/include/stdlib.h:102: warning: redundant redeclaration of `restrict' in same scope
> /usr/include/stdlib.h:102: warning: previous declaration of `restrict'
> /usr/include/stdlib.h:103: conflicting types for `restrict'
> <snip>
> (and also stdio.h, string.h, sys/types.h, select.h)

>From <sys/cdefs.h>:
-----------------------------------------------------------------------------
/*
 * GCC 2.95 provides `__restrict' as an extension to C90 to support the
 * C99-specific `restrict' type qualifier.  We happen to use `__restrict' as
 * a way to define the `restrict' type qualifier without disturbing older
 * software that is unaware of C99 keywords.
 */
#if !(__GNUC__ == 2 && __GNUC_MINOR__ == 95)
#if __STDC_VERSION__ < 199901
#define __restrict
#else
#define __restrict      restrict
#endif
#endif
-----------------------------------------------------------------------------

The <stdlib.h> hasn't changed in over two months; <sys/cdefs.h>
hasn't changed in about 7 weeks.

Apparently, someone hosed the compiler flags.  Looking at your
cribbed link:

> Someone posted a link to the failure that I get, so I'll crib:
> http://www.0xfce3.net/error.txt

We see:

cc -O -pipe   -std=iso9899:1999  -I/usr/obj/usr/src/i386/legacy/usr/include 
-static -L/usr/obj/usr/src/i386/legacy/usr/lib -o xinstall xinstall.o -legacy

Works.

cc -O -pipe -I. -I/usr/src/usr.sbin/config -W -Wall -ansi -pedantic
-Wbad-function-cast -Wcast-align  -Wcast-qual -Wchar-subscripts -Winline 
-Wmissing-prototypes -Wnested-externs -Wpointer-arith  -Wredundant-decls
-Wshadow -Wstrict-prototypes -Wwrite-strings   -std=iso9899:1999 
-I/usr/obj/usr/src/i386/legacy/usr/include -c config.c

Hosed.  I believe you'll find that it's the comobination of
the compiler flags "-ansi -pedantic" with "-std-iso9899:1999"...
this might be pilot error in your local make.conf, as well,
since I think it turns off GNU extensions, which we apparently
depend upon, but my money is on:

http://www.freebsd.org/cgi/cvsweb.cgi/src/share/mk/bsd.sys.mk
 
Version 1.29:

"Be C std strict on i386 and amd64 as we can.  Be loose on Alpha
 and ia64".

...or maybe 1.25:

"Turn back on c99, the tree should be ready for it now."


> > Short term, cd /usr/src/sbin/ipfw; make depend && make all install ought
> > to fix it.
> 
> I tried that as well, but the new binary also dumps core, but works
> well with previous versions of the firewall.  Even back as far as
> my kernel.working from May 7 2003.

Bogus header files; specifically, <netinet/ip_fw.h>.  Because you
can't build world, you are compiling the ipfw program with the old
system include files instead of the new ones.  You may also be
missing a cvs update on the ipfw sources themselves (specifically,
ipfw2.c).

-- Terry



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3EE5B9D5.8FE3E6EF>