5 /* Internal definitions used in the libc code. */
6 #define __getservbyname_r getservbyname_r
7 #define __socket socket
8 #define __getsockname getsockname
9 #define __inet_aton inet_aton
10 #define __gethostbyaddr_r gethostbyaddr_r
11 #define __gethostbyname2_r gethostbyname2_r
15 __check_pf (bool *p1
, bool *p2
, struct in6addrinfo
**in6ai
, size_t *in6ailen
)
23 __check_native (uint32_t a1_index
, int *a1_native
,
24 uint32_t a2_index
, int *a2_native
)
28 __idna_to_ascii_lz (const char *input
, char **output
, int flags
)
33 __idna_to_unicode_lzlz (const char *input
, char **output
, int flags
)
39 #include "../sysdeps/posix/getaddrinfo.c"
41 service_user
*__nss_hosts_database attribute_hidden
;
44 /* This is the beginning of the real test code. The above defines
45 (among other things) the function rfc3484_sort. */
48 #if __BYTE_ORDER == __BIG_ENDIAN
51 # define h(n) __bswap_constant_32 (n)
54 struct sockaddr_in addrs
[] =
56 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a86d1d) } },
57 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a85d03) } },
58 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a82c3d) } },
59 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a86002) } },
60 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a802f3) } },
61 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a80810) } },
62 { .sin_family
= AF_INET
, .sin_addr
= { h (0xc0a85e02) } }
64 #define naddrs (sizeof (addrs) / sizeof (addrs[0]))
65 static struct addrinfo ais
[naddrs
];
66 static struct sort_result results
[naddrs
];
67 static size_t order
[naddrs
];
69 static int expected
[naddrs
] =
76 __getline (char **lineptr
, size_t *n
, FILE *s
)
87 labels
= default_labels
;
88 precedence
= default_precedence
;
89 scopes
= default_scopes
;
91 struct sockaddr_in so
;
92 so
.sin_family
= AF_INET
;
93 so
.sin_addr
.s_addr
= h (0xc0a85f19);
95 for (int i
= 0; i
< naddrs
; ++i
)
97 ais
[i
].ai_family
= AF_INET
;
98 ais
[i
].ai_addr
= (struct sockaddr
*) &addrs
[i
];
99 results
[i
].dest_addr
= &ais
[i
];
100 results
[i
].got_source_addr
= true;
101 memcpy(&results
[i
].source_addr
, &so
, sizeof (so
));
102 results
[i
].source_addr_len
= sizeof (so
);
103 results
[i
].source_addr_flags
= 0;
104 results
[i
].prefixlen
= 8;
105 results
[i
].index
= 0;
110 struct sort_result_combo combo
= { .results
= results
, .nresults
= naddrs
};
111 qsort_r (order
, naddrs
, sizeof (order
[0]), rfc3484_sort
, &combo
);
114 for (int i
= 0; i
< naddrs
; ++i
)
116 struct in_addr addr
= ((struct sockaddr_in
*) (results
[order
[i
]].dest_addr
->ai_addr
))->sin_addr
;
118 int here
= memcmp (&addr
, &addrs
[expected
[i
]].sin_addr
,
119 sizeof (struct in_addr
));
120 printf ("[%d] = %s: %s\n", i
, inet_ntoa (addr
), here
? "FAIL" : "OK");
127 #define TEST_FUNCTION do_test ()
128 #include "../test-skeleton.c"