7fc9190f0e
* gcc is kept at -Np0, because of void-cross ```sh git grep -l '^patch_args=-Np0' "srcpkgs/$1*/template" | while read template; do for p in ${template%/template}/patches/*; do sed -i ' \,^[+-][+-][+-] /dev/null,b /^[*-]\+ [0-9]\+\(,[0-9]\+\)\? [*-]\+$/b s,^[*][*][*] ,&a/, /^--- /{ s,\(^--- \)\(./\)*,\1a/, s,[.][Oo][Rr][Ii][Gg]\([ /]\),\1, s/[.][Oo][Rr][Ii][Gg]$// s/[.]patched[.]\([^.]\)/.\1/ h } /^+++ -/{ g s/^--- a/+++ b/ b } s,\(^+++ \)\(./\)*,\1b/, ' "$p" done sed -i '/^patch_args=/d' $template done ```
63 lines
2.7 KiB
Diff
63 lines
2.7 KiB
Diff
An all-in-one patch that fixes several issues:
|
|
|
|
1) UnscaledCycleClock not fully implemented for ppc*-musl (disabled on musl)
|
|
2) powerpc stacktrace implementation only works on glibc (disabled on musl)
|
|
3) powerpc stacktrace implementation has ppc64 assumptions (fixed)
|
|
4) examine_stack.cpp makes glibc assumptions on powerpc (fixed)
|
|
|
|
--- a/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc
|
|
+++ b/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc
|
|
@@ -20,7 +20,7 @@
|
|
#include <intrin.h>
|
|
#endif
|
|
|
|
-#if defined(__powerpc__) || defined(__ppc__)
|
|
+#if (defined(__powerpc__) || defined(__ppc__)) && defined(__GLIBC__)
|
|
#ifdef __GLIBC__
|
|
#include <sys/platform/ppc.h>
|
|
#elif defined(__FreeBSD__)
|
|
@@ -59,7 +59,7 @@
|
|
return base_internal::NominalCPUFrequency();
|
|
}
|
|
|
|
-#elif defined(__powerpc__) || defined(__ppc__)
|
|
+#elif (defined(__powerpc__) || defined(__ppc__)) && defined(__GLIBC__)
|
|
|
|
int64_t UnscaledCycleClock::Now() {
|
|
#ifdef __GLIBC__
|
|
--- a/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h
|
|
+++ b/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h
|
|
@@ -46,7 +46,7 @@
|
|
|
|
// The following platforms have an implementation of a hardware counter.
|
|
#if defined(__i386__) || defined(__x86_64__) || defined(__aarch64__) || \
|
|
- defined(__powerpc__) || defined(__ppc__) || \
|
|
+ ((defined(__powerpc__) || defined(__ppc__)) && defined(__GLIBC__)) || \
|
|
defined(_M_IX86) || defined(_M_X64)
|
|
#define ABSL_HAVE_UNSCALED_CYCLECLOCK_IMPLEMENTATION 1
|
|
#else
|
|
--- a/third_party/abseil-cpp/absl/debugging/internal/examine_stack.cc
|
|
+++ b/third_party/abseil-cpp/absl/debugging/internal/examine_stack.cc
|
|
@@ -63,8 +63,10 @@ void* GetProgramCounter(void* vuc) {
|
|
return reinterpret_cast<void*>(context->uc_mcontext.pc);
|
|
#elif defined(__powerpc64__)
|
|
return reinterpret_cast<void*>(context->uc_mcontext.gp_regs[32]);
|
|
-#elif defined(__powerpc__)
|
|
+#elif defined(__powerpc__) && defined(__GLIBC__)
|
|
return reinterpret_cast<void*>(context->uc_mcontext.uc_regs->gregs[32]);
|
|
+#elif defined(__powerpc__)
|
|
+ return reinterpret_cast<void*>(context->uc_mcontext.gregs[32]);
|
|
#elif defined(__riscv)
|
|
return reinterpret_cast<void*>(context->uc_mcontext.__gregs[REG_PC]);
|
|
#elif defined(__s390__) && !defined(__s390x__)
|
|
--- a/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h
|
|
+++ b/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h
|
|
@@ -64,7 +64,7 @@
|
|
#elif defined(__i386__) || defined(__x86_64__)
|
|
#define ABSL_STACKTRACE_INL_HEADER \
|
|
"absl/debugging/internal/stacktrace_x86-inl.inc"
|
|
-#elif defined(__ppc__) || defined(__PPC__)
|
|
+#elif (defined(__ppc__) || defined(__PPC__)) && defined(__GLIBC__)
|
|
#define ABSL_STACKTRACE_INL_HEADER \
|
|
"absl/debugging/internal/stacktrace_powerpc-inl.inc"
|
|
#elif defined(__aarch64__)
|