base/allocator: Fix __THROW and mallinfo for Musl

This commit is contained in:
klzgrad 2022-11-09 23:36:59 +08:00
parent 779659fa19
commit 8f2b611f24
4 changed files with 18 additions and 3 deletions

View File

@ -282,7 +282,12 @@ void PartitionAllocMallocInitOnce() {
return;
}
#if PA_BUILDFLAG(IS_LINUX) || PA_BUILDFLAG(IS_CHROMEOS)
#if defined(__MUSL__)
// Musl calls malloc() in pthread_atfork(), resulting in a deadlock.
static_cast<void>(BeforeForkInParent);
static_cast<void>(AfterForkInParent);
static_cast<void>(AfterForkInChild);
#elif PA_BUILDFLAG(IS_LINUX) || PA_BUILDFLAG(IS_CHROMEOS)
// When fork() is called, only the current thread continues to execute in the
// child process. If the lock is held, but *not* by this thread when fork() is
// called, we have a deadlock.

View File

@ -660,7 +660,9 @@ SHIM_ALWAYS_EXPORT int mallopt(int cmd, int value) __THROW {
#endif // !PA_BUILDFLAG(IS_APPLE) && !PA_BUILDFLAG(IS_ANDROID)
#if PA_BUILDFLAG(IS_LINUX) || PA_BUILDFLAG(IS_CHROMEOS)
#if defined(__MUSL__)
// Musl does not support struct mallinfo.
#elif PA_BUILDFLAG(IS_LINUX) || PA_BUILDFLAG(IS_CHROMEOS)
SHIM_ALWAYS_EXPORT struct mallinfo mallinfo(void) __THROW {
partition_alloc::SimplePartitionStatsDumper allocator_dumper;
Allocator()->DumpStats("malloc", true, &allocator_dumper);

View File

@ -9,7 +9,9 @@
#if defined(__GNUC__)
#if PA_BUILDFLAG(IS_POSIX)
#if defined(__MUSL__)
// Musl does not provide sys/cdefs.h
#elif PA_BUILDFLAG(IS_POSIX)
#include <sys/cdefs.h> // for __THROW
#endif

View File

@ -25,6 +25,12 @@
#include "partition_alloc/shim/allocator_shim_internals.h"
// Musl does not specify anything for malloc() etc.
#if defined(__MUSL__)
#undef __THROW
#define __THROW
#endif
extern "C" {
// WARNING: Whenever a new function is added there (which, surprisingly enough,