Merge from vendor branch TEXINFO:
[dragonfly.git] / sys / opencrypto / crypto_if.m
1 #
2 # Copyright (c) 2002, Sam Leffler
3 # All rights reserved.
4 #
5 # Redistribution and use in source and binary forms, with or without
6 # modification, are permitted provided that the following conditions
7 # are met:
8 # 1. Redistributions of source code must retain the above copyright
9 #    notice, this list of conditions and the following disclaimer.
10 # 2. Redistributions in binary form must reproduce the above copyright
11 #    notice, this list of conditions and the following disclaimer in the
12 #    documentation and/or other materials provided with the distribution.
13 # 3. All advertising materials mentioning features or use of this software
14 #    must display the following acknowledgement:
15 #    This product includes software developed by Boris Popov.
16 # 4. Neither the name of the author nor the names of any co-contributors
17 #    may be used to endorse or promote products derived from this software
18 #    without specific prior written permission.
19 #
20 # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 # ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
24 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 # SUCH DAMAGE.
31 #
32 # $FreeBSD: src/sys/opencrypto/crypto_if.m,v 1.1.2.1 2002/11/21 23:34:23 sam Exp $
33 # $DragonFly: src/sys/opencrypto/crypto_if.m,v 1.2 2003/06/17 04:28:54 dillon Exp $
34 #
35
36 #include <crypto/cryptodev.h>
37
38 INTERFACE crypto;
39
40 METHOD int32_t get_driverid {
41         u_int32_t       flags;
42 };
43
44 # XXX define typedefs to work around inadequate parser
45 HEADER {
46         typedef int crypto_newsession_cb(void*, u_int32_t*, struct cryptoini*);
47         typedef int crypto_freesession_cb(void*, u_int64_t*);
48         typedef int crypto_process_cb(void*, struct cryptop*);
49         typedef int crypto_kprocess_cb(void*, struct cryptkop*);
50 };
51
52 METHOD int register {
53         u_int32_t       driverid;
54         int             alg;
55         u_int16_t       maxoplen;
56         u_int32_t       flags;
57         crypto_newsession_cb* newses;
58         crypto_freesession_cb* freeses;
59         crypto_process_cb* process;
60         void            *arg;
61 };
62
63 METHOD int kregister {
64         u_int32_t       driverid;
65         int             kalg;
66         u_int32_t       flags;
67         crypto_kprocess_cb* kprocess;
68         void            *arg;
69 };
70
71 METHOD int unregister {
72         u_int32_t       driverid;
73         int             alg;
74 };
75
76 METHOD int unregister_all {
77         u_int32_t       driverid;
78 };
79
80 METHOD int newsession {
81         u_int64_t       *sid;
82         struct cryptoini *cri;
83         int             hard;
84 };
85
86 METHOD int freesession {
87         u_int64_t       sid;
88 };
89
90 METHOD int dispatch {
91         struct cryptop  *crp;
92 };
93
94 METHOD int kdispatch {
95         struct cryptkop *krp;
96 };
97
98 METHOD int crypto_unblock {
99         u_int32_t       driverid;
100         int             what;
101 };
102
103 METHOD int invoke {
104         struct cryptop  *crp;
105 };
106
107 METHOD int kinvoke {
108         struct cryptkop *krp;
109 };
110
111 METHOD struct cryptop * getreq {
112         int     num;
113 };
114
115 METHOD void freereq {
116         struct cryptop  *crp;
117 };
118
119 METHOD void done {
120         struct cryptop  *crp;
121 };
122
123 METHOD void kdone {
124         struct cryptkop *krp;
125 };
126
127 METHOD int getfeat {
128         int             *featp;
129 };