xref: /freebsd/share/man/man4/crypto.4 (revision ad30f8e79bd1007cc2476e491bd21b4f5e389e0a)
1.\"	$OpenBSD: crypto.4,v 1.4 2002/09/12 07:15:03 deraadt Exp $
2.\"
3.\" Copyright (c) 2001 Theo de Raadt
4.\" All rights reserved.
5.\"
6.\" Redistribution and use in source and binary forms, with or without
7.\" modification, are permitted provided that the following conditions
8.\" are met:
9.\" 1. Redistributions of source code must retain the above copyright
10.\"    notice, this list of conditions and the following disclaimer.
11.\" 2. Redistributions in binary form must reproduce the above copyright
12.\"    notice, this list of conditions and the following disclaimer in the
13.\"    documentation and/or other materials provided with the distribution.
14.\" 3. The name of the author may not be used to endorse or promote products
15.\"    derived from this software without specific prior written permission.
16.\"
17.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19.\" WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20.\" DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
21.\" INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22.\" (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
23.\" SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
25.\" STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26.\" ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27.\" POSSIBILITY OF SUCH DAMAGE.
28.\"
29.\" $FreeBSD$
30.\"
31.Dd September 7, 2010
32.Dt CRYPTO 4
33.Os
34.Sh NAME
35.Nm crypto ,
36.Nm cryptodev
37.Nd hardware crypto access driver
38.Sh SYNOPSIS
39.Cd device crypto
40.Cd device cryptodev
41.Sh DESCRIPTION
42The
43.Nm
44driver provides a device-independent framework to support
45cryptographic operations in the kernel.
46The
47.Nm cryptodev
48driver provides userland applications access to this support
49through the
50.Pa /dev/crypto
51device.
52This node primarily operates in an
53.Xr ioctl 2
54based model, permitting a variety of applications to query device capabilities,
55submit transactions, and get results.
56.Pp
57If
58.Ar count
59given in the specification, and is greater than 0, a maximum of one
60.Nm
61device is created.
62.Pp
63The following
64.Xr ioctl 2
65calls apply only to the
66.Nm
67devices:
68.Bl -tag -width ".Dv CIOCGSESSION"
69.It Dv CIOCGSESSION
70Setup a new crypto session for a new type of operation.
71.It Dv CIOCFSESSION
72Free a previously established session.
73.It Dv CIOCCRYPT
74Perform a crypto operation against a previously setup session.
75.El
76.Sh FEATURES
77Depending on hardware being present, the following symmetric and
78asymmetric cryptographic features are potentially available from
79.Pa /dev/crypto :
80.Pp
81.Bl -tag -width ".Dv CRYPTO_RIPEMD160_HMAC" -offset indent -compact
82.It Dv CRYPTO_DES_CBC
83.It Dv CRYPTO_3DES_CBC
84.It Dv CRYPTO_BLF_CBC
85.It Dv CRYPTO_CAMELLIA_CBC
86.It Dv CRYPTO_CAST_CBC
87.It Dv CRYPTO_SKIPJACK_CBC
88.It Dv CRYPTO_MD5_HMAC
89.It Dv CRYPTO_SHA1_HMAC
90.It Dv CRYPTO_RIPEMD160_HMAC
91.It Dv CRYPTO_MD5_KPDK
92.It Dv CRYPTO_SHA1_KPDK
93.It Dv CRYPTO_AES_CBC
94.It Dv CRYPTO_ARC4
95.It Dv CRYPTO_MD5
96.It Dv CRYPTO_SHA1
97.It Dv CRK_MOD_EXP
98.It Dv CRK_MOD_EXP_CRT
99.It Dv CRK_DSA_SIGN
100.It Dv CRK_DSA_VERIFY
101.It Dv CRK_DH_COMPUTE_KEY
102.El
103.Sh FILES
104.Bl -tag -width ".Pa /dev/crypto" -compact
105.It Pa /dev/crypto
106crypto access device
107.El
108.Sh SEE ALSO
109.Xr aesni 4 ,
110.Xr glxsb 4 ,
111.Xr hifn 4 ,
112.Xr ipsec 4 ,
113.Xr padlock 4 ,
114.Xr safe 4 ,
115.Xr ubsec 4 ,
116.Xr geli 8 ,
117.Xr crypto 9
118.Sh HISTORY
119The
120.Nm
121driver first appeared in
122.Ox 3.0 .
123The
124.Nm
125driver was imported to
126.Fx 5.0 .
127