diff options
| author | Andrea Corallo | 2021-01-24 21:05:33 +0100 |
|---|---|---|
| committer | Andrea Corallo | 2021-01-24 21:05:33 +0100 |
| commit | b8d3ae78c54db7c7bb65d367a80f9be3d8744c48 (patch) | |
| tree | 982f190d1dd79685c43a9829dd66e6a7cbbd0c67 /lib/explicit_bzero.c | |
| parent | 0ffb3dfaa483b0c5cf1f7f367efcb5e9c041ab53 (diff) | |
| parent | e5aaa1251cfb9d6d18682a5eda137a2e12ca4213 (diff) | |
| download | emacs-b8d3ae78c54db7c7bb65d367a80f9be3d8744c48.tar.gz emacs-b8d3ae78c54db7c7bb65d367a80f9be3d8744c48.zip | |
Merge remote-tracking branch 'savannah/master' into native-comp
Diffstat (limited to 'lib/explicit_bzero.c')
| -rw-r--r-- | lib/explicit_bzero.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/lib/explicit_bzero.c b/lib/explicit_bzero.c index feea4446c06..f50ed0875d7 100644 --- a/lib/explicit_bzero.c +++ b/lib/explicit_bzero.c | |||
| @@ -54,11 +54,21 @@ explicit_bzero (void *s, size_t len) | |||
| 54 | explicit_memset (s, '\0', len); | 54 | explicit_memset (s, '\0', len); |
| 55 | #elif HAVE_MEMSET_S | 55 | #elif HAVE_MEMSET_S |
| 56 | (void) memset_s (s, len, '\0', len); | 56 | (void) memset_s (s, len, '\0', len); |
| 57 | #else | 57 | #elif defined __GNUC__ && !defined __clang__ |
| 58 | memset (s, '\0', len); | 58 | memset (s, '\0', len); |
| 59 | # if defined __GNUC__ && !defined __clang__ | ||
| 60 | /* Compiler barrier. */ | 59 | /* Compiler barrier. */ |
| 61 | asm volatile ("" ::: "memory"); | 60 | asm volatile ("" ::: "memory"); |
| 62 | # endif | 61 | #elif defined __clang__ |
| 62 | memset (s, '\0', len); | ||
| 63 | /* Compiler barrier. */ | ||
| 64 | /* With asm ("" ::: "memory") LLVM analyzes uses of 's' and finds that the | ||
| 65 | whole thing is dead and eliminates it. Use 'g' to work around this | ||
| 66 | problem. See <https://bugs.llvm.org/show_bug.cgi?id=15495#c11>. */ | ||
| 67 | __asm__ volatile ("" : : "g"(s) : "memory"); | ||
| 68 | #else | ||
| 69 | /* Invoke memset through a volatile function pointer. This defeats compiler | ||
| 70 | optimizations. */ | ||
| 71 | void * (* const volatile volatile_memset) (void *, int, size_t) = memset; | ||
| 72 | (void) volatile_memset (s, '\0', len); | ||
| 63 | #endif | 73 | #endif |
| 64 | } | 74 | } |