Ensure tinc compiles with gcc -std=c99.

We use a lot of C99 features already, but also some extensions which are not in
the standard.
This commit is contained in:
Guus Sliepen 2009-09-08 21:45:24 +02:00
parent f52ea0a7eb
commit 9b394bc887
5 changed files with 23 additions and 29 deletions

View file

@ -21,7 +21,7 @@ AC_DEFINE([__USE_BSD], 1, [Enable BSD extensions])
ALL_LINGUAS="nl" ALL_LINGUAS="nl"
dnl Checks for programs. dnl Checks for programs.
AC_PROG_CC AC_PROG_CC_C99
AC_PROG_CPP AC_PROG_CPP
AC_PROG_INSTALL AC_PROG_INSTALL
AC_PROG_LN_S AC_PROG_LN_S

View file

@ -37,7 +37,7 @@ connection_t *broadcast;
static int connection_compare(const connection_t *a, const connection_t *b) static int connection_compare(const connection_t *a, const connection_t *b)
{ {
return (void *)a - (void *)b; return a - b;
} }
void init_connections(void) void init_connections(void)
@ -144,7 +144,7 @@ void dump_connections(void)
for(node = connection_tree->head; node; node = node->next) { for(node = connection_tree->head; node; node = node->next) {
c = node->data; c = node->data;
logger(LOG_DEBUG, _(" %s at %s options %lx socket %d status %04x outbuf %d/%d/%d"), logger(LOG_DEBUG, _(" %s at %s options %lx socket %d status %04x outbuf %d/%d/%d"),
c->name, c->hostname, c->options, c->socket, c->status.value, c->name, c->hostname, c->options, c->socket, *(uint32_t *)&c->status,
c->outbufsize, c->outbufstart, c->outbuflen); c->outbufsize, c->outbufstart, c->outbuflen);
} }

View file

@ -32,20 +32,17 @@
#define OPTION_TCPONLY 0x0002 #define OPTION_TCPONLY 0x0002
#define OPTION_PMTU_DISCOVERY 0x0004 #define OPTION_PMTU_DISCOVERY 0x0004
typedef union connection_status_t { typedef struct connection_status_t {
struct { int pinged:1; /* sent ping */
int pinged:1; /* sent ping */ int active:1; /* 1 if active.. */
int active:1; /* 1 if active.. */ int connecting:1; /* 1 if we are waiting for a non-blocking connect() to finish */
int connecting:1; /* 1 if we are waiting for a non-blocking connect() to finish */ int termreq:1; /* the termination of this connection was requested */
int termreq:1; /* the termination of this connection was requested */ int remove:1; /* Set to 1 if you want this connection removed */
int remove:1; /* Set to 1 if you want this connection removed */ int timeout:1; /* 1 if gotten timeout */
int timeout:1; /* 1 if gotten timeout */ int encryptout:1; /* 1 if we can encrypt outgoing traffic */
int encryptout:1; /* 1 if we can encrypt outgoing traffic */ int decryptin:1; /* 1 if we have to decrypt incoming traffic */
int decryptin:1; /* 1 if we have to decrypt incoming traffic */ int mst:1; /* 1 if this connection is part of a minimum spanning tree */
int mst:1; /* 1 if this connection is part of a minimum spanning tree */ int unused:23;
int unused:23;
};
uint32_t value;
} connection_status_t; } connection_status_t;
#include "edge.h" #include "edge.h"

View file

@ -251,7 +251,7 @@ static void check_dead_connections(void)
} else { } else {
if(c->status.remove) { if(c->status.remove) {
logger(LOG_WARNING, _("Old connection_t for %s (%s) status %04x still lingering, deleting..."), logger(LOG_WARNING, _("Old connection_t for %s (%s) status %04x still lingering, deleting..."),
c->name, c->hostname, c->status.value); c->name, c->hostname, *(uint32_t *)&c->status);
connection_del(c); connection_del(c);
continue; continue;
} }

View file

@ -29,17 +29,14 @@
#include "list.h" #include "list.h"
#include "subnet.h" #include "subnet.h"
typedef union node_status_t { typedef struct node_status_t {
struct { int unused_active:1; /* 1 if active (not used for nodes) */
int unused_active:1; /* 1 if active (not used for nodes) */ int validkey:1; /* 1 if we currently have a valid key for him */
int validkey:1; /* 1 if we currently have a valid key for him */ int waitingforkey:1; /* 1 if we already sent out a request */
int waitingforkey:1; /* 1 if we already sent out a request */ int visited:1; /* 1 if this node has been visited by one of the graph algorithms */
int visited:1; /* 1 if this node has been visited by one of the graph algorithms */ int reachable:1; /* 1 if this node is reachable in the graph */
int reachable:1; /* 1 if this node is reachable in the graph */ int indirect:1; /* 1 if this node is not directly reachable by us */
int indirect:1; /* 1 if this node is not directly reachable by us */ int unused:26;
int unused:26;
};
uint32_t value;
} node_status_t; } node_status_t;
typedef struct node_t { typedef struct node_t {