crypto/mem_clr.c: switch to OPENSSL_cleanse implementation from master.
authorAndy Polyakov <appro@openssl.org>
Thu, 9 Jun 2016 19:56:09 +0000 (21:56 +0200)
committerAndy Polyakov <appro@openssl.org>
Sun, 12 Jun 2016 11:47:57 +0000 (13:47 +0200)
It's probably worth reminding that this is a fall-back implementation
for platforms that don't have assembly OPENSSL_cleanse.

Reviewed-by: Rich Salz <rsalz@openssl.org>
crypto/mem_clr.c

index ab85344eef386b8df6331151473126d8220ecd35..579e9d18251d51b5a4b026fcde08267b913d95e0 100644 (file)
 #include <string.h>
 #include <openssl/crypto.h>
 
-unsigned char cleanse_ctr = 0;
+/*
+ * Pointer to memset is volatile so that compiler must de-reference
+ * the pointer and can't assume that it points to any function in
+ * particular (such as memset, which it then might further "optimize")
+ */
+typedef void *(*memset_t)(void *,int,size_t);
+
+static volatile memset_t memset_func = memset;
 
 void OPENSSL_cleanse(void *ptr, size_t len)
 {
-    unsigned char *p = ptr;
-    size_t loop = len, ctr = cleanse_ctr;
-
-    if (ptr == NULL)
-        return;
-
-    while (loop--) {
-        *(p++) = (unsigned char)ctr;
-        ctr += (17 + ((size_t)p & 0xF));
-    }
-    p = memchr(ptr, (unsigned char)ctr, len);
-    if (p)
-        ctr += (63 + (size_t)p);
-    cleanse_ctr = (unsigned char)ctr;
+    memset_func(ptr, 0, len);
 }