X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Fmem%2Fmem.h;h=19f69c038c67efe1e11ac8ab5cec036123aa3b95;hb=870b63169c782ef0cc52687397e5b9a7125a61b0;hp=06a1b7a1f2411150147d043cc0bfdbf7635967e8;hpb=299170fa67ff3cf664cbcd2c95c4a85d0d6e699d;p=ccan diff --git a/ccan/mem/mem.h b/ccan/mem/mem.h index 06a1b7a1..19f69c03 100644 --- a/ccan/mem/mem.h +++ b/ccan/mem/mem.h @@ -144,7 +144,10 @@ static inline bool memstarts(void const *data, size_t data_len, * } */ PURE_FUNCTION -bool memeqzero(const void *data, size_t length); +static inline bool memeqstr(const void *data, size_t length, const char *string) +{ + return memeq(data, length, string, strlen(string)); +} /** * memeqzero - Is a byte array all zeroes? @@ -157,10 +160,7 @@ bool memeqzero(const void *data, size_t length); * } */ PURE_FUNCTION -static inline bool memeqstr(const void *data, size_t length, const char *string) -{ - return memeq(data, length, string, strlen(string)); -} +bool memeqzero(const void *data, size_t length); /** * memstarts_str - Does this byte array start with a string prefix? @@ -250,6 +250,7 @@ static inline void *memcheck_(const void *data, size_t len) #else static inline void *memcheck_(const void *data, size_t len) { + (void)len; return (void *)data; } #endif @@ -275,4 +276,20 @@ static inline void *memcheck_(const void *data, size_t len) #else #define memcheck(data, len) memcheck_((data), (len)) #endif + +/** + * memtaint - mark a memory region unused + * @data: start of region + * @len: length in bytes + * + * This writes an "0xdeadbeef" eyecatcher repeatedly to the memory. + * When running under valgrind, it also tells valgrind that the memory is + * uninitialized, triggering valgrind errors if it is used for branches + * or written out (or passed to memcheck!) in future. + * + * Example: + * // We'll reuse this buffer later, but be sure we don't access it. + * memtaint(somebytes, bytes_len); + */ +void memtaint(void *data, size_t len); #endif /* CCAN_MEM_H */