mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-30 10:45:40 +03:00 
			
		
		
		
	This commit enhances the stub resolver to reload the configuration in the per-thread _res object if the /etc/resolv.conf file has changed. The resolver checks whether the application has modified _res and will not overwrite the _res object in that case. The struct resolv_context mechanism is used to check the configuration file only once per name lookup.
		
			
				
	
	
		
			101 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* libresolv interfaces for internal use across glibc.
 | |
|    Copyright (C) 2016-2017 Free Software Foundation, Inc.
 | |
|    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
 | |
|    <http://www.gnu.org/licenses/>.  */
 | |
| 
 | |
| #ifndef _RESOLV_INTERNAL_H
 | |
| #define _RESOLV_INTERNAL_H 1
 | |
| 
 | |
| #include <resolv.h>
 | |
| #include <stdbool.h>
 | |
| 
 | |
| /* 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.  */
 | |
| 
 | |
| 
 | |
| /* Internal version of RES_USE_INET6 which does not trigger a
 | |
|    deprecation warning.  */
 | |
| #define DEPRECATED_RES_USE_INET6 0x00002000
 | |
| 
 | |
| static inline bool
 | |
| res_use_inet6 (void)
 | |
| {
 | |
|   return _res.options & DEPRECATED_RES_USE_INET6;
 | |
| }
 | |
| 
 | |
| enum
 | |
|   {
 | |
|     /* The advertized EDNS buffer size.  The value 1200 is derived
 | |
|        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,
 | |
|   };
 | |
| 
 | |
| 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,
 | |
|                            unsigned char *buf, int buflen) attribute_hidden;
 | |
| 
 | |
| /* 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 *);
 | |
| libresolv_hidden_proto (__res_context_search)
 | |
| 
 | |
| /* 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 *);
 | |
| libresolv_hidden_proto (__res_context_query)
 | |
| 
 | |
| /* 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 **,
 | |
|                         int *, int *, int *) attribute_hidden;
 | |
| 
 | |
| /* Internal function similar to res_hostalias.  */
 | |
| const char *__res_context_hostalias (struct resolv_context *,
 | |
|                                      const char *, char *, size_t);
 | |
| libresolv_hidden_proto (__res_context_hostalias);
 | |
| 
 | |
| /* Add an OPT record to a DNS query.  */
 | |
| int __res_nopt (struct resolv_context *, int n0,
 | |
|                 unsigned char *buf, int buflen, int anslen) attribute_hidden;
 | |
| 
 | |
| /* 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)
 | |
| 
 | |
| #endif  /* _RESOLV_INTERNAL_H */
 |