Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
D
DNS-Compliance-Testing
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
6
Issues
6
List
Boards
Labels
Service Desk
Milestones
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Incidents
Environments
Packages & Registries
Packages & Registries
Container Registry
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ISC Open Source Projects
DNS-Compliance-Testing
Commits
222ab0d0
Commit
222ab0d0
authored
Feb 23, 2018
by
Mark Andrews
Committed by
Ondřej Surý
Feb 23, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
address Linux portability issues
parent
ab21dbd5
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
87 additions
and
10 deletions
+87
-10
configure.ac
configure.ac
+18
-0
genreport.c
genreport.c
+69
-10
No files found.
configure.ac
View file @
222ab0d0
...
...
@@ -9,4 +9,22 @@ AC_USE_SYSTEM_EXTENSIONS
AC_CANONICAL_HOST
AC_CHECK_LIB(resolv,res_init)
AC_CHECK_LIB(bind,res_init)
AC_CHECK_HEADERS(sys/types.h netinet/in.h arpa/nameser.h resolv.h)
AC_MSG_CHECKING(for res_getservers)
AC_TRY_COMPILE([
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/nameser.h>
#include <resolv.h>
],
[
union res_sockaddr_union servers[10];
res_getservers(&_res, &servers, sizeof(servers)/sizeof(*servers));
],
[
AC_DEFINE([HAVE_RES_GETSERVERS], [1],
[Define to 1 if you have the `res_getservers' function.])
AC_MSG_RESULT(yes)
],
[AC_MSG_RESULT(no)])
AC_OUTPUT
genreport.c
View file @
222ab0d0
...
...
@@ -8,6 +8,8 @@
#define FD_SETSIZE 1600
#include <config.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
...
...
@@ -36,6 +38,10 @@
#include <resolv.h>
#include <signal.h>
#ifndef FD_COPY
#define FD_COPY(x, y) memmove(y, x, sizeof(*x))
#endif
#define ns_t_dname 39
#define ns_t_sink 40
#define ns_t_apl 42
...
...
@@ -99,7 +105,16 @@ static int inorder = 0;
static
int
serial
=
0
;
static
long
long
sent
;
#ifdef HAVE_RES_GETSERVERS
static
union
res_sockaddr_union
servers
[
10
];
#else
static
union
{
struct
sockaddr_in
sin
;
struct
sockaddr_in6
sin6
;
}
servers
[
10
];
#endif
static
int
nservers
=
0
;
int
ident
=
0
;
...
...
@@ -427,7 +442,7 @@ storage_equal(struct sockaddr_storage *s1, struct sockaddr_storage *s2) {
struct
sockaddr_in
*
sin1
,
*
sin2
;
struct
sockaddr_in6
*
sin61
,
*
sin62
;
if
(
s1
->
ss_
len
!=
s2
->
ss_len
||
s1
->
ss_
family
!=
s2
->
ss_family
)
if
(
s1
->
ss_family
!=
s2
->
ss_family
)
return
(
0
);
switch
(
s1
->
ss_family
)
{
...
...
@@ -799,13 +814,16 @@ addtag(struct workitem *item, const char *tag) {
static
void
resend
(
struct
workitem
*
item
)
{
int
n
,
fd
=
-
1
;
socklen_t
ss_len
;
switch
(
item
->
summary
->
storage
.
ss_family
)
{
case
AF_INET
:
fd
=
udp4
;
ss_len
=
sizeof
(
struct
sockaddr_in
);
break
;
case
AF_INET6
:
fd
=
udp6
;
ss_len
=
sizeof
(
struct
sockaddr_in6
);
break
;
}
...
...
@@ -826,8 +844,7 @@ resend(struct workitem *item) {
}
n
=
sendto
(
fd
,
item
->
buf
,
item
->
buflen
,
0
,
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
item
->
summary
->
storage
.
ss_len
);
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
ss_len
);
if
(
n
>
0
)
{
if
(
debug
)
printf
(
"resend %s rdlen=%u udpsize=%u flags=%04x "
...
...
@@ -863,13 +880,17 @@ dotest(struct workitem *item) {
unsigned
char
*
cp
;
unsigned
int
ttl
;
int
n
,
fd
,
id
,
tries
=
0
,
opcode
;
socklen_t
ss_len
;
switch
(
item
->
summary
->
storage
.
ss_family
)
{
case
AF_INET
:
fd
=
udp4
;
ss_len
=
sizeof
(
struct
sockaddr_in
);
break
;
case
AF_INET6
:
fd
=
udp6
;
ss_len
=
sizeof
(
struct
sockaddr_in6
);
break
;
}
...
...
@@ -996,8 +1017,7 @@ dotest(struct workitem *item) {
}
n
=
sendto
(
fd
,
item
->
buf
,
item
->
buflen
,
0
,
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
item
->
summary
->
storage
.
ss_len
);
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
ss_len
);
}
if
(
n
>
0
)
{
...
...
@@ -1133,6 +1153,7 @@ static void
dolookup
(
struct
workitem
*
item
,
int
type
)
{
char
name
[
1024
];
int
n
,
fd
=
-
1
;
socklen_t
ss_len
;
item
->
summary
->
tests
++
;
item
->
summary
->
type
=
item
->
type
=
type
;
...
...
@@ -1148,9 +1169,11 @@ dolookup(struct workitem *item, int type) {
switch
(
item
->
summary
->
storage
.
ss_family
)
{
case
AF_INET
:
fd
=
udp4
;
ss_len
=
sizeof
(
struct
sockaddr_in
);
break
;
case
AF_INET6
:
fd
=
udp6
;
ss_len
=
sizeof
(
struct
sockaddr_in6
);
break
;
}
...
...
@@ -1218,8 +1241,7 @@ dolookup(struct workitem *item, int type) {
}
n
=
sendto
(
fd
,
item
->
buf
,
item
->
buflen
,
0
,
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
item
->
summary
->
storage
.
ss_len
);
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
ss_len
);
}
if
(
n
>
0
)
{
if
(
debug
)
...
...
@@ -1946,6 +1968,7 @@ connectdone(int fd) {
static
void
connecttoserver
(
struct
workitem
*
item
)
{
int
fd
,
n
,
on
=
1
;
socklen_t
ss_len
;
fd
=
socket
(
item
->
summary
->
storage
.
ss_family
,
SOCK_STREAM
,
IPPROTO_TCP
);
...
...
@@ -1964,6 +1987,7 @@ connecttoserver(struct workitem *item) {
freeitem
(
item
);
return
;
}
/*
* Make the socket non blocking.
*/
...
...
@@ -1977,6 +2001,7 @@ connecttoserver(struct workitem *item) {
return
;
}
#ifdef SO_NOSIGPIPE
/*
* Don't generate a SIG_PIPE if there is a I/O error on this socket.
*/
...
...
@@ -1989,12 +2014,21 @@ connecttoserver(struct workitem *item) {
freeitem
(
item
);
return
;
}
#endif
switch
(
item
->
summary
->
storage
.
ss_family
)
{
case
AF_INET
:
ss_len
=
sizeof
(
struct
sockaddr_in
);
break
;
case
AF_INET6
:
ss_len
=
sizeof
(
struct
sockaddr_in6
);
break
;
}
/*
* Start the actual connect.
*/
n
=
connect
(
fd
,
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
item
->
summary
->
storage
.
ss_len
);
n
=
connect
(
fd
,
(
struct
sockaddr
*
)
&
item
->
summary
->
storage
,
ss_len
);
if
(
n
==
-
1
&&
errno
==
EINPROGRESS
)
{
if
(
!
item
->
outstanding
++
)
outstanding
++
;
...
...
@@ -2669,7 +2703,16 @@ main(int argc, char **argv) {
ident
=
getpid
()
&
0xFFFF
;
#ifdef SIGINFO
/* Preferred signal. */
signal
(
SIGINFO
,
info
);
#endif
signal
(
SIGUSR1
,
info
);
#ifndef SO_NOSIGPIPE
/* Ignore SIGPIPE if we can't set SO_NOSIGPIPE. */
signal
(
SIGPIPE
,
SIG_IGN
);
#endif
FD_ZERO
(
&
rfds
);
FD_ZERO
(
&
wfds
);
...
...
@@ -2741,8 +2784,12 @@ main(int argc, char **argv) {
}
}
if
(
icmp4
>=
0
)
{
#ifdef IP_STRIPHDR
n
=
setsockopt
(
icmp4
,
IPPROTO_IP
,
IP_STRIPHDR
,
(
void
*
)
&
on
,
sizeof
(
on
));
#else
n
=
-
1
;
#endif
if
(
n
==
-
1
)
{
close
(
icmp4
);
icmp4
=
-
1
;
...
...
@@ -2784,9 +2831,21 @@ main(int argc, char **argv) {
* If we haven't been given recursive servers to use the
* get the system's default servers.
*/
if
(
!
nservers
)
#ifdef HAVE_RES_GETSERVERS
if
(
!
nservers
)
{
nservers
=
res_getservers
(
&
_res
,
servers
,
sizeof
(
servers
)
/
sizeof
(
servers
[
0
]));
}
#else
/*
* This does not support IPv6 nameservers.
*/
if
(
!
nservers
)
{
memset
(
servers
,
0
,
sizeof
(
servers
));
for
(;
nservers
<
_res
.
nscount
;
nservers
++
)
servers
[
nservers
].
sin
=
_res
.
nsaddr_list
[
nservers
];
}
#endif
gettimeofday
(
&
start
,
NULL
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment