1 /* @(#)clnt_perror.c 2.1 88/07/29 4.0 RPCSRC */
3 * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
4 * unrestricted use provided that this legend is included on all tape
5 * media and as a part of the software program in whole or part. Users
6 * may copy or modify Sun RPC without charge, but are not authorized
7 * to license or distribute it to anyone else except as part of a product or
8 * program developed by the user.
10 * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
11 * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
12 * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
14 * Sun RPC is provided with no support and without any obligation on the
15 * part of Sun Microsystems, Inc. to assist in its use, correction,
16 * modification or enhancement.
18 * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
19 * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
20 * OR ANY PART THEREOF.
22 * In no event will Sun Microsystems, Inc. be liable for any lost revenue
23 * or profits or other special, indirect and consequential damages, even if
24 * Sun has been advised of the possibility of such damages.
26 * Sun Microsystems, Inc.
28 * Mountain View, California 94043
30 #if !defined(lint) && defined(SCCSIDS)
31 static char sccsid
[] = "@(#)clnt_perror.c 1.15 87/10/07 Copyr 1984 Sun Micro";
37 * Copyright (C) 1984, Sun Microsystems, Inc.
47 # include <libio/iolibio.h>
48 # define fputs(s, f) INTUSE(_IO_fputs) (s, f)
51 static char *auth_errmsg (enum auth_stat stat
) internal_function
;
53 #ifdef _RPC_THREAD_SAFE_
55 * Making buf a preprocessor macro requires renaming the local
56 * buf variable in a few functions. Overriding a global variable
57 * with a local variable of the same name is a bad idea, anyway.
59 #define buf ((char *)RPC_THREAD_VARIABLE(clnt_perr_buf_s))
68 buf
= (char *) malloc (256);
73 * Print reply error info
76 clnt_sperror (CLIENT
* rpch
, const char *msg
)
87 CLNT_GETERR (rpch
, &e
);
89 len
= sprintf (str
, "%s: ", msg
);
92 str
= stpcpy (str
, clnt_sperrno (e
.re_status
));
97 case RPC_CANTENCODEARGS
:
98 case RPC_CANTDECODERES
:
100 case RPC_PROGUNAVAIL
:
101 case RPC_PROCUNAVAIL
:
102 case RPC_CANTDECODEARGS
:
103 case RPC_SYSTEMERROR
:
104 case RPC_UNKNOWNHOST
:
105 case RPC_UNKNOWNPROTO
:
106 case RPC_PMAPFAILURE
:
107 case RPC_PROGNOTREGISTERED
:
113 len
= sprintf (str
, "; errno = %s", __strerror_r (e
.re_errno
,
114 chrbuf
, sizeof chrbuf
));
118 case RPC_VERSMISMATCH
:
119 len
= sprintf (str
, _("; low version = %lu, high version = %lu"),
120 e
.re_vers
.low
, e
.re_vers
.high
);
125 err
= auth_errmsg (e
.re_why
);
126 str
= stpcpy (str
, _ ("; why = "));
129 str
= stpcpy (str
, err
);
133 len
= sprintf (str
, _("(unknown authentication error - %d)"),
139 case RPC_PROGVERSMISMATCH
:
140 len
= sprintf (str
, _("; low version = %lu, high version = %lu"),
141 e
.re_vers
.low
, e
.re_vers
.high
);
145 default: /* unknown */
146 len
= sprintf (str
, "; s1 = %lu, s2 = %lu", e
.re_lb
.s1
, e
.re_lb
.s2
);
156 clnt_perror (CLIENT
* rpch
, const char *msg
)
159 if (_IO_fwide (stderr
, 0) > 0)
160 (void) __fwprintf (stderr
, L
"%s", clnt_sperror (rpch
, msg
));
163 (void) fputs (clnt_sperror (rpch
, msg
), stderr
);
169 enum clnt_stat status
;
170 unsigned int message_off
;
173 static const char rpc_errstr
[] =
175 #define RPC_SUCCESS_IDX 0
178 #define RPC_CANTENCODEARGS_IDX (RPC_SUCCESS_IDX + sizeof "RPC: Success")
179 N_("RPC: Can't encode arguments")
181 #define RPC_CANTDECODERES_IDX (RPC_CANTENCODEARGS_IDX \
182 + sizeof "RPC: Can't encode arguments")
183 N_("RPC: Can't decode result")
185 #define RPC_CANTSEND_IDX (RPC_CANTDECODERES_IDX \
186 + sizeof "RPC: Can't decode result")
187 N_("RPC: Unable to send")
189 #define RPC_CANTRECV_IDX (RPC_CANTSEND_IDX \
190 + sizeof "RPC: Unable to send")
191 N_("RPC: Unable to receive")
193 #define RPC_TIMEDOUT_IDX (RPC_CANTRECV_IDX \
194 + sizeof "RPC: Unable to receive")
197 #define RPC_VERSMISMATCH_IDX (RPC_TIMEDOUT_IDX \
198 + sizeof "RPC: Timed out")
199 N_("RPC: Incompatible versions of RPC")
201 #define RPC_AUTHERROR_IDX (RPC_VERSMISMATCH_IDX \
202 + sizeof "RPC: Incompatible versions of RPC")
203 N_("RPC: Authentication error")
205 #define RPC_PROGUNAVAIL_IDX (RPC_AUTHERROR_IDX \
206 + sizeof "RPC: Authentication error")
207 N_("RPC: Program unavailable")
209 #define RPC_PROGVERSMISMATCH_IDX (RPC_PROGUNAVAIL_IDX \
210 + sizeof "RPC: Program unavailable")
211 N_("RPC: Program/version mismatch")
213 #define RPC_PROCUNAVAIL_IDX (RPC_PROGVERSMISMATCH_IDX \
214 + sizeof "RPC: Program/version mismatch")
215 N_("RPC: Procedure unavailable")
217 #define RPC_CANTDECODEARGS_IDX (RPC_PROCUNAVAIL_IDX \
218 + sizeof "RPC: Procedure unavailable")
219 N_("RPC: Server can't decode arguments")
221 #define RPC_SYSTEMERROR_IDX (RPC_CANTDECODEARGS_IDX \
222 + sizeof "RPC: Server can't decode arguments")
223 N_("RPC: Remote system error")
225 #define RPC_UNKNOWNHOST_IDX (RPC_SYSTEMERROR_IDX \
226 + sizeof "RPC: Remote system error")
227 N_("RPC: Unknown host")
229 #define RPC_UNKNOWNPROTO_IDX (RPC_UNKNOWNHOST_IDX \
230 + sizeof "RPC: Unknown host")
231 N_("RPC: Unknown protocol")
233 #define RPC_PMAPFAILURE_IDX (RPC_UNKNOWNPROTO_IDX \
234 + sizeof "RPC: Unknown protocol")
235 N_("RPC: Port mapper failure")
237 #define RPC_PROGNOTREGISTERED_IDX (RPC_PMAPFAILURE_IDX \
238 + sizeof "RPC: Port mapper failure")
239 N_("RPC: Program not registered")
241 #define RPC_FAILED_IDX (RPC_PROGNOTREGISTERED_IDX \
242 + sizeof "RPC: Program not registered")
243 N_("RPC: Failed (unspecified error)")
246 static const struct rpc_errtab rpc_errlist
[] =
248 { RPC_SUCCESS
, RPC_SUCCESS_IDX
},
249 { RPC_CANTENCODEARGS
, RPC_CANTENCODEARGS_IDX
},
250 { RPC_CANTDECODERES
, RPC_CANTDECODERES_IDX
},
251 { RPC_CANTSEND
, RPC_CANTSEND_IDX
},
252 { RPC_CANTRECV
, RPC_CANTRECV_IDX
},
253 { RPC_TIMEDOUT
, RPC_TIMEDOUT_IDX
},
254 { RPC_VERSMISMATCH
, RPC_VERSMISMATCH_IDX
},
255 { RPC_AUTHERROR
, RPC_AUTHERROR_IDX
},
256 { RPC_PROGUNAVAIL
, RPC_PROGUNAVAIL_IDX
},
257 { RPC_PROGVERSMISMATCH
, RPC_PROGVERSMISMATCH_IDX
},
258 { RPC_PROCUNAVAIL
, RPC_PROCUNAVAIL_IDX
},
259 { RPC_CANTDECODEARGS
, RPC_CANTDECODEARGS_IDX
},
260 { RPC_SYSTEMERROR
, RPC_SYSTEMERROR_IDX
},
261 { RPC_UNKNOWNHOST
, RPC_UNKNOWNHOST_IDX
},
262 { RPC_UNKNOWNPROTO
, RPC_UNKNOWNPROTO_IDX
},
263 { RPC_PMAPFAILURE
, RPC_PMAPFAILURE_IDX
},
264 { RPC_PROGNOTREGISTERED
, RPC_PROGNOTREGISTERED_IDX
},
265 { RPC_FAILED
, RPC_FAILED_IDX
}
270 * This interface for use by clntrpc
273 clnt_sperrno (enum clnt_stat stat
)
277 for (i
= 0; i
< sizeof (rpc_errlist
) / sizeof (struct rpc_errtab
); i
++)
279 if (rpc_errlist
[i
].status
== stat
)
281 return _(rpc_errstr
+ rpc_errlist
[i
].message_off
);
284 return _("RPC: (unknown error code)");
288 clnt_perrno (enum clnt_stat num
)
291 if (_IO_fwide (stderr
, 0) > 0)
292 (void) __fwprintf (stderr
, L
"%s", clnt_sperrno (num
));
295 (void) fputs (clnt_sperrno (num
), stderr
);
300 clnt_spcreateerror (const char *msg
)
306 struct rpc_createerr
*ce
;
310 ce
= &get_rpc_createerr ();
311 len
= sprintf (str
, "%s: ", msg
);
313 cp
= stpcpy (cp
, clnt_sperrno (ce
->cf_stat
));
316 case RPC_PMAPFAILURE
:
317 cp
= stpcpy (stpcpy (cp
, " - "),
318 clnt_sperrno (ce
->cf_error
.re_status
));
321 case RPC_SYSTEMERROR
:
322 cp
= stpcpy (stpcpy (cp
, " - "),
323 __strerror_r (ce
->cf_error
.re_errno
,
324 chrbuf
, sizeof chrbuf
));
335 clnt_pcreateerror (const char *msg
)
338 if (_IO_fwide (stderr
, 0) > 0)
339 (void) __fwprintf (stderr
, L
"%s", clnt_spcreateerror (msg
));
342 (void) fputs (clnt_spcreateerror (msg
), stderr
);
347 enum auth_stat status
;
348 unsigned int message_off
;
351 static const char auth_errstr
[] =
353 #define AUTH_OK_IDX 0
354 N_("Authentication OK")
356 #define AUTH_BADCRED_IDX (AUTH_OK_IDX + sizeof "Authentication OK")
357 N_("Invalid client credential")
359 #define AUTH_REJECTEDCRED_IDX (AUTH_BADCRED_IDX \
360 + sizeof "Invalid client credential")
361 N_("Server rejected credential")
363 #define AUTH_BADVERF_IDX (AUTH_REJECTEDCRED_IDX \
364 + sizeof "Server rejected credential")
365 N_("Invalid client verifier")
367 #define AUTH_REJECTEDVERF_IDX (AUTH_BADVERF_IDX \
368 + sizeof "Invalid client verifier")
369 N_("Server rejected verifier")
371 #define AUTH_TOOWEAK_IDX (AUTH_REJECTEDVERF_IDX \
372 + sizeof "Server rejected verifier")
373 N_("Client credential too weak")
375 #define AUTH_INVALIDRESP_IDX (AUTH_TOOWEAK_IDX \
376 + sizeof "Client credential too weak")
377 N_("Invalid server verifier")
379 #define AUTH_FAILED_IDX (AUTH_INVALIDRESP_IDX \
380 + sizeof "Invalid server verifier")
381 N_("Failed (unspecified error)")
384 static const struct auth_errtab auth_errlist
[] =
386 { AUTH_OK
, AUTH_OK_IDX
},
387 { AUTH_BADCRED
, AUTH_BADCRED_IDX
},
388 { AUTH_REJECTEDCRED
, AUTH_REJECTEDCRED_IDX
},
389 { AUTH_BADVERF
, AUTH_BADVERF_IDX
},
390 { AUTH_REJECTEDVERF
, AUTH_REJECTEDVERF_IDX
},
391 { AUTH_TOOWEAK
, AUTH_TOOWEAK_IDX
},
392 { AUTH_INVALIDRESP
, AUTH_INVALIDRESP_IDX
},
393 { AUTH_FAILED
, AUTH_FAILED_IDX
}
398 auth_errmsg (enum auth_stat stat
)
402 for (i
= 0; i
< sizeof (auth_errlist
) / sizeof (struct auth_errtab
); i
++)
404 if (auth_errlist
[i
].status
== stat
)
406 return _(auth_errstr
+ auth_errlist
[i
].message_off
);
413 static void __attribute__ ((unused
))
418 text_set_element (__libc_subfreeres
, free_mem
);