4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
24 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
25 * Use is subject to license terms.
28 #pragma ident "%Z%%M% %I% %E% SMI" /* SVr4.0 1.2 */
39 static const char __nsl_dom
[] = "SUNW_OST_NETNSL";
41 static char *_xti_errlist
[] = {
43 "Incorrect address format", /* 1 - TBADADDR */
44 "Incorrect options format", /* 2 - TBADOPT */
45 "Illegal permissions", /* 3 - TACCES */
46 "Illegal file descriptor", /* 4 - TBADF */
47 "Couldn't allocate address", /* 5 - TNOADDR */
48 "Routine will place interface out of state", /* 6 - TOUTSTATE */
49 "Illegal called/calling sequence number", /* 7 - TBADSEQ */
50 "System error", /* 8 - TSYSERR */
51 "An event requires attention", /* 9 - TLOOK */
52 "Illegal amount of data", /* 10 - TBADDATA */
53 "Buffer not large enough", /* 11 - TBUFOVFLW */
54 "Can't send message - (blocked)", /* 12 - TFLOW */
55 "No message currently available", /* 13 - TNODATA */
56 "Disconnect message not found", /* 14 - TNODIS */
57 "Unitdata error message not found", /* 15 - TNOUDERR */
58 "Incorrect flags specified", /* 16 - TBADFLAG */
59 "Orderly release message not found", /* 17 - TNOREL */
60 "Primitive not supported by provider", /* 18 - TNOTSUPPORT */
61 "State is in process of changing", /* 19 - TSTATECHNG */
63 /* Following error codes are new in XTI */
65 "Unsupported structure type requested", /* 20 - TNOSTRUCTYPE */
66 "Invalid transport provider name", /* 21 - TBADNAME */
67 "Listener queue length limit is zero", /* 22 - TBADQLEN */
68 "Transport address is in use", /* 23 - TADDRBUSY */
69 "Outstanding connection indications", /* 24 - TINDOUT */
70 "Listener-acceptor transport provider mismatch",
71 /* 25 - TPROVMISMATCH */
72 "Connection acceptor has listen queue length limit greater than zero",
74 "Connection acceptor-listener address not same but required by transport",
76 "Incoming connection queue is full", /* 28 - TQFULL */
77 "Protocol error on transport primitive", /* 29 - TPROTO */
80 static int _xti_nerr
= A_CNT(_xti_errlist
)-1; /* take off entry t_errno 0 */
83 _tx_strerror(int errnum
, int api_semantics
)
85 static char buf
[BUFSIZ
];
87 if (_T_IS_XTI(api_semantics
)) {
88 if (errnum
<= _xti_nerr
&& errnum
>= 0)
89 return (dgettext(__nsl_dom
, _xti_errlist
[errnum
]));
90 (void) snprintf(buf
, sizeof (buf
), "%d: %s", errnum
,
91 dgettext(__nsl_dom
, "error unknown"));
97 * This code for TLI only. It uses "t_nerr" and "t_errlist"
98 * which are exposed interfaces in the t_error() man page.
99 * XTI uses different array to avoid binary compatibility
100 * issues in using the exposed array. [ XTI t_error() does
101 * not mention the error message list array ]
103 * For the moment we simply index into the t_errlist[] array.
104 * When the array fills (we cannot allow it to expand in size
105 * or binary compatibility will be broken), this code will need
106 * modification. See the comment in _errlst.c.
108 if (errnum
< t_nerr
&& errnum
>= 0)
109 return (dgettext(__nsl_dom
, t_errlist
[errnum
]));
110 (void) snprintf(buf
, sizeof (buf
), "%d: %s", errnum
,
111 dgettext(__nsl_dom
, "error unknown"));