compl_auth_verify() compared the generated and received MAC with
memcmp(), which returns early on the first differing byte and leaks
the number of matching leading bytes through timing.

Use rte_memeq_timingsafe() for the verify comparison.

Bugzilla ID: 1773
Fixes: 786963fdcf3e ("crypto/cnxk: add digest support")
Cc: [email protected]

Signed-off-by: Stephen Hemminger <[email protected]>
Acked-by: Tejasree Kondoj <[email protected]>
---
 drivers/crypto/cnxk/cnxk_ae.h | 4 +++-
 drivers/crypto/cnxk/cnxk_se.h | 2 +-
 2 files changed, 4 insertions(+), 2 deletions(-)

diff --git a/drivers/crypto/cnxk/cnxk_ae.h b/drivers/crypto/cnxk/cnxk_ae.h
index 691f9bfce5..f2aa5d5a2e 100644
--- a/drivers/crypto/cnxk/cnxk_ae.h
+++ b/drivers/crypto/cnxk/cnxk_ae.h
@@ -8,6 +8,7 @@
 #include <rte_common.h>
 #include <rte_crypto_asym.h>
 #include <rte_malloc.h>
+#include <rte_memory.h>
 
 #include "roc_ae.h"
 #include "roc_re.h"
@@ -1921,7 +1922,8 @@ cnxk_ae_dequeue_rsa_op(struct rte_crypto_op *cop, uint8_t 
*rptr,
                         * Offset output data pointer by length field
                         * (2 bytes) and compare signed data.
                         */
-                       if (memcmp(rptr + 2, rsa->message.data, 
rsa->message.length))
+                       if (!rte_memeq_timingsafe(rptr + 2,
+                                                 rsa->message.data, 
rsa->message.length))
                                cop->status = RTE_CRYPTO_OP_STATUS_ERROR;
                }
                break;
diff --git a/drivers/crypto/cnxk/cnxk_se.h b/drivers/crypto/cnxk/cnxk_se.h
index 09d9d1e0e3..3ed32f7ddd 100644
--- a/drivers/crypto/cnxk/cnxk_se.h
+++ b/drivers/crypto/cnxk/cnxk_se.h
@@ -3362,7 +3362,7 @@ compl_auth_verify(struct rte_crypto_op *op, uint8_t 
*gen_mac, uint64_t mac_len)
                return;
        }
 
-       if (memcmp(mac, gen_mac, mac_len))
+       if (!rte_memeq_timingsafe(mac, gen_mac, mac_len))
                op->status = RTE_CRYPTO_OP_STATUS_AUTH_FAILED;
        else
                op->status = RTE_CRYPTO_OP_STATUS_SUCCESS;
-- 
2.53.0

Reply via email to