- djm@cvs.openbsd.org 2013/01/12 11:22:04

[cipher.c]
     improve error message for integrity failure in AES-GCM modes; ok markus@
This commit is contained in:
Damien Miller 2013-01-12 22:41:26 +11:00
parent 1422c0887c
commit c20eb8b8ea
2 changed files with 13 additions and 3 deletions

View File

@ -1,3 +1,9 @@
20130112
- (djm) OpenBSD CVS Sync
- djm@cvs.openbsd.org 2013/01/12 11:22:04
[cipher.c]
improve error message for integrity failure in AES-GCM modes; ok markus@
20130109 20130109
- (djm) OpenBSD CVS Sync - (djm) OpenBSD CVS Sync
- dtucker@cvs.openbsd.org 2012/12/14 05:26:43 - dtucker@cvs.openbsd.org 2012/12/14 05:26:43

View File

@ -1,4 +1,4 @@
/* $OpenBSD: cipher.c,v 1.85 2013/01/08 18:49:04 markus Exp $ */ /* $OpenBSD: cipher.c,v 1.86 2013/01/12 11:22:04 djm Exp $ */
/* /*
* Author: Tatu Ylonen <ylo@cs.hut.fi> * Author: Tatu Ylonen <ylo@cs.hut.fi>
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@ -342,8 +342,12 @@ cipher_crypt(CipherContext *cc, u_char *dest, const u_char *src,
fatal("%s: EVP_Cipher failed", __func__); fatal("%s: EVP_Cipher failed", __func__);
if (authlen) { if (authlen) {
/* compute tag (on encrypt) or verify tag (on decrypt) */ /* compute tag (on encrypt) or verify tag (on decrypt) */
if (EVP_Cipher(&cc->evp, NULL, NULL, 0) < 0) if (EVP_Cipher(&cc->evp, NULL, NULL, 0) < 0) {
fatal("%s: EVP_Cipher(finish) failed", __func__); if (cc->encrypt)
fatal("%s: EVP_Cipher(final) failed", __func__);
else
fatal("Decryption integrity check failed");
}
if (cc->encrypt && if (cc->encrypt &&
!EVP_CIPHER_CTX_ctrl(&cc->evp, EVP_CTRL_GCM_GET_TAG, !EVP_CIPHER_CTX_ctrl(&cc->evp, EVP_CTRL_GCM_GET_TAG,
authlen, dest + aadlen + len)) authlen, dest + aadlen + len))