Skip to content

Commit

Permalink
lzloader: fix memset() implementation
Browse files Browse the repository at this point in the history
Some compilers apparently optimize code in fastlz/ to call memset(), so
the uncompressing boot loader, fastlz/lzloader.cc, needs to implement
this function. The current implementation called the "builtin" memset,
which, if you look at the compilation result, actually calls memset()
and results in endless recursion and a hanging boot... This started
happening on Fedora 32 with Gcc 10, for example.

So let's implement memset() using the base_memset() we already have in
libc/string/memset.c.

Fixes #1084.

Signed-off-by: Nadav Har'El <nyh@scylladb.com>
  • Loading branch information
nyh committed May 23, 2020
1 parent 8647177 commit f50218f
Showing 1 changed file with 10 additions and 5 deletions.
15 changes: 10 additions & 5 deletions fastlz/lzloader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,16 @@ extern char _binary_loader_stripped_elf_lz_start;
extern char _binary_loader_stripped_elf_lz_end;
extern char _binary_loader_stripped_elf_lz_size;

// std libraries used by fastlz.
extern "C" void *memset(void *s, int c, size_t n)
{
return __builtin_memset(s, c, n);
}
// The code in fastlz.cc does not call memset(), but some version of gcc
// implement some assignments by calling memset(), so we need to implement
// a memset() function. This is not performance-critical so let's stick to
// the basic implementation we have in libc/string/memset.c. To avoid
// compiling this source file a second time (the loader needs different
// compile parameters), we #include it here instead.
extern "C" void *memset(void *s, int c, size_t n);
#define memset_base memset
#include "libc/string/memset.c"
#undef memset_base

extern "C" void uncompress_loader()
{
Expand Down

0 comments on commit f50218f

Please sign in to comment.