1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
$NetBSD: patch-ar,v 1.1 2014/06/15 20:48:50 jnemeth Exp $
--- sendmail/daemon.c.orig 2014-05-16 20:40:15.000000000 +0000
+++ sendmail/daemon.c
@@ -57,6 +57,10 @@ SM_RCSID("@(#)$Id: daemon.c,v 8.698 2013
# endif /* HAS_IN_H */
#endif /* IP_SRCROUTE && NETINET */
+#if NAMED_BIND
+extern struct __res_state sm_res;
+#endif
+
#include <sm/fdset.h>
#define DAEMON_C 1
@@ -2295,16 +2299,16 @@ makeconnection(host, port, mci, e, enoug
if (hp == NULL && p[-1] == '.')
{
#if NAMED_BIND
- int oldopts = _res.options;
+ int oldopts = sm_res.options;
- _res.options &= ~(RES_DEFNAMES|RES_DNSRCH);
+ sm_res.options &= ~(RES_DEFNAMES|RES_DNSRCH);
#endif /* NAMED_BIND */
p[-1] = '\0';
hp = sm_gethostbyname(&host[1],
family);
p[-1] = '.';
#if NAMED_BIND
- _res.options = oldopts;
+ sm_res.options = oldopts;
#endif /* NAMED_BIND */
}
*p = ']';
@@ -2333,15 +2337,15 @@ makeconnection(host, port, mci, e, enoug
if (hp == NULL && *p == '.')
{
#if NAMED_BIND
- int oldopts = _res.options;
+ int oldopts = sm_res.options;
- _res.options &= ~(RES_DEFNAMES|RES_DNSRCH);
+ sm_res.options &= ~(RES_DEFNAMES|RES_DNSRCH);
#endif /* NAMED_BIND */
*p = '\0';
hp = sm_gethostbyname(host, family);
*p = '.';
#if NAMED_BIND
- _res.options = oldopts;
+ sm_res.options = oldopts;
#endif /* NAMED_BIND */
}
}
@@ -4005,13 +4009,13 @@ host_map_lookup(map, name, av, statp)
#if NAMED_BIND
if (map->map_timeout > 0)
{
- retrans = _res.retrans;
- _res.retrans = map->map_timeout;
+ retrans = sm_res.retrans;
+ sm_res.retrans = map->map_timeout;
}
if (map->map_retry > 0)
{
- retry = _res.retry;
- _res.retry = map->map_retry;
+ retry = sm_res.retry;
+ sm_res.retry = map->map_retry;
}
#endif /* NAMED_BIND */
@@ -4074,9 +4078,9 @@ host_map_lookup(map, name, av, statp)
}
#if NAMED_BIND
if (map->map_timeout > 0)
- _res.retrans = retrans;
+ sm_res.retrans = retrans;
if (map->map_retry > 0)
- _res.retry = retry;
+ sm_res.retry = retry;
#endif /* NAMED_BIND */
s->s_namecanon.nc_flags |= NCF_VALID; /* will be soon */
@@ -4407,11 +4411,11 @@ hostnamebyanyaddr(sap)
# if NAMED_BIND
/* shorten name server timeout to avoid higher level timeouts */
- saveretry = _res.retry;
- if (_res.retry * _res.retrans > 20)
- _res.retry = 20 / _res.retrans;
- if (_res.retry == 0)
- _res.retry = 1;
+ saveretry = sm_res.retry;
+ if (sm_res.retry * sm_res.retrans > 20)
+ sm_res.retry = 20 / sm_res.retrans;
+ if (sm_res.retry == 0)
+ sm_res.retry = 1;
# endif /* NAMED_BIND */
switch (sap->sa.sa_family)
@@ -4450,7 +4454,7 @@ hostnamebyanyaddr(sap)
}
# if NAMED_BIND
- _res.retry = saveretry;
+ sm_res.retry = saveretry;
# endif /* NAMED_BIND */
# if NETINET || NETINET6
|