mirror of https://github.com/Chizi123/dnscomp.git

Joel Grunbaum
2020-10-19 31afa3d8d6499d119bdf54bd37820b630c9e37e9
calculating request time as struct timespec
3 files modified
29 ■■■■ changed files
dns.c 22 ●●●● patch | view | raw | blame | history
include/dns.h 2 ●●● patch | view | raw | blame | history
main.c 5 ●●●● patch | view | raw | blame | history
dns.c
@@ -6,6 +6,7 @@
//#include <netint/in.h>
//#include <netdb.h>
//#include <sys/time.h>
#include <time.h>
#include <unistd.h>
#include "dns.h"
@@ -68,15 +69,18 @@
     char* rdata;
};
void resolve(unsigned char* buf, char* hostname, char* dns_ip, int query_type)
struct timespec resolve(unsigned char* buf, char* hostname, char* dns_ip, int query_type)
{
     int s, i;
     struct sockaddr_in dest;
     unsigned char *qname;
     struct DNS_HEADER* dns = (struct DNS_HEADER*)buf;
     struct QUESTION* qinfo;
     struct timespec start, end, total, timeout;
     timeout.tv_nsec=0; timeout.tv_sec=1;
     s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
     setsockopt(s, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(struct timespec)); //use a 1 second timeout for receiving, should be more than enough and anything more is really bad
     dest.sin_family = AF_INET;
     dest.sin_port = htons(53);
     dest.sin_addr.s_addr = inet_addr(dns_ip);
@@ -107,13 +111,25 @@
     //send request
     // return less than 0 is a fail
     clock_gettime(CLOCK_MONOTONIC, &start);
     sendto(s,(char*)buf, sizeof(struct DNS_HEADER)+strlen((const char*)qname)+1+sizeof(struct QUESTION), 0, (struct sockaddr*)&dest, sizeof(dest));
     //receive response
     //negative return is a fail
     i = sizeof(dest);
     recvfrom(s, (char*)buf, 65536, 0, (struct sockaddr*)&dest, (socklen_t*)&i);
     return;
     i = recvfrom(s, (char*)buf, 65536, 0, (struct sockaddr*)&dest, (socklen_t*)&i);
     clock_gettime(CLOCK_MONOTONIC, &end);
     if (i == -1)
          total.tv_nsec = -1;
     else
          total.tv_sec = end.tv_sec - start.tv_sec;
     if ((end.tv_nsec - start.tv_nsec) < 0)
          total.tv_nsec = start.tv_nsec - end.tv_nsec;
     else
          total.tv_nsec = end.tv_nsec - start.tv_nsec;
     close(s);
     return total;
}
void print_packet(unsigned char* buf)
include/dns.h
@@ -8,5 +8,5 @@
#define T_TXT 16                // Text record
#define T_AAAA 28               // IPv6 address
void resolve(unsigned char* buf, char* hostname, char* dns_ip, int query_type);
struct timespec resolve(unsigned char* buf, char* hostname, char* dns_ip, int query_type);
void print_packet(unsigned char* buf);
main.c
@@ -2,6 +2,7 @@
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <time.h>
#include "dns.h"
int main(int argc, char** argv)
@@ -45,7 +46,9 @@
          }
     }
     unsigned char buf[65536];
     resolve(buf, hostname, server, type);
     struct timespec time;
     time = resolve(buf, hostname, server, type);
     printf("Request took %ld.%09lds\n", time.tv_sec, time.tv_nsec);
     print_packet(buf);
     return 0;
}