On Sat, Oct 15, 2016 at 12:40:43PM +0100, Pascal Terjan wrote:
> rp-pppoe plugin of ppp no longer builds:
> In file included from pppoe.h:87:0,
> from plugin.c:29:
> /usr/include/linux/in.h:28:3: error: redeclaration of enumerator 'IPPROTO_IP'
> IPPROTO_IP = 0, /* Dummy protocol for TCP */
> /usr/include/netinet/in.h:42:5: note: previous definition of
> 'IPPROTO_IP' was here
> IPPROTO_IP = 0, /* Dummy protocol for TCP. */
> Short reproducer:
> #include <sys/cdefs.h>
> #include <sys/socket.h>
> #include <linux/if.h>
> #include <netinet/in.h>
> #include <linux/ppp_defs.h>
> #include <linux/if_pppox.h>
> Full log:
> Moving the include of linux/if.h after netinet/in.h fixes it.
> I guess the breakage is caused by
> but the commit doesn't look wrong to me.
These kernel uapi headers did not declare their dependencies correctly
and this patch fixed it. Many uapi headers from kernel unfortunately
conflict with glibc and other userspace headers, and userspace code is often
relying on this behavior, e.g. has had a working order of includes.
My patch series has compatibility changes so that kernel headers can be
included after glibc ones.
Unfortunately I haven't had time to provide similar patches to glibc so
things might breaks if kernel headers are included before glibc headers.
So the best I can do for now is to ask you to change the userspace include
order to first include glibc headers and then kernel uapi ones.
This is an unfortunate kernel header API break, sorry. ABI's are not affected