xref: /freebsd/lib/libipsec/ipsec_strerror.c (revision 9a4365d0e0833374e893c519639bde71756aa104)
19a4365d0SYoshinobu Inoue /*
29a4365d0SYoshinobu Inoue  * Copyright (C) 1995, 1996, 1997, 1998, and 1999 WIDE Project.
39a4365d0SYoshinobu Inoue  * All rights reserved.
49a4365d0SYoshinobu Inoue  *
59a4365d0SYoshinobu Inoue  * Redistribution and use in source and binary forms, with or without
69a4365d0SYoshinobu Inoue  * modification, are permitted provided that the following conditions
79a4365d0SYoshinobu Inoue  * are met:
89a4365d0SYoshinobu Inoue  * 1. Redistributions of source code must retain the above copyright
99a4365d0SYoshinobu Inoue  *    notice, this list of conditions and the following disclaimer.
109a4365d0SYoshinobu Inoue  * 2. Redistributions in binary form must reproduce the above copyright
119a4365d0SYoshinobu Inoue  *    notice, this list of conditions and the following disclaimer in the
129a4365d0SYoshinobu Inoue  *    documentation and/or other materials provided with the distribution.
139a4365d0SYoshinobu Inoue  * 3. Neither the name of the project nor the names of its contributors
149a4365d0SYoshinobu Inoue  *    may be used to endorse or promote products derived from this software
159a4365d0SYoshinobu Inoue  *    without specific prior written permission.
169a4365d0SYoshinobu Inoue  *
179a4365d0SYoshinobu Inoue  * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
189a4365d0SYoshinobu Inoue  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
199a4365d0SYoshinobu Inoue  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
209a4365d0SYoshinobu Inoue  * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
219a4365d0SYoshinobu Inoue  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
229a4365d0SYoshinobu Inoue  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
239a4365d0SYoshinobu Inoue  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
249a4365d0SYoshinobu Inoue  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
259a4365d0SYoshinobu Inoue  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
269a4365d0SYoshinobu Inoue  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
279a4365d0SYoshinobu Inoue  * SUCH DAMAGE.
289a4365d0SYoshinobu Inoue  *
299a4365d0SYoshinobu Inoue  * $FreeBSD$
309a4365d0SYoshinobu Inoue  */
319a4365d0SYoshinobu Inoue 
329a4365d0SYoshinobu Inoue #include <sys/types.h>
339a4365d0SYoshinobu Inoue #include <sys/param.h>
349a4365d0SYoshinobu Inoue 
359a4365d0SYoshinobu Inoue #include <string.h>
369a4365d0SYoshinobu Inoue #include <netinet6/ipsec.h>
379a4365d0SYoshinobu Inoue 
389a4365d0SYoshinobu Inoue #include "ipsec_strerror.h"
399a4365d0SYoshinobu Inoue 
409a4365d0SYoshinobu Inoue int ipsec_errcode;
419a4365d0SYoshinobu Inoue 
429a4365d0SYoshinobu Inoue static char *ipsec_errlist[] = {
439a4365d0SYoshinobu Inoue "Success",					/*EIPSEC_NO_ERROR*/
449a4365d0SYoshinobu Inoue "Not supported",				/*EIPSEC_NOT_SUPPORTED*/
459a4365d0SYoshinobu Inoue "Invalid argument",				/*EIPSEC_INVAL_ARGUMENT*/
469a4365d0SYoshinobu Inoue "Invalid sadb message",				/*EIPSEC_INVAL_SADBMSG*/
479a4365d0SYoshinobu Inoue "Invalid version",				/*EIPSEC_INVAL_VERSION*/
489a4365d0SYoshinobu Inoue "Invalid security policy",			/*EIPSEC_INVAL_POLICY*/
499a4365d0SYoshinobu Inoue "Invalid address specification",		/*EIPSEC_INVAL_ADDRESS*/
509a4365d0SYoshinobu Inoue "Invalid ipsec protocol",			/*EIPSEC_INVAL_PROTO*/
519a4365d0SYoshinobu Inoue "Invalid ipsec mode",				/*EIPSEC_INVAL_MODE*/
529a4365d0SYoshinobu Inoue "Invalid ipsec level",				/*EIPSEC_INVAL_LEVEL*/
539a4365d0SYoshinobu Inoue "Invalid SA type",				/*EIPSEC_INVAL_SATYPE*/
549a4365d0SYoshinobu Inoue "Invalid message type",				/*EIPSEC_INVAL_MSGTYPE*/
559a4365d0SYoshinobu Inoue "Invalid extension type",			/*EIPSEC_INVAL_EXTTYPE*/
569a4365d0SYoshinobu Inoue "Invalid algorithm type",			/*EIPSEC_INVAL_ALGS*/
579a4365d0SYoshinobu Inoue "Invalid key length",				/*EIPSEC_INVAL_KEYLEN*/
589a4365d0SYoshinobu Inoue "Invalid address family",			/*EIPSEC_INVAL_FAMILY*/
599a4365d0SYoshinobu Inoue "Invalid prefix length",			/*EIPSEC_INVAL_PREFIXLEN*/
609a4365d0SYoshinobu Inoue "Invalid direciton",				/*EIPSEC_INVAL_DIR*/
619a4365d0SYoshinobu Inoue "SPI range violation",				/*EIPSEC_INVAL_SPI*/
629a4365d0SYoshinobu Inoue "No protocol specified",			/*EIPSEC_NO_PROTO*/
639a4365d0SYoshinobu Inoue "No algorithm specified",			/*EIPSEC_NO_ALGS*/
649a4365d0SYoshinobu Inoue "No buffers available",				/*EIPSEC_NO_BUFS*/
659a4365d0SYoshinobu Inoue "Must get supported algorithms list first",	/*EIPSEC_DO_GET_SUPP_LIST*/
669a4365d0SYoshinobu Inoue "Protocol mismatch",				/*EIPSEC_PROTO_MISMATCH*/
679a4365d0SYoshinobu Inoue "Family mismatch",				/*EIPSEC_FAMILY_MISMATCH*/
689a4365d0SYoshinobu Inoue "Too few arguments",				/*EIPSEC_FEW_ARGUMENTS*/
699a4365d0SYoshinobu Inoue NULL,						/*EIPSEC_SYSTEM_ERROR*/
709a4365d0SYoshinobu Inoue "Unknown error",				/*EIPSEC_MAX*/
719a4365d0SYoshinobu Inoue };
729a4365d0SYoshinobu Inoue 
739a4365d0SYoshinobu Inoue char *ipsec_strerror(void)
749a4365d0SYoshinobu Inoue {
759a4365d0SYoshinobu Inoue 	if (ipsec_errcode < 0 || ipsec_errcode > EIPSEC_MAX)
769a4365d0SYoshinobu Inoue 		ipsec_errcode = EIPSEC_MAX;
779a4365d0SYoshinobu Inoue 
789a4365d0SYoshinobu Inoue 	return ipsec_errlist[ipsec_errcode];
799a4365d0SYoshinobu Inoue }
809a4365d0SYoshinobu Inoue 
819a4365d0SYoshinobu Inoue void ipsec_set_strerror(char *str)
829a4365d0SYoshinobu Inoue {
839a4365d0SYoshinobu Inoue 	ipsec_errcode = EIPSEC_SYSTEM_ERROR;
849a4365d0SYoshinobu Inoue 	ipsec_errlist[EIPSEC_SYSTEM_ERROR] = str;
859a4365d0SYoshinobu Inoue 
869a4365d0SYoshinobu Inoue 	return;
879a4365d0SYoshinobu Inoue }
88