use bzero() instead of memset_s()
authorDebian Samba Maintainers <pkg-samba-maint@lists.alioth.debian.org>
Mon, 10 Jun 2024 17:17:53 +0000 (20:17 +0300)
committerMichael Tokarev <mjt@tls.msk.ru>
Mon, 10 Jun 2024 17:17:53 +0000 (20:17 +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 a6a2b40777f3c932ca6839a08a31998cc295acb1..070d3679251cdded0fa9e3d541efe5575005b03b 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.