xref: /onnv-gate/usr/src/lib/pkcs11/pkcs11_softtoken/common/softEC.h (revision 5697:324be5104707)
1*5697Smcpowers /*
2*5697Smcpowers  * CDDL HEADER START
3*5697Smcpowers  *
4*5697Smcpowers  * The contents of this file are subject to the terms of the
5*5697Smcpowers  * Common Development and Distribution License (the "License").
6*5697Smcpowers  * You may not use this file except in compliance with the License.
7*5697Smcpowers  *
8*5697Smcpowers  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*5697Smcpowers  * or http://www.opensolaris.org/os/licensing.
10*5697Smcpowers  * See the License for the specific language governing permissions
11*5697Smcpowers  * and limitations under the License.
12*5697Smcpowers  *
13*5697Smcpowers  * When distributing Covered Code, include this CDDL HEADER in each
14*5697Smcpowers  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*5697Smcpowers  * If applicable, add the following below this CDDL HEADER, with the
16*5697Smcpowers  * fields enclosed by brackets "[]" replaced with your own identifying
17*5697Smcpowers  * information: Portions Copyright [yyyy] [name of copyright owner]
18*5697Smcpowers  *
19*5697Smcpowers  * CDDL HEADER END
20*5697Smcpowers  */
21*5697Smcpowers /*
22*5697Smcpowers  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
23*5697Smcpowers  * Use is subject to license terms.
24*5697Smcpowers  */
25*5697Smcpowers 
26*5697Smcpowers #ifndef _SOFTEC_H
27*5697Smcpowers #define	_SOFTEC_H
28*5697Smcpowers 
29*5697Smcpowers #pragma ident	"%Z%%M%	%I%	%E% SMI"
30*5697Smcpowers 
31*5697Smcpowers #ifdef __cplusplus
32*5697Smcpowers extern "C" {
33*5697Smcpowers #endif
34*5697Smcpowers 
35*5697Smcpowers #include <sys/types.h>
36*5697Smcpowers #include <security/pkcs11t.h>
37*5697Smcpowers #include <ecc_impl.h>
38*5697Smcpowers #include "softObject.h"
39*5697Smcpowers #include "softSession.h"
40*5697Smcpowers 
41*5697Smcpowers typedef struct soft_ecc_ctx {
42*5697Smcpowers 	soft_object_t *key;
43*5697Smcpowers 	ECParams ecparams;
44*5697Smcpowers } soft_ecc_ctx_t;
45*5697Smcpowers 
46*5697Smcpowers extern CK_RV soft_get_public_key_attribute(soft_object_t *, CK_ATTRIBUTE_PTR);
47*5697Smcpowers extern CK_RV soft_get_private_key_attribute(soft_object_t *, CK_ATTRIBUTE_PTR);
48*5697Smcpowers extern CK_RV set_extra_attr_to_object(soft_object_t *, CK_ATTRIBUTE_TYPE,
49*5697Smcpowers     CK_ATTRIBUTE_PTR);
50*5697Smcpowers extern CK_RV soft_ec_genkey_pair(soft_object_t *, soft_object_t *);
51*5697Smcpowers extern CK_RV soft_ec_key_derive(soft_object_t *, soft_object_t *, void *,
52*5697Smcpowers     size_t);
53*5697Smcpowers extern CK_RV soft_ecc_sign_verify_init_common(soft_session_t *,
54*5697Smcpowers     CK_MECHANISM_PTR, soft_object_t *, boolean_t);
55*5697Smcpowers extern CK_RV soft_ecc_sign(soft_session_t *, CK_BYTE_PTR, CK_ULONG,
56*5697Smcpowers     CK_BYTE_PTR, CK_ULONG_PTR);
57*5697Smcpowers extern CK_RV soft_ecc_verify(soft_session_t *, CK_BYTE_PTR, CK_ULONG,
58*5697Smcpowers     CK_BYTE_PTR, CK_ULONG);
59*5697Smcpowers extern CK_RV soft_ecc_digest_sign_common(soft_session_t *, CK_BYTE_PTR,
60*5697Smcpowers     CK_ULONG, CK_BYTE_PTR, CK_ULONG_PTR, boolean_t);
61*5697Smcpowers extern CK_RV soft_ecc_digest_verify_common(soft_session_t *, CK_BYTE_PTR,
62*5697Smcpowers     CK_ULONG, CK_BYTE_PTR, CK_ULONG, boolean_t);
63*5697Smcpowers 
64*5697Smcpowers #ifdef	__cplusplus
65*5697Smcpowers }
66*5697Smcpowers #endif
67*5697Smcpowers 
68*5697Smcpowers #endif /* _SOFTEC_H */
69