AEAD users RTE_CRYPTO_AEAD_OP_* with aead_op and CIPHER uses RTE_CRYPTO_CIPHER_OP_* with cipher_op in current code.
This commit aligns aead_op and cipher_op operation to fix incorrect AEAD verification. Fixes: df52cb3b6e13 ("app/crypto-perf: move verify as single test type") Signed-off-by: Suanming Mou <suanmi...@nvidia.com> --- app/test-crypto-perf/cperf_test_verify.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/app/test-crypto-perf/cperf_test_verify.c b/app/test-crypto-perf/cperf_test_verify.c index 8aa714b969..525a2b1373 100644 --- a/app/test-crypto-perf/cperf_test_verify.c +++ b/app/test-crypto-perf/cperf_test_verify.c @@ -113,6 +113,7 @@ cperf_verify_op(struct rte_crypto_op *op, uint8_t *data; uint32_t cipher_offset, auth_offset; uint8_t cipher, auth; + bool is_encrypt = false; int res = 0; if (op->status != RTE_CRYPTO_OP_STATUS_SUCCESS) @@ -154,12 +155,14 @@ cperf_verify_op(struct rte_crypto_op *op, cipher_offset = 0; auth = 0; auth_offset = 0; + is_encrypt = options->cipher_op == RTE_CRYPTO_CIPHER_OP_ENCRYPT; break; case CPERF_CIPHER_THEN_AUTH: cipher = 1; cipher_offset = 0; auth = 1; auth_offset = options->test_buffer_size; + is_encrypt = options->cipher_op == RTE_CRYPTO_CIPHER_OP_ENCRYPT; break; case CPERF_AUTH_ONLY: cipher = 0; @@ -172,12 +175,14 @@ cperf_verify_op(struct rte_crypto_op *op, cipher_offset = 0; auth = 1; auth_offset = options->test_buffer_size; + is_encrypt = options->cipher_op == RTE_CRYPTO_CIPHER_OP_ENCRYPT; break; case CPERF_AEAD: cipher = 1; cipher_offset = 0; - auth = 1; + auth = options->aead_op == RTE_CRYPTO_AEAD_OP_ENCRYPT; auth_offset = options->test_buffer_size; + is_encrypt = !!auth; break; default: res = 1; @@ -185,7 +190,7 @@ cperf_verify_op(struct rte_crypto_op *op, } if (cipher == 1) { - if (options->cipher_op == RTE_CRYPTO_CIPHER_OP_ENCRYPT) + if (is_encrypt) res += !!memcmp(data + cipher_offset, vector->ciphertext.data, options->test_buffer_size); -- 2.34.1