4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
22 * Copyright (c) 1990, 2010, Oracle and/or its affiliates. All rights reserved.
25 /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
26 /* All Rights Reserved */
29 * University Copyright- Copyright (c) 1982, 1986, 1988
30 * The Regents of the University of California
33 * University Acknowledgment- Portions of this document are derived from
34 * software developed by the University of California, Berkeley, and its
38 #include <sys/types.h>
39 #include <sys/socket.h>
40 #include <sys/stropts.h>
41 #include <sys/stream.h>
42 #include <sys/socketvar.h>
47 extern int _so_socket();
48 extern int _s_netconfig_path();
49 extern int _setsockopt();
51 int _socket_create(int, int, int, int);
53 #pragma weak socket = _socket
56 _socket(int family
, int type
, int protocol
)
58 return (_socket_create(family
, type
, protocol
, SOV_DEFAULT
));
62 * Used by the BCP library.
65 _socket_bsd(int family
, int type
, int protocol
)
67 return (_socket_create(family
, type
, protocol
, SOV_SOCKBSD
));
71 _socket_svr4(int family
, int type
, int protocol
)
73 return (_socket_create(family
, type
, protocol
, SOV_SOCKSTREAM
));
77 __xnet_socket(int family
, int type
, int protocol
)
79 return (_socket_create(family
, type
, protocol
, SOV_XPG4_2
));
83 * Create a socket endpoint for socket() and socketpair().
84 * In SunOS 4.X and in SunOS 5.X prior to XPG 4.2 the only error
85 * that could be returned due to invalid <family, type, protocol>
86 * was EPROTONOSUPPORT. (While the SunOS 4.X source contains EPROTOTYPE
87 * error as well that error can only be generated if the kernel is
88 * incorrectly configured.)
89 * For backwards compatibility only applications that request XPG 4.2
90 * (through c89 or XOPEN_SOURCE) will get EPROTOTYPE or EAFNOSUPPORT errors.
93 _socket_create(int family
, int type
, int protocol
, int version
)
98 * Try creating without knowing the device assuming that
99 * the transport provider is registered in /etc/sock2path.d.
100 * If none found fall back to using /etc/netconfig to look
101 * up the name of the transport device name. This provides
102 * backwards compatibility for transport providers that have not
103 * yet been converted to using /etc/sock2path.d.
104 * XXX When all transport providers use /etc/sock2path.d. this
105 * part of the code can be removed.
107 fd
= _so_socket(family
, type
, protocol
, NULL
, version
);
110 int saved_errno
= errno
;
113 switch (saved_errno
) {
116 if (version
!= SOV_XPG4_2
)
117 saved_errno
= EPROTONOSUPPORT
;
119 case EPROTONOSUPPORT
:
126 if (_s_netconfig_path(family
, type
, protocol
,
127 &devpath
, &prototype
) == -1) {
131 fd
= _so_socket(family
, type
, protocol
, devpath
, version
);
137 if (prototype
!= 0) {
138 if (_setsockopt(fd
, SOL_SOCKET
, SO_PROTOTYPE
,
139 (caddr_t
)&prototype
, (int)sizeof (prototype
)) < 0) {
142 * setsockopt often fails with ENOPROTOOPT
143 * but socket() should fail with
146 errno
= EPROTONOSUPPORT
;