X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=security%2Fintegrity%2Fevm%2Fevm_crypto.c;h=3b9f5a080e4f69b937b2c782f67142541811fba9;hb=88d7ed35085184f15a2af3d9e88d775059b2f307;hp=847a2d7dff17e62711bf9efd32f5e3cae834ea8a;hpb=fe0e94c5a7e5335ba0d200e7d3e26e9f80cda4b1;p=profile%2Fivi%2Fkernel-x86-ivi.git diff --git a/security/integrity/evm/evm_crypto.c b/security/integrity/evm/evm_crypto.c index 847a2d7..3b9f5a0 100644 --- a/security/integrity/evm/evm_crypto.c +++ b/security/integrity/evm/evm_crypto.c @@ -52,6 +52,14 @@ static struct shash_desc *init_desc(const char type) *tfm = NULL; return ERR_PTR(rc); } + if (type == EVM_XATTR_HMAC) { + rc = crypto_shash_setkey(*tfm, evmkey, evmkey_len); + if (rc) { + crypto_free_shash(*tfm); + *tfm = NULL; + return ERR_PTR(rc); + } + } } desc = kmalloc(sizeof(*desc) + crypto_shash_descsize(*tfm), @@ -62,14 +70,7 @@ static struct shash_desc *init_desc(const char type) desc->tfm = *tfm; desc->flags = CRYPTO_TFM_REQ_MAY_SLEEP; - if (type == EVM_XATTR_HMAC) { - rc = crypto_shash_setkey(*tfm, evmkey, evmkey_len); - if (rc) - goto out; - } - rc = crypto_shash_init(desc); -out: if (rc) { kfree(desc); return ERR_PTR(rc);