diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-15 13:42:15 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-15 13:42:15 -0400 |
commit | cb906953d2c3fd450655d9fa833f03690ad50c23 (patch) | |
tree | 06c5665afb24baee3ac49f62db61ca97918079b4 /include/linux | |
parent | 6c373ca89399c5a3f7ef210ad8f63dc3437da345 (diff) | |
parent | 3abafaf2192b1712079edfd4232b19877d6f41a5 (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6
Pull crypto update from Herbert Xu:
"Here is the crypto update for 4.1:
New interfaces:
- user-space interface for AEAD
- user-space interface for RNG (i.e., pseudo RNG)
New hashes:
- ARMv8 SHA1/256
- ARMv8 AES
- ARMv8 GHASH
- ARM assembler and NEON SHA256
- MIPS OCTEON SHA1/256/512
- MIPS img-hash SHA1/256 and MD5
- Power 8 VMX AES/CBC/CTR/GHASH
- PPC assembler AES, SHA1/256 and MD5
- Broadcom IPROC RNG driver
Cleanups/fixes:
- prevent internal helper algos from being exposed to user-space
- merge common code from assembly/C SHA implementations
- misc fixes"
* git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6: (169 commits)
crypto: arm - workaround for building with old binutils
crypto: arm/sha256 - avoid sha256 code on ARMv7-M
crypto: x86/sha512_ssse3 - move SHA-384/512 SSSE3 implementation to base layer
crypto: x86/sha256_ssse3 - move SHA-224/256 SSSE3 implementation to base layer
crypto: x86/sha1_ssse3 - move SHA-1 SSSE3 implementation to base layer
crypto: arm64/sha2-ce - move SHA-224/256 ARMv8 implementation to base layer
crypto: arm64/sha1-ce - move SHA-1 ARMv8 implementation to base layer
crypto: arm/sha2-ce - move SHA-224/256 ARMv8 implementation to base layer
crypto: arm/sha256 - move SHA-224/256 ASM/NEON implementation to base layer
crypto: arm/sha1-ce - move SHA-1 ARMv8 implementation to base layer
crypto: arm/sha1_neon - move SHA-1 NEON implementation to base layer
crypto: arm/sha1 - move SHA-1 ARM asm implementation to base layer
crypto: sha512-generic - move to generic glue implementation
crypto: sha256-generic - move to generic glue implementation
crypto: sha1-generic - move to generic glue implementation
crypto: sha512 - implement base layer for SHA-512
crypto: sha256 - implement base layer for SHA-256
crypto: sha1 - implement base layer for SHA-1
crypto: api - remove instance when test failed
crypto: api - Move alg ref count init to crypto_check_alg
...
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/crypto.h | 6 | ||||
-rw-r--r-- | include/linux/hw_random.h | 4 |
2 files changed, 10 insertions, 0 deletions
diff --git a/include/linux/crypto.h b/include/linux/crypto.h index fb5ef16d6a12..10df5d2d093a 100644 --- a/include/linux/crypto.h +++ b/include/linux/crypto.h | |||
@@ -95,6 +95,12 @@ | |||
95 | #define CRYPTO_ALG_KERN_DRIVER_ONLY 0x00001000 | 95 | #define CRYPTO_ALG_KERN_DRIVER_ONLY 0x00001000 |
96 | 96 | ||
97 | /* | 97 | /* |
98 | * Mark a cipher as a service implementation only usable by another | ||
99 | * cipher and never by a normal user of the kernel crypto API | ||
100 | */ | ||
101 | #define CRYPTO_ALG_INTERNAL 0x00002000 | ||
102 | |||
103 | /* | ||
98 | * Transform masks and values (for crt_flags). | 104 | * Transform masks and values (for crt_flags). |
99 | */ | 105 | */ |
100 | #define CRYPTO_TFM_REQ_MASK 0x000fff00 | 106 | #define CRYPTO_TFM_REQ_MASK 0x000fff00 |
diff --git a/include/linux/hw_random.h b/include/linux/hw_random.h index eb7b414d232b..4f7d8f4b1e9a 100644 --- a/include/linux/hw_random.h +++ b/include/linux/hw_random.h | |||
@@ -50,10 +50,14 @@ struct hwrng { | |||
50 | struct completion cleanup_done; | 50 | struct completion cleanup_done; |
51 | }; | 51 | }; |
52 | 52 | ||
53 | struct device; | ||
54 | |||
53 | /** Register a new Hardware Random Number Generator driver. */ | 55 | /** Register a new Hardware Random Number Generator driver. */ |
54 | extern int hwrng_register(struct hwrng *rng); | 56 | extern int hwrng_register(struct hwrng *rng); |
57 | extern int devm_hwrng_register(struct device *dev, struct hwrng *rng); | ||
55 | /** Unregister a Hardware Random Number Generator driver. */ | 58 | /** Unregister a Hardware Random Number Generator driver. */ |
56 | extern void hwrng_unregister(struct hwrng *rng); | 59 | extern void hwrng_unregister(struct hwrng *rng); |
60 | extern void devm_hwrng_unregister(struct device *dve, struct hwrng *rng); | ||
57 | /** Feed random bits into the pool. */ | 61 | /** Feed random bits into the pool. */ |
58 | extern void add_hwgenerator_randomness(const char *buffer, size_t count, size_t entropy); | 62 | extern void add_hwgenerator_randomness(const char *buffer, size_t count, size_t entropy); |
59 | 63 | ||