aboutsummaryrefslogtreecommitdiffstats
path: root/crypto/algif_skcipher.c
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2010-10-19 21:23:00 +0800
committerHerbert Xu <herbert@gondor.apana.org.au>2010-11-19 17:47:58 +0800
commitfe869cdb89c95d060c77eea20204d6c91f233b53 (patch)
treefb665d1f162e8bdf978d264ca24d8a07d7380316 /crypto/algif_skcipher.c
parentcrypto: af_alg - User-space interface for Crypto API (diff)
downloadlinux-dev-fe869cdb89c95d060c77eea20204d6c91f233b53.tar.xz
linux-dev-fe869cdb89c95d060c77eea20204d6c91f233b53.zip
crypto: algif_hash - User-space interface for hash operations
This patch adds the af_alg plugin for hash, corresponding to the ahash kernel operation type. Keys can optionally be set through the setsockopt interface. Each sendmsg call will finalise the hash unless sent with a MSG_MORE flag. Partial hash states can be cloned using accept(2). The interface is completely synchronous, all operations will complete prior to the system call returning. Both sendmsg(2) and splice(2) support reading the user-space data directly without copying (except that the Crypto API itself may copy the data if alignment is off). For now only the splice(2) interface supports performing digest instead of init/update/final. In future the sendmsg(2) interface will also be modified to use digest/finup where possible so that hardware that cannot return a partial hash state can still benefit from this interface. Thakns to Miloslav Trmac for reviewing this and contributing fixes and improvements. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Acked-by: David S. Miller <davem@davemloft.net> Tested-by: Martin Willi <martin@strongswan.org>
Diffstat (limited to 'crypto/algif_skcipher.c')
0 files changed, 0 insertions, 0 deletions