|
@@ -220,6 +220,26 @@ static int ccp_aes_cmac_digest(struct ahash_request *req)
|
|
|
return ccp_aes_cmac_finup(req);
|
|
|
}
|
|
|
|
|
|
+static int ccp_aes_cmac_export(struct ahash_request *req, void *out)
|
|
|
+{
|
|
|
+ struct ccp_aes_cmac_req_ctx *rctx = ahash_request_ctx(req);
|
|
|
+ struct ccp_aes_cmac_req_ctx *state = out;
|
|
|
+
|
|
|
+ *state = *rctx;
|
|
|
+
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+static int ccp_aes_cmac_import(struct ahash_request *req, const void *in)
|
|
|
+{
|
|
|
+ struct ccp_aes_cmac_req_ctx *rctx = ahash_request_ctx(req);
|
|
|
+ const struct ccp_aes_cmac_req_ctx *state = in;
|
|
|
+
|
|
|
+ *rctx = *state;
|
|
|
+
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
static int ccp_aes_cmac_setkey(struct crypto_ahash *tfm, const u8 *key,
|
|
|
unsigned int key_len)
|
|
|
{
|
|
@@ -352,10 +372,13 @@ int ccp_register_aes_cmac_algs(struct list_head *head)
|
|
|
alg->final = ccp_aes_cmac_final;
|
|
|
alg->finup = ccp_aes_cmac_finup;
|
|
|
alg->digest = ccp_aes_cmac_digest;
|
|
|
+ alg->export = ccp_aes_cmac_export;
|
|
|
+ alg->import = ccp_aes_cmac_import;
|
|
|
alg->setkey = ccp_aes_cmac_setkey;
|
|
|
|
|
|
halg = &alg->halg;
|
|
|
halg->digestsize = AES_BLOCK_SIZE;
|
|
|
+ halg->statesize = sizeof(struct ccp_aes_cmac_req_ctx);
|
|
|
|
|
|
base = &halg->base;
|
|
|
snprintf(base->cra_name, CRYPTO_MAX_ALG_NAME, "cmac(aes)");
|