2016-10-04 17:52:10 +08:00
|
|
|
/* libresolv interfaces for internal use across glibc.
|
2024-01-02 02:12:26 +08:00
|
|
|
Copyright (C) 2016-2024 Free Software Foundation, Inc.
|
2016-10-04 17:52:10 +08:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with the GNU C Library; if not, see
|
Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
$(find $(git ls-files) -prune -type f \
! -name '*.po' \
! -name 'ChangeLog*' \
! -path COPYING ! -path COPYING.LIB \
! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
! -path manual/texinfo.tex ! -path scripts/config.guess \
! -path scripts/config.sub ! -path scripts/install-sh \
! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
! -path INSTALL ! -path locale/programs/charmap-kw.h \
! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
! '(' -name configure \
-execdir test -f configure.ac -o -f configure.in ';' ')' \
! '(' -name preconfigure \
-execdir test -f preconfigure.ac ';' ')' \
-print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
chmod a+x sysdeps/unix/sysv/linux/riscv/configure
# Omit irrelevant whitespace and comment-only changes,
# perhaps from a slightly-different Autoconf version.
git checkout -f \
sysdeps/csky/configure \
sysdeps/hppa/configure \
sysdeps/riscv/configure \
sysdeps/unix/sysv/linux/csky/configure
# Omit changes that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
git checkout -f \
sysdeps/powerpc/powerpc64/ppc-mcount.S \
sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
# Omit change that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
2019-09-07 13:40:42 +08:00
|
|
|
<https://www.gnu.org/licenses/>. */
|
2016-10-04 17:52:10 +08:00
|
|
|
|
|
|
|
#ifndef _RESOLV_INTERNAL_H
|
|
|
|
#define _RESOLV_INTERNAL_H 1
|
|
|
|
|
|
|
|
#include <resolv.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
2017-04-13 16:52:27 +08:00
|
|
|
/* Resolver flags. Used for _flags in struct __res_state. */
|
|
|
|
#define RES_F_VC 0x00000001 /* Socket is TCP. */
|
|
|
|
#define RES_F_CONN 0x00000002 /* Socket is connected. */
|
|
|
|
#define RES_F_EDNS0ERR 0x00000004 /* EDNS0 caused errors. */
|
2024-06-14 00:56:30 +08:00
|
|
|
#define RES_F_SNGLKUP 0x00200000 /* Private version of RES_SNGLKUP. */
|
|
|
|
#define RES_F_SNGLKUPREOP 0x00400000 /* Private version of RES_SNGLKUPREOP. */
|
2017-04-13 16:52:27 +08:00
|
|
|
|
2022-03-23 01:35:54 +08:00
|
|
|
/* The structure HEADER is normally aligned on a word boundary. In
|
|
|
|
some code, we need to access this structure when it may be aligned
|
|
|
|
on a byte boundary. To avoid unaligned accesses, we need a typedef
|
|
|
|
with alignment one. This ensures the fields are accessed with byte
|
|
|
|
loads and stores. */
|
|
|
|
typedef HEADER __attribute__ ((__aligned__(1))) UHEADER;
|
|
|
|
|
2022-12-28 05:11:42 +08:00
|
|
|
/* List of known interfaces. */
|
|
|
|
struct netaddr
|
|
|
|
{
|
|
|
|
int addrtype;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
uint32_t addr;
|
|
|
|
uint32_t mask;
|
|
|
|
} ipv4;
|
|
|
|
} u;
|
|
|
|
};
|
|
|
|
|
2019-04-08 16:40:31 +08:00
|
|
|
/* Legacy function. This needs to be removed once all NSS modules
|
|
|
|
have been adjusted. */
|
2016-10-04 17:52:10 +08:00
|
|
|
static inline bool
|
|
|
|
res_use_inet6 (void)
|
|
|
|
{
|
2019-04-08 16:40:31 +08:00
|
|
|
return false;
|
2016-10-04 17:52:10 +08:00
|
|
|
}
|
|
|
|
|
2017-04-13 19:09:38 +08:00
|
|
|
enum
|
|
|
|
{
|
2023-05-20 21:37:47 +08:00
|
|
|
/* The advertised EDNS buffer size. The value 1200 is derived
|
2017-04-13 19:09:38 +08:00
|
|
|
from the IPv6 minimum MTU (1280 bytes) minus some arbitrary
|
|
|
|
space for tunneling overhead. If the DNS server does not react
|
|
|
|
to ICMP Fragmentation Needed But DF Set messages, this should
|
|
|
|
avoid all UDP fragments on current networks. Avoiding UDP
|
|
|
|
fragments is desirable because it prevents fragmentation-based
|
|
|
|
spoofing attacks because the randomness in a DNS packet is
|
|
|
|
concentrated in the first fragment (with the headers) and does
|
|
|
|
not protect subsequent fragments. */
|
|
|
|
RESOLV_EDNS_BUFFER_SIZE = 1200,
|
|
|
|
};
|
|
|
|
|
2017-07-01 03:10:23 +08:00
|
|
|
struct resolv_context;
|
|
|
|
|
|
|
|
/* Internal function for implementing res_nmkquery and res_mkquery.
|
|
|
|
Also used by __res_context_query. */
|
|
|
|
int __res_context_mkquery (struct resolv_context *, int op, const char *dname,
|
|
|
|
int class, int type, const unsigned char *data,
|
2021-07-19 13:55:27 +08:00
|
|
|
unsigned char *buf, int buflen);
|
|
|
|
libc_hidden_proto (__res_context_mkquery)
|
2017-07-01 03:10:23 +08:00
|
|
|
|
|
|
|
/* Main resolver query function for use within glibc. */
|
|
|
|
int __res_context_search (struct resolv_context *, const char *, int, int,
|
|
|
|
unsigned char *, int, unsigned char **,
|
|
|
|
unsigned char **, int *, int *, int *);
|
resolv: Move res_query functions into libc
This switches to public symbols without __ prefixes, due to improved
namespace management in glibc.
The script was used with --no-new-version to move the symbols
__res_nquery, __res_nquerydomain, __res_nsearch, __res_query,
__res_querydomain, __res_search, res_query, res_querydomain,
res_search. The public symbols res_nquery, res_nquerydomain,
res_nsearch, res_ownok, res_query, res_querydomain, res_search
were added with make update-all-abi.
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
Tested-by: Carlos O'Donell <carlos@redhat.com>
2021-07-19 13:55:27 +08:00
|
|
|
libc_hidden_proto (__res_context_search)
|
2017-07-01 03:10:23 +08:00
|
|
|
|
|
|
|
/* Main resolver query function for use within glibc. */
|
|
|
|
int __res_context_query (struct resolv_context *, const char *, int, int,
|
|
|
|
unsigned char *, int, unsigned char **,
|
|
|
|
unsigned char **, int *, int *, int *);
|
resolv: Move res_query functions into libc
This switches to public symbols without __ prefixes, due to improved
namespace management in glibc.
The script was used with --no-new-version to move the symbols
__res_nquery, __res_nquerydomain, __res_nsearch, __res_query,
__res_querydomain, __res_search, res_query, res_querydomain,
res_search. The public symbols res_nquery, res_nquerydomain,
res_nsearch, res_ownok, res_query, res_querydomain, res_search
were added with make update-all-abi.
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
Tested-by: Carlos O'Donell <carlos@redhat.com>
2021-07-19 13:55:27 +08:00
|
|
|
libc_hidden_proto (__res_context_query)
|
2017-07-01 03:10:23 +08:00
|
|
|
|
|
|
|
/* Internal function used to implement the query and search
|
|
|
|
functions. */
|
|
|
|
int __res_context_send (struct resolv_context *, const unsigned char *, int,
|
|
|
|
const unsigned char *, int, unsigned char *,
|
|
|
|
int, unsigned char **, unsigned char **,
|
2021-07-19 13:55:27 +08:00
|
|
|
int *, int *, int *);
|
|
|
|
libc_hidden_proto (__res_context_send)
|
2017-07-01 03:10:23 +08:00
|
|
|
|
2022-06-25 00:16:41 +08:00
|
|
|
/* Return true if the query has been handled in RES_NOAAAA mode. For
|
|
|
|
that, RES_NOAAAA must be active, and the question type must be AAAA.
|
|
|
|
The caller is expected to return *RESULT as the return value. */
|
|
|
|
bool __res_handle_no_aaaa (struct resolv_context *ctx,
|
|
|
|
const unsigned char *buf, int buflen,
|
|
|
|
unsigned char *ans, int anssiz, int *result)
|
|
|
|
attribute_hidden;
|
|
|
|
|
2017-07-01 03:10:23 +08:00
|
|
|
/* Internal function similar to res_hostalias. */
|
|
|
|
const char *__res_context_hostalias (struct resolv_context *,
|
|
|
|
const char *, char *, size_t);
|
2021-07-19 13:55:27 +08:00
|
|
|
libc_hidden_proto (__res_context_hostalias);
|
2017-07-01 03:10:23 +08:00
|
|
|
|
2017-04-13 19:09:38 +08:00
|
|
|
/* Add an OPT record to a DNS query. */
|
2017-07-01 03:10:23 +08:00
|
|
|
int __res_nopt (struct resolv_context *, int n0,
|
2021-07-19 13:55:27 +08:00
|
|
|
unsigned char *buf, int buflen, int anslen);
|
|
|
|
libc_hidden_proto (__res_nopt)
|
2017-04-13 19:09:38 +08:00
|
|
|
|
2017-06-21 19:09:08 +08:00
|
|
|
/* Convert from presentation format (which usually means ASCII
|
|
|
|
printable) to network format (which is usually some kind of binary
|
|
|
|
format). The input is in the range [SRC, SRC + SRCLEN). The
|
|
|
|
output is written to DST (which has to be 4 or 16 bytes long,
|
|
|
|
depending on AF). Return 0 for invalid input, 1 for success, -1
|
|
|
|
for an invalid address family. */
|
|
|
|
int __inet_pton_length (int af, const char *src, size_t srclen, void *);
|
|
|
|
libc_hidden_proto (__inet_pton_length)
|
|
|
|
|
2018-06-26 21:13:54 +08:00
|
|
|
/* Called as part of the thread shutdown sequence. */
|
|
|
|
void __res_thread_freeres (void) attribute_hidden;
|
|
|
|
|
2019-03-12 18:40:47 +08:00
|
|
|
/* The Linux kernel does not enable all ICMP messages on a UDP socket
|
|
|
|
by default. A call this function enables full error reporting for
|
|
|
|
the socket FD. FAMILY must be AF_INET or AF_INET6. Returns 0 on
|
|
|
|
success, -1 on failure. */
|
|
|
|
int __res_enable_icmp (int family, int fd) attribute_hidden;
|
|
|
|
|
2021-07-19 13:55:27 +08:00
|
|
|
|
|
|
|
/* Returns the name server address for the indicated index. */
|
|
|
|
struct sockaddr *__res_get_nsaddr (res_state statp, unsigned int n);
|
|
|
|
libc_hidden_proto (__res_get_nsaddr)
|
|
|
|
|
|
|
|
|
2016-10-04 17:52:10 +08:00
|
|
|
#endif /* _RESOLV_INTERNAL_H */
|