X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=pppd%2Feui64.h;fp=pppd%2Feui64.h;h=f809342cb76e1428e4da2757e7384665fc723790;hb=ba7f7e053daae846a54a1d08d3d133a5f1266ace;hp=f29200b818d7efd0fbfb1e2914a39255f99954b6;hpb=76016e1b948b7d9675b4e0750d1f943d96d9523b;p=ppp.git diff --git a/pppd/eui64.h b/pppd/eui64.h index f29200b..f809342 100644 --- a/pppd/eui64.h +++ b/pppd/eui64.h @@ -38,9 +38,36 @@ #include "pppdconf.h" -#if !defined(PPP_WITH_IPV6CP) -#error "this file should only be included when PPP_WITH_IPV6CP is defined" -#endif /* not defined(PPP_WITH_IPV6CP) */ +#if defined(SOL2) +#include + +typedef union { + uint8_t e8[8]; /* lower 64-bit IPv6 address */ + uint32_t e32[2]; /* lower 64-bit IPv6 address */ +} eui64_t; + +/* + * Declare the two below, since in.h only defines them when _KERNEL + * is declared - which shouldn't be true when dealing with user-land programs + */ +#define s6_addr8 _S6_un._S6_u8 +#define s6_addr32 _S6_un._S6_u32 + +#else /* else if not defined(SOL2) */ + +/* + * TODO: + * + * Maybe this should be done by processing struct in6_addr directly... + */ +typedef union +{ + u_int8_t e8[8]; + u_int16_t e16[4]; + u_int32_t e32[2]; +} eui64_t; + +#endif /* defined(SOL2) */ #define eui64_iszero(e) (((e).e32[0] | (e).e32[1]) == 0) #define eui64_equals(e, o) (((e).e32[0] == (o).e32[0]) && \