aboutsummaryrefslogtreecommitdiffstats
path: root/src/dns.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/dns.c')
-rw-r--r--src/dns.c134
1 files changed, 67 insertions, 67 deletions
diff --git a/src/dns.c b/src/dns.c
index c50b9f388..57c955005 100644
--- a/src/dns.c
+++ b/src/dns.c
@@ -59,11 +59,11 @@
#define DNS_K_TEA_CYCLES 32
#define DNS_K_TEA_MAGIC 0x9E3779B9U
-static void dns_retransmit_handler (int fd, short what, void *arg);
+static void dns_retransmit_handler (gint fd, short what, void *arg);
static void
-dns_k_tea_init(struct dns_k_tea *tea, uint32_t key[], unsigned cycles)
+dns_k_tea_init(struct dns_k_tea *tea, guint32 key[], guint cycles)
{
memcpy(tea->key, key, sizeof tea->key);
@@ -72,7 +72,7 @@ dns_k_tea_init(struct dns_k_tea *tea, uint32_t key[], unsigned cycles)
static void
-dns_k_tea_encrypt (struct dns_k_tea *tea, uint32_t v[], uint32_t *w)
+dns_k_tea_encrypt (struct dns_k_tea *tea, guint32 v[], guint32 *w)
{
guint32 y, z, sum, n;
@@ -113,10 +113,10 @@ dns_k_tea_encrypt (struct dns_k_tea *tea, uint32_t v[], uint32_t *w)
-static inline unsigned int
-dns_k_permutor_powof (unsigned int n)
+static inline guint
+dns_k_permutor_powof (guint n)
{
- unsigned int m, i = 0;
+ guint m, i = 0;
for (m = 1; m < n; m <<= 1, i++);
@@ -124,10 +124,10 @@ dns_k_permutor_powof (unsigned int n)
} /* dns_k_permutor_powof() */
static void
-dns_k_permutor_init (struct dns_k_permutor *p, unsigned low, unsigned high)
+dns_k_permutor_init (struct dns_k_permutor *p, guint low, guint high)
{
- uint32_t key[DNS_K_TEA_KEY_SIZE / sizeof (uint32_t)];
- unsigned width, i;
+ guint32 key[DNS_K_TEA_KEY_SIZE / sizeof (guint32)];
+ guint width, i;
p->stepi = 0;
@@ -150,10 +150,10 @@ dns_k_permutor_init (struct dns_k_permutor *p, unsigned low, unsigned high)
} /* dns_k_permutor_init() */
-static unsigned
-dns_k_permutor_F (struct dns_k_permutor *p, unsigned k, unsigned x)
+static guint
+dns_k_permutor_F (struct dns_k_permutor *p, guint k, guint x)
{
- uint32_t in[DNS_K_TEA_BLOCK_SIZE / sizeof (uint32_t)], out[DNS_K_TEA_BLOCK_SIZE / sizeof (uint32_t)];
+ guint32 in[DNS_K_TEA_BLOCK_SIZE / sizeof (guint32)], out[DNS_K_TEA_BLOCK_SIZE / sizeof (guint32)];
memset(in, '\0', sizeof in);
@@ -166,11 +166,11 @@ dns_k_permutor_F (struct dns_k_permutor *p, unsigned k, unsigned x)
} /* dns_k_permutor_F() */
-static unsigned
-dns_k_permutor_E (struct dns_k_permutor *p, unsigned n)
+static guint
+dns_k_permutor_E (struct dns_k_permutor *p, guint n)
{
- unsigned l[2], r[2];
- unsigned i;
+ guint l[2], r[2];
+ guint i;
i = 0;
l[i] = p->mask & (n >> p->shift);
@@ -187,11 +187,11 @@ dns_k_permutor_E (struct dns_k_permutor *p, unsigned n)
} /* dns_k_permutor_E() */
-static unsigned
-dns_k_permutor_D (struct dns_k_permutor *p, unsigned n)
+static guint
+dns_k_permutor_D (struct dns_k_permutor *p, guint n)
{
- unsigned l[2], r[2];
- unsigned i;
+ guint l[2], r[2];
+ guint i;
i = p->rounds - 1;
l[i % 2] = p->mask & (n >> p->shift);
@@ -208,10 +208,10 @@ dns_k_permutor_D (struct dns_k_permutor *p, unsigned n)
} /* dns_k_permutor_D() */
-static unsigned
+static guint
dns_k_permutor_step(struct dns_k_permutor *p)
{
- unsigned n;
+ guint n;
do {
n = dns_k_permutor_E(p, p->stepi++);
@@ -225,10 +225,10 @@ dns_k_permutor_step(struct dns_k_permutor *p)
* Simple permutation box. Useful for shuffling rrsets from an iterator.
* Uses AES s-box to provide good diffusion.
*/
-static unsigned short
-dns_k_shuffle16 (unsigned short n, unsigned s)
+static guint16
+dns_k_shuffle16 (guint16 n, guint s)
{
- static const unsigned char sbox[256] =
+ static const guint8 sbox[256] =
{ 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5,
0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76,
0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0,
@@ -261,8 +261,8 @@ dns_k_shuffle16 (unsigned short n, unsigned s)
0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf,
0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68,
0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 };
- unsigned char a, b;
- unsigned i;
+ guchar a, b;
+ guint i;
a = 0xff & (n >> 0);
b = 0xff & (n >> 8);
@@ -347,7 +347,7 @@ make_dns_header (struct rspamd_dns_request *req)
}
static void
-format_dns_name (struct rspamd_dns_request *req, const char *name, guint namelen)
+format_dns_name (struct rspamd_dns_request *req, const gchar *name, guint namelen)
{
guint8 *pos = req->packet + req->pos, *end, *dot, *begin;
guint remain = req->packet_len - req->pos - 5, label_len;
@@ -425,15 +425,15 @@ format_dns_name (struct rspamd_dns_request *req, const char *name, guint namelen
static void
make_ptr_req (struct rspamd_dns_request *req, struct in_addr addr)
{
- char ipbuf[sizeof("255.255.255.255.in-addr.arpa")];
+ gchar ipbuf[sizeof("255.255.255.255.in-addr.arpa")];
guint32 a = ntohl (addr.s_addr), r;
guint16 *p;
r = rspamd_snprintf (ipbuf, sizeof(ipbuf), "%d.%d.%d.%d.in-addr.arpa",
- (int)(guint8)((a ) & 0xff),
- (int)(guint8)((a>>8 ) & 0xff),
- (int)(guint8)((a>>16) & 0xff),
- (int)(guint8)((a>>24) & 0xff));
+ (gint)(guint8)((a ) & 0xff),
+ (gint)(guint8)((a>>8 ) & 0xff),
+ (gint)(guint8)((a>>16) & 0xff),
+ (gint)(guint8)((a>>24) & 0xff));
allocate_packet (req, r);
make_dns_header (req);
@@ -447,7 +447,7 @@ make_ptr_req (struct rspamd_dns_request *req, struct in_addr addr)
}
static void
-make_a_req (struct rspamd_dns_request *req, const char *name)
+make_a_req (struct rspamd_dns_request *req, const gchar *name)
{
guint16 *p;
@@ -463,7 +463,7 @@ make_a_req (struct rspamd_dns_request *req, const char *name)
}
static void
-make_txt_req (struct rspamd_dns_request *req, const char *name)
+make_txt_req (struct rspamd_dns_request *req, const gchar *name)
{
guint16 *p;
@@ -479,7 +479,7 @@ make_txt_req (struct rspamd_dns_request *req, const char *name)
}
static void
-make_mx_req (struct rspamd_dns_request *req, const char *name)
+make_mx_req (struct rspamd_dns_request *req, const gchar *name)
{
guint16 *p;
@@ -495,7 +495,7 @@ make_mx_req (struct rspamd_dns_request *req, const char *name)
}
static void
-make_srv_req (struct rspamd_dns_request *req, const char *service, const char *proto, const char *name)
+make_srv_req (struct rspamd_dns_request *req, const gchar *service, const gchar *proto, const gchar *name)
{
guint16 *p;
guint len;
@@ -517,7 +517,7 @@ make_srv_req (struct rspamd_dns_request *req, const char *service, const char *p
}
static void
-make_spf_req (struct rspamd_dns_request *req, const char *name)
+make_spf_req (struct rspamd_dns_request *req, const gchar *name)
{
guint16 *p;
@@ -532,7 +532,7 @@ make_spf_req (struct rspamd_dns_request *req, const char *name)
req->requested_name = name;
}
-static int
+static gint
send_dns_request (struct rspamd_dns_request *req)
{
gint r;
@@ -584,7 +584,7 @@ decompress_label (guint8 *begin, guint16 *len, guint16 max)
}
static guint8 *
-dns_request_reply_cmp (struct rspamd_dns_request *req, guint8 *in, int len)
+dns_request_reply_cmp (struct rspamd_dns_request *req, guint8 *in, gint len)
{
guint8 *p, *c, *l1, *l2;
guint16 len1, len2;
@@ -666,7 +666,7 @@ dns_request_reply_cmp (struct rspamd_dns_request *req, guint8 *in, int len)
#define MAX_RECURSION_LEVEL 10
static gboolean
-dns_parse_labels (guint8 *in, char **target, guint8 **pos, struct rspamd_dns_reply *rep, int *remain, gboolean make_name)
+dns_parse_labels (guint8 *in, gchar **target, guint8 **pos, struct rspamd_dns_reply *rep, gint *remain, gboolean make_name)
{
guint16 namelen = 0;
guint8 *p = *pos, *begin = *pos, *l, *t, *end = *pos + *remain;
@@ -760,7 +760,7 @@ end:
#define GET32(x) do {if (*remain < sizeof (guint32)) {goto err;} memcpy (&(x), p, sizeof (guint32)); (x) = ntohl ((x)); p += sizeof (guint32); *remain -= sizeof (guint32); } while(0)
static gint
-dns_parse_rr (guint8 *in, union rspamd_reply_element *elt, guint8 **pos, struct rspamd_dns_reply *rep, int *remain)
+dns_parse_rr (guint8 *in, union rspamd_reply_element *elt, guint8 **pos, struct rspamd_dns_reply *rep, gint *remain)
{
guint8 *p = *pos, parts;
guint16 type, datalen, txtlen, copied;
@@ -897,19 +897,19 @@ dns_parse_rr (guint8 *in, union rspamd_reply_element *elt, guint8 **pos, struct
return 0;
err:
- msg_info ("incomplete RR, only %d bytes remain, packet length %d", (int)*remain, (int)(*pos - in));
+ msg_info ("incomplete RR, only %d bytes remain, packet length %d", (gint)*remain, (gint)(*pos - in));
return -1;
}
static struct rspamd_dns_reply *
-dns_parse_reply (guint8 *in, int r, struct rspamd_dns_resolver *resolver, struct rspamd_dns_request **req_out)
+dns_parse_reply (guint8 *in, gint r, struct rspamd_dns_resolver *resolver, struct rspamd_dns_request **req_out)
{
struct dns_header *header = (struct dns_header *)in;
struct rspamd_dns_request *req;
struct rspamd_dns_reply *rep;
union rspamd_reply_element *elt;
guint8 *pos;
- int i, t;
+ gint i, t;
/* First check header fields */
if (header->qr == 0) {
@@ -961,11 +961,11 @@ dns_parse_reply (guint8 *in, int r, struct rspamd_dns_resolver *resolver, struct
}
static void
-dns_read_cb (int fd, short what, void *arg)
+dns_read_cb (gint fd, short what, void *arg)
{
struct rspamd_dns_resolver *resolver = arg;
struct rspamd_dns_request *req = NULL;
- int r;
+ gint r;
struct rspamd_dns_reply *rep;
guint8 in[UDP_PACKET_SIZE];
@@ -982,11 +982,11 @@ dns_read_cb (int fd, short what, void *arg)
}
static void
-dns_timer_cb (int fd, short what, void *arg)
+dns_timer_cb (gint fd, short what, void *arg)
{
struct rspamd_dns_request *req = arg;
struct rspamd_dns_reply *rep;
- int r;
+ gint r;
/* Retransmit dns request */
req->retransmits ++;
@@ -1045,7 +1045,7 @@ dns_timer_cb (int fd, short what, void *arg)
}
static void
-dns_retransmit_handler (int fd, short what, void *arg)
+dns_retransmit_handler (gint fd, short what, void *arg)
{
struct rspamd_dns_request *req = arg;
struct rspamd_dns_reply *rep;
@@ -1095,7 +1095,7 @@ make_dns_request (struct rspamd_dns_resolver *resolver,
va_list args;
struct rspamd_dns_request *req;
struct in_addr addr;
- const char *name, *service, *proto;
+ const gchar *name, *service, *proto;
gint r;
req = memory_pool_alloc (pool, sizeof (struct rspamd_dns_request));
@@ -1113,25 +1113,25 @@ make_dns_request (struct rspamd_dns_resolver *resolver,
make_ptr_req (req, addr);
break;
case DNS_REQUEST_MX:
- name = va_arg (args, const char *);
+ name = va_arg (args, const gchar *);
make_mx_req (req, name);
break;
case DNS_REQUEST_A:
- name = va_arg (args, const char *);
+ name = va_arg (args, const gchar *);
make_a_req (req, name);
break;
case DNS_REQUEST_TXT:
- name = va_arg (args, const char *);
+ name = va_arg (args, const gchar *);
make_txt_req (req, name);
break;
case DNS_REQUEST_SPF:
- name = va_arg (args, const char *);
+ name = va_arg (args, const gchar *);
make_spf_req (req, name);
break;
case DNS_REQUEST_SRV:
- service = va_arg (args, const char *);
- proto = va_arg (args, const char *);
- name = va_arg (args, const char *);
+ service = va_arg (args, const gchar *);
+ proto = va_arg (args, const gchar *);
+ name = va_arg (args, const gchar *);
make_srv_req (req, service, proto, name);
break;
}
@@ -1186,7 +1186,7 @@ static gboolean
parse_resolv_conf (struct rspamd_dns_resolver *resolver)
{
FILE *r;
- char buf[BUFSIZ], *p;
+ gchar buf[BUFSIZ], *p;
struct rspamd_dns_server *new;
struct in_addr addr;
@@ -1234,8 +1234,8 @@ dns_resolver_init (struct config_file *cfg)
{
GList *cur;
struct rspamd_dns_resolver *new;
- char *begin, *p;
- int priority, i;
+ gchar *begin, *p;
+ gint priority, i;
struct rspamd_dns_server *serv;
new = memory_pool_alloc0 (cfg->cfg_pool, sizeof (struct rspamd_dns_resolver));
@@ -1305,7 +1305,7 @@ dns_resolver_init (struct config_file *cfg)
return new;
}
-static char dns_rcodes[16][16] = {
+static gchar dns_rcodes[16][16] = {
[DNS_RC_NOERROR] = "NOERROR",
[DNS_RC_FORMERR] = "FORMERR",
[DNS_RC_SERVFAIL] = "SERVFAIL",
@@ -1319,20 +1319,20 @@ static char dns_rcodes[16][16] = {
[DNS_RC_NOTZONE] = "NOTZONE",
};
-const char *
+const gchar *
dns_strerror (enum dns_rcode rcode)
{
rcode &= 0xf;
- static char numbuf[16];
+ static gchar numbuf[16];
if ('\0' == dns_rcodes[rcode][0]) {
- rspamd_snprintf (numbuf, sizeof (numbuf), "UNKNOWN: %d", (int)rcode);
+ rspamd_snprintf (numbuf, sizeof (numbuf), "UNKNOWN: %d", (gint)rcode);
return numbuf;
}
return dns_rcodes[rcode];
}
-static char dns_types[6][16] = {
+static gchar dns_types[6][16] = {
[DNS_REQUEST_A] = "A request",
[DNS_REQUEST_PTR] = "PTR request",
[DNS_REQUEST_MX] = "MX request",
@@ -1341,7 +1341,7 @@ static char dns_types[6][16] = {
[DNS_REQUEST_SPF] = "SPF request"
};
-const char *
+const gchar *
dns_strtype (enum rspamd_request_type type)
{
return dns_types[type];