diff options
author | Michael Brown <mcb30@etherboot.org> | 2007-01-30 14:55:17 +0000 |
---|---|---|
committer | Michael Brown <mcb30@etherboot.org> | 2007-01-30 14:55:17 +0000 |
commit | db2fde474e4b67482251b3cae5e0068d46af4ab5 (patch) | |
tree | 9e2d2e23241302c1d819b8019c49b311759d85e9 /src/include/gpxe/crypto.h | |
parent | 2f7eac16467abd7f5a354ceea42af8502c0d5f21 (diff) | |
download | ipxe-db2fde474e4b67482251b3cae5e0068d46af4ab5.tar.gz |
Generalise digest_algorithm to crypto_algorithm.
Diffstat (limited to 'src/include/gpxe/crypto.h')
-rw-r--r-- | src/include/gpxe/crypto.h | 90 |
1 files changed, 65 insertions, 25 deletions
diff --git a/src/include/gpxe/crypto.h b/src/include/gpxe/crypto.h index 023a00228..9023c354b 100644 --- a/src/include/gpxe/crypto.h +++ b/src/include/gpxe/crypto.h @@ -9,38 +9,78 @@ #include <stdint.h> -/** - * A message-digest algorithm - * - */ -struct digest_algorithm { +/** A cryptographic algorithm */ +struct crypto_algorithm { /** Algorithm name */ const char *name; - /** Size of a context for this algorithm */ - size_t context_len; - /** Size of a message digest for this algorithm */ - size_t digest_len; - /** - * Initialise digest algorithm - * - * @v context Context for digest operations + /** Context size */ + size_t ctxsize; + /** Block size */ + size_t blocksize; + /** Final output size */ + size_t digestsize; + /** Initialise algorithm + * + * @v ctx Context */ - void ( * init ) ( void *context ); - /** - * Calculate digest over data buffer + void ( * init ) ( void *ctx ); + /** Set key * - * @v context Context for digest operations - * @v data Data buffer - * @v len Length of data buffer + * @v ctx Context + * @v key Key + * @v keylen Key length + * @ret rc Return status code */ - void ( * update ) ( void *context, const void *data, size_t len ); - /** - * Finish calculating digest + int ( * setkey ) ( void *ctx, void *key, size_t keylen ); + /** Encode data + * + * @v ctx Context + * @v src Data to encode + * @v dst Encoded data, or NULL + * @v len Length of data + * @ret rc Return status code * - * @v context Context for digest operations - * @v digest Buffer for message digest + * For a cipher algorithm, the enciphered data should be + * placed in @c dst. For a digest algorithm, only the digest + * state should be updated, and @c dst will be NULL. + * + * @v len is guaranteed to be a multiple of @c blocksize. */ - void ( * finish ) ( void *context, void *digest ); + void ( * encode ) ( void *ctx, const void *src, void *dst, + size_t len ); + /** Decode data + * + * @v ctx Context + * @v src Data to decode + * @v dst Decoded data + * @v len Length of data + * @ret rc Return status code + * + * @v len is guaranteed to be a multiple of @c blocksize. + */ + void ( * decode ) ( void *ctx, const void *src, void *dst, + size_t len ); + /** Finalise algorithm + * + * @v ctx Context + * @v out Algorithm final output + */ + void ( * final ) ( void *ctx, void *out ); }; +static inline void digest_init ( struct crypto_algorithm *crypto, + void *ctx ) { + crypto->init ( ctx ); +} + +static inline void digest_update ( struct crypto_algorithm *crypto, + void *ctx, const void *data, size_t len ) { + crypto->encode ( ctx, data, NULL, len ); +} + +static inline void digest_final ( struct crypto_algorithm *crypto, + void *ctx, void *out ) { + crypto->final ( ctx, out ); +} + #endif /* _GPXE_CRYPTO_H */ |