Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
ff7a61f8
Commit
ff7a61f8
authored
Sep 24, 2000
by
Rein Klazes
Committed by
Alexandre Julliard
Sep 24, 2000
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make calls to gethostbyname, gethostbyaddr, getservbyname,
getservbyport, getprotobyname and getprotobynumber thread-safe.
parent
2cc15088
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
255 additions
and
66 deletions
+255
-66
configure
configure
+77
-26
configure.in
configure.in
+27
-0
async.c
dlls/winsock/async.c
+52
-20
socket.c
dlls/winsock/socket.c
+93
-20
acconfig.h
include/acconfig.h
+3
-0
config.h.in
include/config.h.in
+3
-0
No files found.
configure
View file @
ff7a61f8
...
...
@@ -5883,15 +5883,66 @@ EOF
echo
$ac_n
"checking "
whether we can use re-entrant gethostbyname_r Linux style
"""...
$ac_c
"
1>&6
echo
"configure:5889: checking "
whether we can use re-entrant gethostbyname_r Linux style
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_linux_gethostbyname_r_6
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 5894 "configure"
#include "confdefs.h"
#include <netdb.h>
int main() {
char *name=NULL;
struct hostent he;
struct hostent *result;
char *buf=NULL;
int bufsize=0;
int res,errnr;
char *addr=NULL;
int addrlen=0;
int addrtype=0;
res=gethostbyname_r(name,&he,buf,bufsize,&result,&errnr);
res=gethostbyaddr_r(addr, addrlen, addrtype,&he,buf,bufsize,&result,&errnr);
; return 0; }
EOF
if
{
(
eval echo
configure:5915:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_linux_gethostbyname_r_6
=
yes
else
echo
"configure: failed program was:"
>
&5
cat
conftest.
$ac_ext
>
&5
rm
-rf
conftest
*
wine_cv_linux_gethostbyname_r_6
=
no
fi
rm
-f
conftest
*
fi
echo
"
$ac_t
""
$wine_cv_linux_gethostbyname_r_6
"
1>&6
if
test
"
$wine_cv_linux_gethostbyname_r_6
"
=
"yes"
then
cat
>>
confdefs.h
<<
\
EOF
#define HAVE_LINUX_GETHOSTBYNAME_R_6 1
EOF
fi
if
test
"
$ac_cv_header_linux_joystick_h
"
=
"yes"
then
echo
$ac_n
"checking "
whether linux/joystick.h uses the Linux 2.2+ API
"""...
$ac_c
"
1>&6
echo
"configure:5
890
: checking "
whether linux/joystick.h uses the Linux 2.2+ API
""
>
&5
echo
"configure:5
941
: checking "
whether linux/joystick.h uses the Linux 2.2+ API
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_linux_joystick_22_api
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 5
895
"configure"
#line 5
946
"configure"
#include "confdefs.h"
#include <sys/ioctl.h>
...
...
@@ -5906,7 +5957,7 @@ int main() {
/*empty*/
; return 0; }
EOF
if
{
(
eval echo
configure:59
10
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:59
61
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_linux_joystick_22_api
=
yes
else
...
...
@@ -5933,12 +5984,12 @@ fi
if
test
"
$ac_cv_header_sys_vfs_h
"
=
"yes"
then
echo
$ac_n
"checking "
whether sys/vfs.h defines statfs
"""...
$ac_c
"
1>&6
echo
"configure:59
37
: checking "
whether sys/vfs.h defines statfs
""
>
&5
echo
"configure:59
88
: checking "
whether sys/vfs.h defines statfs
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_sys_vfs_has_statfs
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 59
42
"configure"
#line 59
93
"configure"
#include "confdefs.h"
#include <sys/types.h>
...
...
@@ -5955,7 +6006,7 @@ int main() {
; return 0; }
EOF
if
{
(
eval echo
configure:
5959
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:
6010
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_sys_vfs_has_statfs
=
yes
else
...
...
@@ -5982,12 +6033,12 @@ fi
if
test
"
$ac_cv_header_sys_statfs_h
"
=
"yes"
then
echo
$ac_n
"checking "
whether sys/statfs.h defines statfs
"""...
$ac_c
"
1>&6
echo
"configure:
5986
: checking "
whether sys/statfs.h defines statfs
""
>
&5
echo
"configure:
6037
: checking "
whether sys/statfs.h defines statfs
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_sys_statfs_has_statfs
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line
5991
"configure"
#line
6042
"configure"
#include "confdefs.h"
#include <sys/types.h>
...
...
@@ -6002,7 +6053,7 @@ int main() {
; return 0; }
EOF
if
{
(
eval echo
configure:60
06
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:60
57
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_sys_statfs_has_statfs
=
yes
else
...
...
@@ -6029,12 +6080,12 @@ fi
if
test
"
$ac_cv_header_sys_mount_h
"
=
"yes"
then
echo
$ac_n
"checking "
whether sys/mount.h defines statfs
"""...
$ac_c
"
1>&6
echo
"configure:60
33
: checking "
whether sys/mount.h defines statfs
""
>
&5
echo
"configure:60
84
: checking "
whether sys/mount.h defines statfs
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_sys_mount_has_statfs
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 60
38
"configure"
#line 60
89
"configure"
#include "confdefs.h"
#include <sys/types.h>
...
...
@@ -6049,7 +6100,7 @@ int main() {
; return 0; }
EOF
if
{
(
eval echo
configure:6
053
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:6
104
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_sys_mount_has_statfs
=
yes
else
...
...
@@ -6075,7 +6126,7 @@ fi
echo
$ac_n
"checking "
for
statfs.f_bfree
"""...
$ac_c
"
1>&6
echo
"configure:6
079
: checking "
for
statfs.f_bfree
""
>
&5
echo
"configure:6
130
: checking "
for
statfs.f_bfree
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_statfs_bfree
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
...
...
@@ -6084,7 +6135,7 @@ else
wine_cv_statfs_bfree
=
no
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 6
088
"configure"
#line 6
139
"configure"
#include "confdefs.h"
#include <sys/types.h>
...
...
@@ -6111,7 +6162,7 @@ int main() {
; return 0; }
EOF
if
{
(
eval echo
configure:61
15
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:61
66
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_statfs_bfree
=
yes
else
...
...
@@ -6135,7 +6186,7 @@ EOF
fi
echo
$ac_n
"checking "
for
statfs.f_bavail
"""...
$ac_c
"
1>&6
echo
"configure:61
39
: checking "
for
statfs.f_bavail
""
>
&5
echo
"configure:61
90
: checking "
for
statfs.f_bavail
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
wine_cv_statfs_bavail
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
...
...
@@ -6144,7 +6195,7 @@ else
wine_cv_statfs_bavail
=
no
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 61
48
"configure"
#line 61
99
"configure"
#include "confdefs.h"
#include <sys/types.h>
...
...
@@ -6171,7 +6222,7 @@ int main() {
; return 0; }
EOF
if
{
(
eval echo
configure:6
175
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:6
226
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
wine_cv_statfs_bavail
=
yes
else
...
...
@@ -6196,12 +6247,12 @@ fi
echo
$ac_n
"checking "
for
msg_accrights
in
struct msghdr
"""...
$ac_c
"
1>&6
echo
"configure:62
00
: checking "
for
msg_accrights
in
struct msghdr
""
>
&5
echo
"configure:62
51
: checking "
for
msg_accrights
in
struct msghdr
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
ac_cv_c_msg_accrights
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 62
05
"configure"
#line 62
56
"configure"
#include "confdefs.h"
#include <sys/types.h>
#include <sys/socket.h>
...
...
@@ -6209,7 +6260,7 @@ int main() {
struct msghdr hdr; hdr.msg_accrights=0
; return 0; }
EOF
if
{
(
eval echo
configure:62
13
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:62
64
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
ac_cv_c_msg_accrights
=
"yes"
else
...
...
@@ -6232,12 +6283,12 @@ fi
echo
$ac_n
"checking "
for
sun_len
in
struct sockaddr_un
"""...
$ac_c
"
1>&6
echo
"configure:62
36
: checking "
for
sun_len
in
struct sockaddr_un
""
>
&5
echo
"configure:62
87
: checking "
for
sun_len
in
struct sockaddr_un
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
ac_cv_c_sun_len
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 62
41
"configure"
#line 62
92
"configure"
#include "confdefs.h"
#include <sys/types.h>
#include <sys/socket.h>
...
...
@@ -6246,7 +6297,7 @@ int main() {
static struct sockaddr_un addr; addr.sun_len = 1
; return 0; }
EOF
if
{
(
eval echo
configure:6
250
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
if
{
(
eval echo
configure:6
301
:
\"
$ac_compile
\"
)
1>&5
;
(
eval
$ac_compile
)
2>&5
;
}
;
then
rm
-rf
conftest
*
ac_cv_c_sun_len
=
"yes"
else
...
...
@@ -6269,12 +6320,12 @@ fi
echo
$ac_n
"checking "
whether we need to define __i386__
"""...
$ac_c
"
1>&6
echo
"configure:6
273
: checking "
whether we need to define __i386__
""
>
&5
echo
"configure:6
324
: checking "
whether we need to define __i386__
""
>
&5
if
eval
"test
\"
`
echo
'$''{'
ac_cv_cpp_def_i386
'+set}'
`
\"
= set"
;
then
echo
$ac_n
"(cached)
$ac_c
"
1>&6
else
cat
>
conftest.
$ac_ext
<<
EOF
#line 6
278
"configure"
#line 6
329
"configure"
#include "confdefs.h"
#if (defined(i386) || defined(__i386)) && !defined(__i386__)
yes
...
...
configure.in
View file @
ff7a61f8
...
...
@@ -786,6 +786,33 @@ AC_C_INLINE()
AC_TYPE_SIZE_T()
AC_CHECK_SIZEOF(long long,0)
AC_CACHE_CHECK("whether we can use re-entrant gethostbyname_r Linux style",
wine_cv_linux_gethostbyname_r_6,
AC_TRY_COMPILE([
#include <netdb.h>
], [
char *name=NULL;
struct hostent he;
struct hostent *result;
char *buf=NULL;
int bufsize=0;
int res,errnr;
char *addr=NULL;
int addrlen=0;
int addrtype=0;
res=gethostbyname_r(name,&he,buf,bufsize,&result,&errnr);
res=gethostbyaddr_r(addr, addrlen, addrtype,&he,buf,bufsize,&result,&errnr);
],
wine_cv_linux_gethostbyname_r_6=yes,
wine_cv_linux_gethostbyname_r_6=no
)
)
if test "$wine_cv_linux_gethostbyname_r_6" = "yes"
then
AC_DEFINE(HAVE_LINUX_GETHOSTBYNAME_R_6)
fi
if test "$ac_cv_header_linux_joystick_h" = "yes"
then
AC_CACHE_CHECK("whether linux/joystick.h uses the Linux 2.2+ API",
...
...
dlls/winsock/async.c
View file @
ff7a61f8
...
...
@@ -90,10 +90,14 @@
DEFAULT_DEBUG_CHANNEL
(
winsock
);
/* critical section to protect some non-rentrant net function */
CRITICAL_SECTION
csWSgetXXXbyYYY
=
CRITICAL_SECTION_INIT
;
/* protoptypes of some functions in socket.c
*/
UINT16
wsaErrno
(
void
);
UINT16
wsaHerrno
(
void
);
UINT16
wsaHerrno
(
int
errnr
);
#define AQ_WIN16 0x00
#define AQ_WIN32 0x04
...
...
@@ -362,24 +366,49 @@ static DWORD WINAPI _async_queryfun(LPVOID arg) {
case
AQ_GETHOST
:
{
struct
hostent
*
he
;
char
*
copy_hostent
=
targetptr
;
#if HAVE_LINUX_GETHOSTBYNAME_R_6
char
*
extrabuf
;
int
ebufsize
=
1024
;
struct
hostent
hostentry
;
int
locerr
=
ENOBUFS
;
he
=
NULL
;
extrabuf
=
HeapAlloc
(
GetProcessHeap
(),
0
,
ebufsize
)
;
while
(
extrabuf
)
{
int
res
=
(
aq
->
flags
&
AQ_NAME
)
?
gethostbyname_r
(
aq
->
host_name
,
&
hostentry
,
extrabuf
,
ebufsize
,
&
he
,
&
locerr
)
:
gethostbyaddr_r
(
aq
->
host_addr
,
aq
->
host_len
,
aq
->
host_type
,
&
hostentry
,
extrabuf
,
ebufsize
,
&
he
,
&
locerr
);
if
(
res
!=
ERANGE
)
break
;
ebufsize
*=
2
;
extrabuf
=
HeapReAlloc
(
GetProcessHeap
(),
0
,
extrabuf
,
ebufsize
)
;
}
if
(
!
he
)
fail
=
((
locerr
<
0
)
?
wsaErrno
()
:
wsaHerrno
(
locerr
));
#else
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
he
=
(
aq
->
flags
&
AQ_NAME
)
?
gethostbyname
(
aq
->
host_name
)
:
gethostbyaddr
(
aq
->
host_addr
,
aq
->
host_len
,
aq
->
host_type
);
if
(
!
he
)
fail
=
((
h_errno
<
0
)
?
wsaErrno
()
:
wsaHerrno
(
h_errno
));
#endif
if
(
he
)
{
size
=
WS_copy_he
(
copy_hostent
,(
char
*
)
aq
->
sbuf
,
aq
->
sbuflen
,
he
,
aq
->
flags
);
if
(
size
<
0
)
{
fail
=
WSAENOBUFS
;
size
=
-
size
;
}
}
else
{
fail
=
((
h_errno
<
0
)
?
wsaErrno
()
:
wsaHerrno
());
}
#if HAVE_LINUX_GETHOSTBYNAME_R_6
HeapFree
(
GetProcessHeap
(),
0
,
extrabuf
);
#else
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
#endif
}
break
;
case
AQ_GETPROTO
:
{
struct
protoent
*
pe
;
char
*
copy_protoent
=
targetptr
;
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
pe
=
(
aq
->
flags
&
AQ_NAME
)
?
getprotobyname
(
aq
->
proto_name
)
:
getprotobynumber
(
aq
->
proto_number
);
...
...
@@ -390,19 +419,21 @@ static DWORD WINAPI _async_queryfun(LPVOID arg) {
size
=
-
size
;
}
}
else
{
if
(
aq
->
flags
&
AQ_NAME
)
MESSAGE
(
"protocol %s not found; You might want to add "
"this to /etc/protocols
\n
"
,
debugstr_a
(
aq
->
proto_name
)
);
else
MESSAGE
(
"protocol number %d not found; You might want to add "
"this to /etc/protocols
\n
"
,
aq
->
proto_number
);
fail
=
WSANO_DATA
;
if
(
aq
->
flags
&
AQ_NAME
)
MESSAGE
(
"protocol %s not found; You might want to add "
"this to /etc/protocols
\n
"
,
debugstr_a
(
aq
->
proto_name
)
);
else
MESSAGE
(
"protocol number %d not found; You might want to add "
"this to /etc/protocols
\n
"
,
aq
->
proto_number
);
fail
=
WSANO_DATA
;
}
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
}
break
;
case
AQ_GETSERV
:
{
struct
servent
*
se
;
char
*
copy_servent
=
targetptr
;
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
se
=
(
aq
->
flags
&
AQ_NAME
)
?
getservbyname
(
aq
->
serv_name
,
aq
->
serv_proto
)
:
getservbyport
(
aq
->
serv_port
,
aq
->
serv_proto
);
...
...
@@ -413,16 +444,17 @@ static DWORD WINAPI _async_queryfun(LPVOID arg) {
size
=
-
size
;
}
}
else
{
if
(
aq
->
flags
&
AQ_NAME
)
MESSAGE
(
"service %s protocol %s not found; You might want to add "
"this to /etc/services
\n
"
,
debugstr_a
(
aq
->
serv_name
)
,
aq
->
serv_proto
?
debugstr_a
(
aq
->
serv_proto
)
:
"*"
);
else
MESSAGE
(
"service on port %d protocol %s not found; You might want to add "
"this to /etc/services
\n
"
,
aq
->
serv_port
,
aq
->
serv_proto
?
debugstr_a
(
aq
->
serv_proto
)
:
"*"
);
fail
=
WSANO_DATA
;
if
(
aq
->
flags
&
AQ_NAME
)
MESSAGE
(
"service %s protocol %s not found; You might want to add "
"this to /etc/services
\n
"
,
debugstr_a
(
aq
->
serv_name
)
,
aq
->
serv_proto
?
debugstr_a
(
aq
->
serv_proto
)
:
"*"
);
else
MESSAGE
(
"service on port %d protocol %s not found; You might want to add "
"this to /etc/services
\n
"
,
aq
->
serv_port
,
aq
->
serv_proto
?
debugstr_a
(
aq
->
serv_proto
)
:
"*"
);
fail
=
WSANO_DATA
;
}
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
}
break
;
}
...
...
dlls/winsock/socket.c
View file @
ff7a61f8
...
...
@@ -92,6 +92,9 @@
DEFAULT_DEBUG_CHANNEL
(
winsock
);
/* critical section to protect some non-rentrant net function */
extern
CRITICAL_SECTION
csWSgetXXXbyYYY
;
#define DEBUG_SOCKADDR 0
#define dump_sockaddr(a) \
DPRINTF("sockaddr_in: family %d, address %s, port %d\n", \
...
...
@@ -166,7 +169,7 @@ int WSAIOCTL_GetInterfaceCount(void);
int
WSAIOCTL_GetInterfaceName
(
int
intNumber
,
char
*
intName
);
UINT16
wsaErrno
(
void
);
UINT16
wsaHerrno
(
void
);
UINT16
wsaHerrno
(
int
errnr
);
static
HANDLE
_WSHeap
=
0
;
...
...
@@ -2297,20 +2300,46 @@ static char* NULL_STRING = "NULL";
*/
static
WIN_hostent
*
__ws_gethostbyaddr
(
const
char
*
addr
,
int
len
,
int
type
,
int
dup_flag
)
{
WIN_hostent
*
retval
=
NULL
;
LPWSINFO
pwsi
=
WINSOCK_GetIData
();
if
(
pwsi
)
{
struct
hostent
*
host
;
if
(
(
host
=
gethostbyaddr
(
addr
,
len
,
type
))
!=
NULL
)
#if HAVE_LINUX_GETHOSTBYNAME_R_6
char
*
extrabuf
;
int
ebufsize
=
1024
;
struct
hostent
hostentry
;
int
locerr
=
ENOBUFS
;
host
=
NULL
;
extrabuf
=
HeapAlloc
(
GetProcessHeap
(),
0
,
ebufsize
)
;
while
(
extrabuf
)
{
int
res
=
gethostbyaddr_r
(
addr
,
len
,
type
,
&
hostentry
,
extrabuf
,
ebufsize
,
&
host
,
&
locerr
);
if
(
res
!=
ERANGE
)
break
;
ebufsize
*=
2
;
extrabuf
=
HeapReAlloc
(
GetProcessHeap
(),
0
,
extrabuf
,
ebufsize
)
;
}
if
(
!
host
)
SetLastError
((
locerr
<
0
)
?
wsaErrno
()
:
wsaHerrno
(
locerr
));
#else
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
host
=
gethostbyaddr
(
addr
,
len
,
type
);
if
(
!
host
)
SetLastError
((
h_errno
<
0
)
?
wsaErrno
()
:
wsaHerrno
(
h_errno
));
#endif
if
(
host
!=
NULL
)
{
if
(
WS_dup_he
(
pwsi
,
host
,
dup_flag
)
)
ret
urn
(
WIN_hostent
*
)(
pwsi
->
he
);
ret
val
=
(
WIN_hostent
*
)(
pwsi
->
he
);
else
SetLastError
(
WSAENOBUFS
);
else
SetLastError
((
h_errno
<
0
)
?
wsaErrno
()
:
wsaHerrno
());
}
#ifdef HAVE_LINUX_GETHOSTBYNAME_R_6
HeapFree
(
GetProcessHeap
(),
0
,
extrabuf
);
#else
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
#endif
}
return
NULL
;
return
retval
;
}
SEGPTR
WINAPI
WINSOCK_gethostbyaddr16
(
const
char
*
addr
,
INT16
len
,
INT16
type
)
...
...
@@ -2335,18 +2364,44 @@ WIN_hostent* WINAPI WSOCK32_gethostbyaddr(const char *addr, INT len,
*/
static
WIN_hostent
*
__ws_gethostbyname
(
const
char
*
name
,
int
dup_flag
)
{
WIN_hostent
*
retval
=
NULL
;
LPWSINFO
pwsi
=
WINSOCK_GetIData
();
if
(
pwsi
)
{
struct
hostent
*
host
;
if
(
(
host
=
gethostbyname
(
name
))
!=
NULL
)
#ifdef HAVE_LINUX_GETHOSTBYNAME_R_6
char
*
extrabuf
;
int
ebufsize
=
1024
;
struct
hostent
hostentry
;
int
locerr
=
ENOBUFS
;
host
=
NULL
;
extrabuf
=
HeapAlloc
(
GetProcessHeap
(),
0
,
ebufsize
)
;
while
(
extrabuf
)
{
int
res
=
gethostbyname_r
(
name
,
&
hostentry
,
extrabuf
,
ebufsize
,
&
host
,
&
locerr
);
if
(
res
!=
ERANGE
)
break
;
ebufsize
*=
2
;
extrabuf
=
HeapReAlloc
(
GetProcessHeap
(),
0
,
extrabuf
,
ebufsize
)
;
}
if
(
!
host
)
SetLastError
((
locerr
<
0
)
?
wsaErrno
()
:
wsaHerrno
(
locerr
));
#else
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
host
=
gethostbyname
(
name
);
if
(
!
host
)
SetLastError
((
h_errno
<
0
)
?
wsaErrno
()
:
wsaHerrno
(
h_errno
));
#endif
if
(
host
!=
NULL
)
{
if
(
WS_dup_he
(
pwsi
,
host
,
dup_flag
)
)
ret
urn
(
WIN_hostent
*
)(
pwsi
->
he
);
ret
val
=
(
WIN_hostent
*
)(
pwsi
->
he
);
else
SetLastError
(
WSAENOBUFS
);
else
SetLastError
((
h_errno
<
0
)
?
wsaErrno
()
:
wsaHerrno
());
}
#ifdef HAVE_LINUX_GETHOSTBYNAME_R_6
HeapFree
(
GetProcessHeap
(),
0
,
extrabuf
);
#else
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
#endif
}
return
NULL
;
return
retval
;
}
SEGPTR
WINAPI
WINSOCK_gethostbyname16
(
const
char
*
name
)
...
...
@@ -2369,22 +2424,27 @@ WIN_hostent* WINAPI WSOCK32_gethostbyname(const char* name)
*/
static
WIN_protoent
*
__ws_getprotobyname
(
const
char
*
name
,
int
dup_flag
)
{
WIN_protoent
*
retval
=
NULL
;
LPWSINFO
pwsi
=
WINSOCK_GetIData
();
if
(
pwsi
)
{
struct
protoent
*
proto
;
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
if
(
(
proto
=
getprotobyname
(
name
))
!=
NULL
)
{
if
(
WS_dup_pe
(
pwsi
,
proto
,
dup_flag
)
)
ret
urn
(
WIN_protoent
*
)(
pwsi
->
pe
);
ret
val
=
(
WIN_protoent
*
)(
pwsi
->
pe
);
else
SetLastError
(
WSAENOBUFS
);
}
else
{
MESSAGE
(
"protocol %s not found; You might want to add "
"this to /etc/protocols
\n
"
,
debugstr_a
(
name
)
);
SetLastError
(
WSANO_DATA
);
}
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
}
else
SetLastError
(
WSANOTINITIALISED
);
return
NULL
;
return
retval
;
}
SEGPTR
WINAPI
WINSOCK_getprotobyname16
(
const
char
*
name
)
...
...
@@ -2407,22 +2467,27 @@ WIN_protoent* WINAPI WSOCK32_getprotobyname(const char* name)
*/
static
WIN_protoent
*
__ws_getprotobynumber
(
int
number
,
int
dup_flag
)
{
WIN_protoent
*
retval
=
NULL
;
LPWSINFO
pwsi
=
WINSOCK_GetIData
();
if
(
pwsi
)
{
struct
protoent
*
proto
;
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
if
(
(
proto
=
getprotobynumber
(
number
))
!=
NULL
)
{
if
(
WS_dup_pe
(
pwsi
,
proto
,
dup_flag
)
)
ret
urn
(
WIN_protoent
*
)(
pwsi
->
pe
);
ret
val
=
(
WIN_protoent
*
)(
pwsi
->
pe
);
else
SetLastError
(
WSAENOBUFS
);
}
else
{
MESSAGE
(
"protocol number %d not found; You might want to add "
"this to /etc/protocols
\n
"
,
number
);
SetLastError
(
WSANO_DATA
);
}
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
}
else
SetLastError
(
WSANOTINITIALISED
);
return
NULL
;
return
retval
;
}
SEGPTR
WINAPI
WINSOCK_getprotobynumber16
(
INT16
number
)
...
...
@@ -2445,6 +2510,7 @@ WIN_protoent* WINAPI WSOCK32_getprotobynumber(INT number)
*/
static
WIN_servent
*
__ws_getservbyname
(
const
char
*
name
,
const
char
*
proto
,
int
dup_flag
)
{
WIN_servent
*
retval
=
NULL
;
LPWSINFO
pwsi
=
WINSOCK_GetIData
();
if
(
pwsi
)
...
...
@@ -2453,22 +2519,26 @@ static WIN_servent* __ws_getservbyname(const char *name, const char *proto, int
int
i
=
wsi_strtolo
(
pwsi
,
name
,
proto
);
if
(
i
)
{
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
serv
=
getservbyname
(
pwsi
->
buffer
,
proto
?
(
pwsi
->
buffer
+
i
)
:
NULL
);
if
(
serv
!=
NULL
)
{
if
(
WS_dup_se
(
pwsi
,
serv
,
dup_flag
)
)
ret
urn
(
WIN_servent
*
)(
pwsi
->
se
);
ret
val
=
(
WIN_servent
*
)(
pwsi
->
se
);
else
SetLastError
(
WSAENOBUFS
);
}
else
{
MESSAGE
(
"service %s protocol %s not found; You might want to add "
"this to /etc/services
\n
"
,
debugstr_a
(
pwsi
->
buffer
),
proto
?
debugstr_a
(
pwsi
->
buffer
+
i
)
:
"*"
);
SetLastError
(
WSANO_DATA
);
}
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
}
else
SetLastError
(
WSAENOBUFS
);
}
else
SetLastError
(
WSANOTINITIALISED
);
return
NULL
;
return
retval
;
}
SEGPTR
WINAPI
WINSOCK_getservbyname16
(
const
char
*
name
,
const
char
*
proto
)
...
...
@@ -2493,15 +2563,17 @@ WIN_servent* WINAPI WSOCK32_getservbyname(const char *name, const char *proto)
*/
static
WIN_servent
*
__ws_getservbyport
(
int
port
,
const
char
*
proto
,
int
dup_flag
)
{
WIN_servent
*
retval
=
NULL
;
LPWSINFO
pwsi
=
WINSOCK_GetIData
();
if
(
pwsi
)
{
struct
servent
*
serv
;
if
(
!
proto
||
wsi_strtolo
(
pwsi
,
proto
,
NULL
))
{
EnterCriticalSection
(
&
csWSgetXXXbyYYY
);
if
(
(
serv
=
getservbyport
(
port
,
(
proto
)
?
pwsi
->
buffer
:
NULL
))
!=
NULL
)
{
if
(
WS_dup_se
(
pwsi
,
serv
,
dup_flag
)
)
ret
urn
(
WIN_servent
*
)(
pwsi
->
se
);
ret
val
=
(
WIN_servent
*
)(
pwsi
->
se
);
else
SetLastError
(
WSAENOBUFS
);
}
else
{
...
...
@@ -2510,10 +2582,11 @@ static WIN_servent* __ws_getservbyport(int port, const char* proto, int dup_flag
proto
?
debugstr_a
(
pwsi
->
buffer
)
:
"*"
);
SetLastError
(
WSANO_DATA
);
}
LeaveCriticalSection
(
&
csWSgetXXXbyYYY
);
}
else
SetLastError
(
WSAENOBUFS
);
}
else
SetLastError
(
WSANOTINITIALISED
);
return
NULL
;
return
retval
;
}
SEGPTR
WINAPI
WINSOCK_getservbyport16
(
INT16
port
,
const
char
*
proto
)
...
...
@@ -3231,9 +3304,8 @@ UINT16 wsaErrno(void)
}
}
UINT16
wsaHerrno
(
void
)
UINT16
wsaHerrno
(
int
loc_errno
)
{
int
loc_errno
=
h_errno
;
WARN
(
"h_errno %d.
\n
"
,
loc_errno
);
...
...
@@ -3243,6 +3315,7 @@ UINT16 wsaHerrno(void)
case
TRY_AGAIN
:
return
WSATRY_AGAIN
;
case
NO_RECOVERY
:
return
WSANO_RECOVERY
;
case
NO_DATA
:
return
WSANO_DATA
;
case
ENOBUFS
:
return
WSAENOBUFS
;
case
0
:
return
0
;
default:
...
...
include/acconfig.h
View file @
ff7a61f8
...
...
@@ -116,3 +116,6 @@
/* Define if the X libraries support XVideo */
#undef HAVE_XVIDEO
/* Define if Linux-style gethostbyname_r and gethostbyaddr_r are available */
#undef HAVE_LINUX_GETHOSTBYNAME_R_6
include/config.h.in
View file @
ff7a61f8
...
...
@@ -152,6 +152,9 @@
/* Define if the X libraries support XVideo */
#undef HAVE_XVIDEO
/* Define if Linux-style gethostbyname_r and gethostbyaddr_r are available */
#undef HAVE_LINUX_GETHOSTBYNAME_R_6
/* The number of bytes in a long long. */
#undef SIZEOF_LONG_LONG
...
...
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