Skip to content

Commit

Permalink
[compiler-rt] Implement __clear_cache on FreeBSD/powerpc
Browse files Browse the repository at this point in the history
dd91734 (Add clear_cache implementation for ppc64. Fix buffer to
meet ppc64 alignment., 2017-07-28), adds an implementation for
__builtin___clear_cache on powerpc64, which was promptly ammended to
also be used with big endian mode in f67036b (This ppc64 implementation
of clear_cache works for both big and little endian., 2017-08-02)

clang will use this implementation for it's builtin on FreeBSD and result
in an abort() in the cases where 32-bit generation was requested (ex in
macppc or when the big endian powerpc64 build was done with "-m32") and as
reported[1] recently with pcre2, but there is no reason why the same code
couldn't be used in those cases, so use instead the more generic identifier
for the PowerPC architecture.

While at it, update the comment to reflect that POWER8/9 have a 128 byte
wide cache line and so the code could instead use 64 byte windows instead
but that possible optimization has been punted for now.

[1] PCRE2Project/pcre2#92

Reviewed By: jhibbits, #powerpc, MaskRay

Differential Revision: https://reviews.llvm.org/D122640

(cherry picked from commit 81f5c62)
  • Loading branch information
carenas authored and tstellar committed Apr 19, 2022
1 parent 33504b3 commit 09fba23
Showing 1 changed file with 4 additions and 1 deletion.
5 changes: 4 additions & 1 deletion compiler-rt/lib/builtins/clear_cache.c
Expand Up @@ -130,7 +130,10 @@ void __clear_cache(void *start, void *end) {
__asm __volatile("dsb ish");
}
__asm __volatile("isb sy");
#elif defined(__powerpc64__)
#elif defined(__powerpc__)
// Newer CPUs have a bigger line size made of multiple blocks, so the
// following value is a minimal common denominator for what used to be
// a single block cache line and is therefore inneficient.
const size_t line_size = 32;
const size_t len = (uintptr_t)end - (uintptr_t)start;

Expand Down

0 comments on commit 09fba23

Please sign in to comment.