Skip to content

Commit d926510

Browse files
Merge #1496: msan: notate variable assignments from assembly code
31ba404 msan: notate variable assignments from assembly code (Cory Fields) e7ea32e msan: Add SECP256K1_CHECKMEM_MSAN_DEFINE which applies to memory sanitizer and not valgrind (Cory Fields) Pull request description: msan isn't smart enough to see that these are set without some help. This was pointed out here: #1169 (comment) With this commit, msan output is clean even with x86 asm turned on. ACKs for top commit: real-or-random: utACK 31ba404 hebasto: re-ACK 31ba404. Tree-SHA512: c9c51fe542247e1e0a93f6d0063d119cf777ca8c1b7e9c8e45e168a2020dc503872eb2a78004725de81267a3ce78c923be1f8546fb92a3e95fc7ef034e5ba932
2 parents 0653a25 + 31ba404 commit d926510

File tree

2 files changed

+25
-0
lines changed

2 files changed

+25
-0
lines changed

src/checkmem.h

+7
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,8 @@
3030
* - SECP256K1_CHECKMEM_DEFINE(p, len):
3131
* - marks the len-byte memory pointed to by p as defined data (public data, in the
3232
* context of constant-time checking).
33+
* - SECP256K1_CHECKMEM_MSAN_DEFINE(p, len):
34+
* - Like SECP256K1_CHECKMEM_DEFINE, but applies only to memory_sanitizer.
3335
*
3436
*/
3537

@@ -48,11 +50,16 @@
4850
# define SECP256K1_CHECKMEM_ENABLED 1
4951
# define SECP256K1_CHECKMEM_UNDEFINE(p, len) __msan_allocated_memory((p), (len))
5052
# define SECP256K1_CHECKMEM_DEFINE(p, len) __msan_unpoison((p), (len))
53+
# define SECP256K1_CHECKMEM_MSAN_DEFINE(p, len) __msan_unpoison((p), (len))
5154
# define SECP256K1_CHECKMEM_CHECK(p, len) __msan_check_mem_is_initialized((p), (len))
5255
# define SECP256K1_CHECKMEM_RUNNING() (1)
5356
# endif
5457
#endif
5558

59+
#if !defined SECP256K1_CHECKMEM_MSAN_DEFINE
60+
# define SECP256K1_CHECKMEM_MSAN_DEFINE(p, len) SECP256K1_CHECKMEM_NOOP((p), (len))
61+
#endif
62+
5663
/* If valgrind integration is desired (through the VALGRIND define), implement the
5764
* SECP256K1_CHECKMEM_* macros using valgrind. */
5865
#if !defined SECP256K1_CHECKMEM_ENABLED

src/scalar_4x64_impl.h

+18
Original file line numberDiff line numberDiff line change
@@ -462,6 +462,14 @@ static void secp256k1_scalar_reduce_512(secp256k1_scalar *r, const uint64_t *l)
462462
: "S"(l), "i"(SECP256K1_N_C_0), "i"(SECP256K1_N_C_1)
463463
: "rax", "rdx", "r8", "r9", "r10", "r11", "r12", "r13", "r14", "cc");
464464

465+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m0, sizeof(m0));
466+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m1, sizeof(m1));
467+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m2, sizeof(m2));
468+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m3, sizeof(m3));
469+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m4, sizeof(m4));
470+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m5, sizeof(m5));
471+
SECP256K1_CHECKMEM_MSAN_DEFINE(&m6, sizeof(m6));
472+
465473
/* Reduce 385 bits into 258. */
466474
__asm__ __volatile__(
467475
/* Preload */
@@ -541,6 +549,12 @@ static void secp256k1_scalar_reduce_512(secp256k1_scalar *r, const uint64_t *l)
541549
: "g"(m0), "g"(m1), "g"(m2), "g"(m3), "g"(m4), "g"(m5), "g"(m6), "i"(SECP256K1_N_C_0), "i"(SECP256K1_N_C_1)
542550
: "rax", "rdx", "r8", "r9", "r10", "r11", "r12", "r13", "cc");
543551

552+
SECP256K1_CHECKMEM_MSAN_DEFINE(&p0, sizeof(p0));
553+
SECP256K1_CHECKMEM_MSAN_DEFINE(&p1, sizeof(p1));
554+
SECP256K1_CHECKMEM_MSAN_DEFINE(&p2, sizeof(p2));
555+
SECP256K1_CHECKMEM_MSAN_DEFINE(&p3, sizeof(p3));
556+
SECP256K1_CHECKMEM_MSAN_DEFINE(&p4, sizeof(p4));
557+
544558
/* Reduce 258 bits into 256. */
545559
__asm__ __volatile__(
546560
/* Preload */
@@ -586,6 +600,10 @@ static void secp256k1_scalar_reduce_512(secp256k1_scalar *r, const uint64_t *l)
586600
: "=g"(c)
587601
: "g"(p0), "g"(p1), "g"(p2), "g"(p3), "g"(p4), "D"(r), "i"(SECP256K1_N_C_0), "i"(SECP256K1_N_C_1)
588602
: "rax", "rdx", "r8", "r9", "r10", "cc", "memory");
603+
604+
SECP256K1_CHECKMEM_MSAN_DEFINE(r, sizeof(*r));
605+
SECP256K1_CHECKMEM_MSAN_DEFINE(&c, sizeof(c));
606+
589607
#else
590608
secp256k1_uint128 c128;
591609
uint64_t c, c0, c1, c2;

0 commit comments

Comments
 (0)