From: Noah Goldstein Date: Mon, 8 Aug 2022 03:26:22 +0000 (+0800) Subject: elf: Replace `strcpy` call with `memcpy` [BZ #29454] X-Git-Tag: glibc-2.37~438 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=483cfe1a6a33d6335b1901581b41040d2d412511;p=thirdparty%2Fglibc.git elf: Replace `strcpy` call with `memcpy` [BZ #29454] GCC normally does this optimization for us in strlen_pass::handle_builtin_strcpy but only for optimized build. To avoid needing to include strcpy.S in the rtld build to support the debug build, just do the optimization by hand. --- diff --git a/elf/dl-cache.c b/elf/dl-cache.c index 8bbf110d02c..b97c17b3a9c 100644 --- a/elf/dl-cache.c +++ b/elf/dl-cache.c @@ -509,8 +509,9 @@ _dl_load_cache_lookup (const char *name) we are accessing. Therefore we must make the copy of the mapping data without using malloc. */ char *temp; - temp = alloca (strlen (best) + 1); - strcpy (temp, best); + size_t best_len = strlen (best) + 1; + temp = alloca (best_len); + memcpy (temp, best, best_len); return __strdup (temp); }