diff --git a/main/dns.c b/main/dns.c index ff7dde7452781560f3021f1ca652142846bb2e73..52a4b8ddbd21fade976d93268bafb94aaeb45728 100644 --- a/main/dns.c +++ b/main/dns.c @@ -48,9 +48,21 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #define MAX_SIZE 4096 +#ifdef __PDP_ENDIAN +#if __BYTE_ORDER == __PDP_ENDIAN +#define DETERMINED_BYTE_ORDER __LITTLE_ENDIAN +#endif +#endif +#if __BYTE_ORDER == __BIG_ENDIAN +#define DETERMINED_BYTE_ORDER __BIG_ENDIAN +#endif +#if __BYTE_ORDER == __LITTLE_ENDIAN +#define DETERMINED_BYTE_ORDER __LITTLE_ENDIAN +#endif + typedef struct { unsigned id:16; /*!< query identification number */ -#if __BYTE_ORDER == __BIG_ENDIAN +#if DETERMINED_BYTE_ORDER == __BIG_ENDIAN /* fields in third byte */ unsigned qr:1; /*!< response flag */ unsigned opcode:4; /*!< purpose of message */ @@ -64,7 +76,7 @@ typedef struct { unsigned cd:1; /*!< checking disabled by resolver */ unsigned rcode:4; /*!< response code */ #endif -#if __BYTE_ORDER == __LITTLE_ENDIAN || __BYTE_ORDER == __PDP_ENDIAN +#if DETERMINED_BYTE_ORDER == __LITTLE_ENDIAN /* fields in third byte */ unsigned rd:1; /*!< recursion desired */ unsigned tc:1; /*!< truncated message */ @@ -178,7 +190,7 @@ static int dns_parse_answer(void *context, return 0; } -#if !HAVE_RES_NINIT +#ifndef HAVE_RES_NINIT AST_MUTEX_DEFINE_STATIC(res_lock); #endif @@ -190,13 +202,13 @@ int ast_search_dns(void *context, const char *dname, int class, int type, int (*callback)(void *context, unsigned char *answer, int len, unsigned char *fullanswer)) { -#if HAVE_RES_NINIT +#ifdef HAVE_RES_NINIT struct __res_state dnsstate; #endif unsigned char answer[MAX_SIZE]; int res, ret = -1; -#if HAVE_RES_NINIT +#ifdef HAVE_RES_NINIT res_ninit(&dnsstate); res = res_nsearch(&dnsstate, dname, class, type, answer, sizeof(answer)); #else @@ -217,7 +229,7 @@ int ast_search_dns(void *context, else ret = 1; } -#if HAVE_RES_NINIT +#ifdef HAVE_RES_NINIT res_nclose(&dnsstate); #else #ifndef __APPLE__