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>
50 static char *auth_errmsg (enum auth_stat stat
) internal_function
;
52 #ifdef _RPC_THREAD_SAFE_
54 * Making buf a preprocessor macro requires renaming the local
55 * buf variable in a few functions. Overriding a global variable
56 * with a local variable of the same name is a bad idea, anyway.
58 #define buf RPC_THREAD_VARIABLE(clnt_perr_buf_s)
67 buf
= (char *) malloc (256);
72 * Print reply error info
75 clnt_sperror (CLIENT
* rpch
, const char *msg
)
86 CLNT_GETERR (rpch
, &e
);
88 len
= sprintf (str
, "%s: ", msg
);
91 str
= stpcpy (str
, clnt_sperrno (e
.re_status
));
96 case RPC_CANTENCODEARGS
:
97 case RPC_CANTDECODERES
:
100 case RPC_PROCUNAVAIL
:
101 case RPC_CANTDECODEARGS
:
102 case RPC_SYSTEMERROR
:
103 case RPC_UNKNOWNHOST
:
104 case RPC_UNKNOWNPROTO
:
105 case RPC_PMAPFAILURE
:
106 case RPC_PROGNOTREGISTERED
:
112 len
= sprintf (str
, "; errno = %s", __strerror_r (e
.re_errno
,
113 chrbuf
, sizeof chrbuf
));
117 case RPC_VERSMISMATCH
:
118 len
= sprintf (str
, _("; low version = %lu, high version = %lu"),
119 e
.re_vers
.low
, e
.re_vers
.high
);
124 err
= auth_errmsg (e
.re_why
);
125 str
= stpcpy (str
, _ ("; why = "));
128 str
= stpcpy (str
, err
);
132 len
= sprintf (str
, _("(unknown authentication error - %d)"),
138 case RPC_PROGVERSMISMATCH
:
139 len
= sprintf (str
, _("; low version = %lu, high version = %lu"),
140 e
.re_vers
.low
, e
.re_vers
.high
);
144 default: /* unknown */
145 len
= sprintf (str
, "; s1 = %lu, s2 = %lu", e
.re_lb
.s1
, e
.re_lb
.s2
);
153 libc_hidden_def (clnt_sperror
)
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
);
165 libc_hidden_def (clnt_perror
)
170 enum clnt_stat status
;
171 unsigned int message_off
;
174 static const char rpc_errstr
[] =
176 #define RPC_SUCCESS_IDX 0
179 #define RPC_CANTENCODEARGS_IDX (RPC_SUCCESS_IDX + sizeof "RPC: Success")
180 N_("RPC: Can't encode arguments")
182 #define RPC_CANTDECODERES_IDX (RPC_CANTENCODEARGS_IDX \
183 + sizeof "RPC: Can't encode arguments")
184 N_("RPC: Can't decode result")
186 #define RPC_CANTSEND_IDX (RPC_CANTDECODERES_IDX \
187 + sizeof "RPC: Can't decode result")
188 N_("RPC: Unable to send")
190 #define RPC_CANTRECV_IDX (RPC_CANTSEND_IDX \
191 + sizeof "RPC: Unable to send")
192 N_("RPC: Unable to receive")
194 #define RPC_TIMEDOUT_IDX (RPC_CANTRECV_IDX \
195 + sizeof "RPC: Unable to receive")
198 #define RPC_VERSMISMATCH_IDX (RPC_TIMEDOUT_IDX \
199 + sizeof "RPC: Timed out")
200 N_("RPC: Incompatible versions of RPC")
202 #define RPC_AUTHERROR_IDX (RPC_VERSMISMATCH_IDX \
203 + sizeof "RPC: Incompatible versions of RPC")
204 N_("RPC: Authentication error")
206 #define RPC_PROGUNAVAIL_IDX (RPC_AUTHERROR_IDX \
207 + sizeof "RPC: Authentication error")
208 N_("RPC: Program unavailable")
210 #define RPC_PROGVERSMISMATCH_IDX (RPC_PROGUNAVAIL_IDX \
211 + sizeof "RPC: Program unavailable")
212 N_("RPC: Program/version mismatch")
214 #define RPC_PROCUNAVAIL_IDX (RPC_PROGVERSMISMATCH_IDX \
215 + sizeof "RPC: Program/version mismatch")
216 N_("RPC: Procedure unavailable")
218 #define RPC_CANTDECODEARGS_IDX (RPC_PROCUNAVAIL_IDX \
219 + sizeof "RPC: Procedure unavailable")
220 N_("RPC: Server can't decode arguments")
222 #define RPC_SYSTEMERROR_IDX (RPC_CANTDECODEARGS_IDX \
223 + sizeof "RPC: Server can't decode arguments")
224 N_("RPC: Remote system error")
226 #define RPC_UNKNOWNHOST_IDX (RPC_SYSTEMERROR_IDX \
227 + sizeof "RPC: Remote system error")
228 N_("RPC: Unknown host")
230 #define RPC_UNKNOWNPROTO_IDX (RPC_UNKNOWNHOST_IDX \
231 + sizeof "RPC: Unknown host")
232 N_("RPC: Unknown protocol")
234 #define RPC_PMAPFAILURE_IDX (RPC_UNKNOWNPROTO_IDX \
235 + sizeof "RPC: Unknown protocol")
236 N_("RPC: Port mapper failure")
238 #define RPC_PROGNOTREGISTERED_IDX (RPC_PMAPFAILURE_IDX \
239 + sizeof "RPC: Port mapper failure")
240 N_("RPC: Program not registered")
242 #define RPC_FAILED_IDX (RPC_PROGNOTREGISTERED_IDX \
243 + sizeof "RPC: Program not registered")
244 N_("RPC: Failed (unspecified error)")
247 static const struct rpc_errtab rpc_errlist
[] =
249 { RPC_SUCCESS
, RPC_SUCCESS_IDX
},
250 { RPC_CANTENCODEARGS
, RPC_CANTENCODEARGS_IDX
},
251 { RPC_CANTDECODERES
, RPC_CANTDECODERES_IDX
},
252 { RPC_CANTSEND
, RPC_CANTSEND_IDX
},
253 { RPC_CANTRECV
, RPC_CANTRECV_IDX
},
254 { RPC_TIMEDOUT
, RPC_TIMEDOUT_IDX
},
255 { RPC_VERSMISMATCH
, RPC_VERSMISMATCH_IDX
},
256 { RPC_AUTHERROR
, RPC_AUTHERROR_IDX
},
257 { RPC_PROGUNAVAIL
, RPC_PROGUNAVAIL_IDX
},
258 { RPC_PROGVERSMISMATCH
, RPC_PROGVERSMISMATCH_IDX
},
259 { RPC_PROCUNAVAIL
, RPC_PROCUNAVAIL_IDX
},
260 { RPC_CANTDECODEARGS
, RPC_CANTDECODEARGS_IDX
},
261 { RPC_SYSTEMERROR
, RPC_SYSTEMERROR_IDX
},
262 { RPC_UNKNOWNHOST
, RPC_UNKNOWNHOST_IDX
},
263 { RPC_UNKNOWNPROTO
, RPC_UNKNOWNPROTO_IDX
},
264 { RPC_PMAPFAILURE
, RPC_PMAPFAILURE_IDX
},
265 { RPC_PROGNOTREGISTERED
, RPC_PROGNOTREGISTERED_IDX
},
266 { RPC_FAILED
, RPC_FAILED_IDX
}
271 * This interface for use by clntrpc
274 clnt_sperrno (enum clnt_stat stat
)
278 for (i
= 0; i
< sizeof (rpc_errlist
) / sizeof (struct rpc_errtab
); i
++)
280 if (rpc_errlist
[i
].status
== stat
)
282 return _(rpc_errstr
+ rpc_errlist
[i
].message_off
);
285 return _("RPC: (unknown error code)");
287 libc_hidden_def (clnt_sperrno
)
290 clnt_perrno (enum clnt_stat num
)
293 if (_IO_fwide (stderr
, 0) > 0)
294 (void) __fwprintf (stderr
, L
"%s", clnt_sperrno (num
));
297 (void) fputs (clnt_sperrno (num
), stderr
);
302 clnt_spcreateerror (const char *msg
)
308 struct rpc_createerr
*ce
;
312 ce
= &get_rpc_createerr ();
313 len
= sprintf (str
, "%s: ", msg
);
315 cp
= stpcpy (cp
, clnt_sperrno (ce
->cf_stat
));
318 case RPC_PMAPFAILURE
:
319 cp
= stpcpy (stpcpy (cp
, " - "),
320 clnt_sperrno (ce
->cf_error
.re_status
));
323 case RPC_SYSTEMERROR
:
324 cp
= stpcpy (stpcpy (cp
, " - "),
325 __strerror_r (ce
->cf_error
.re_errno
,
326 chrbuf
, sizeof chrbuf
));
335 libc_hidden_def (clnt_spcreateerror
)
338 clnt_pcreateerror (const char *msg
)
341 if (_IO_fwide (stderr
, 0) > 0)
342 (void) __fwprintf (stderr
, L
"%s", clnt_spcreateerror (msg
));
345 (void) fputs (clnt_spcreateerror (msg
), stderr
);
350 enum auth_stat status
;
351 unsigned int message_off
;
354 static const char auth_errstr
[] =
356 #define AUTH_OK_IDX 0
357 N_("Authentication OK")
359 #define AUTH_BADCRED_IDX (AUTH_OK_IDX + sizeof "Authentication OK")
360 N_("Invalid client credential")
362 #define AUTH_REJECTEDCRED_IDX (AUTH_BADCRED_IDX \
363 + sizeof "Invalid client credential")
364 N_("Server rejected credential")
366 #define AUTH_BADVERF_IDX (AUTH_REJECTEDCRED_IDX \
367 + sizeof "Server rejected credential")
368 N_("Invalid client verifier")
370 #define AUTH_REJECTEDVERF_IDX (AUTH_BADVERF_IDX \
371 + sizeof "Invalid client verifier")
372 N_("Server rejected verifier")
374 #define AUTH_TOOWEAK_IDX (AUTH_REJECTEDVERF_IDX \
375 + sizeof "Server rejected verifier")
376 N_("Client credential too weak")
378 #define AUTH_INVALIDRESP_IDX (AUTH_TOOWEAK_IDX \
379 + sizeof "Client credential too weak")
380 N_("Invalid server verifier")
382 #define AUTH_FAILED_IDX (AUTH_INVALIDRESP_IDX \
383 + sizeof "Invalid server verifier")
384 N_("Failed (unspecified error)")
387 static const struct auth_errtab auth_errlist
[] =
389 { AUTH_OK
, AUTH_OK_IDX
},
390 { AUTH_BADCRED
, AUTH_BADCRED_IDX
},
391 { AUTH_REJECTEDCRED
, AUTH_REJECTEDCRED_IDX
},
392 { AUTH_BADVERF
, AUTH_BADVERF_IDX
},
393 { AUTH_REJECTEDVERF
, AUTH_REJECTEDVERF_IDX
},
394 { AUTH_TOOWEAK
, AUTH_TOOWEAK_IDX
},
395 { AUTH_INVALIDRESP
, AUTH_INVALIDRESP_IDX
},
396 { AUTH_FAILED
, AUTH_FAILED_IDX
}
401 auth_errmsg (enum auth_stat stat
)
405 for (i
= 0; i
< sizeof (auth_errlist
) / sizeof (struct auth_errtab
); i
++)
407 if (auth_errlist
[i
].status
== stat
)
409 return _(auth_errstr
+ auth_errlist
[i
].message_off
);
416 libc_freeres_fn (free_mem
)
418 /* Not libc_freeres_ptr, since buf is a macro. */