use bzero() instead of memset_s()
authorDebian Samba Maintainers <pkg-samba-maint@lists.alioth.debian.org>
Thu, 28 Nov 2024 19:28:27 +0000 (22:28 +0300)
committerMichael Tokarev <mjt@tls.msk.ru>
Thu, 28 Nov 2024 19:28:27 +0000 (22:28 +0300)
lib/replace/replace.h header defines ZERO_STRUCT macro
which uses memset_s() function (which is similar to
memset() but can not be optimized out by the compiler).
Glibc has bzero() with similar property, while memset_s()
have is implemented in lib/replace/replace.c, - this way,
some binaries needlessly link with libreplace-samba4 just
to get rep_memset_s() symbol. By using bzero() instead,
this endless linkage is eliminated, so we can package,
for example, libldb (which uses ZERO_STRUCT) without it
linking to libreplace-samba4.

Note: actually using explicit_bzero() so it is not optimized
out by the compiler - this is the original goal of using
memset_s().

Gbp-Pq: Name use-bzero-instead-of-memset_s.diff

lib/replace/replace.h

index 537e61e1e4888ed0b0327509ecda6d8b677944aa..fac51d367d2ea5af7638f475b8fed650e4678ec0 100644 (file)
@@ -815,7 +815,7 @@ typedef unsigned long long ptrdiff_t ;
 /**
  * Zero a structure.
  */
-#define ZERO_STRUCT(x) memset_s((char *)&(x), sizeof(x), 0, sizeof(x))
+#define ZERO_STRUCT(x) explicit_bzero((char *)&(x), sizeof(x))
 
 /**
  * Zero a structure given a pointer to the structure.