[PATCH] D71600: PowerPC 32-bit - forces 8 byte lock/lock_free decisions at compiled time
Alfredo Dal'Ava JĂșnior via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Tue Dec 17 04:55:00 PST 2019
adalava created this revision.
Herald added subscribers: llvm-commits, Sanitizers, cfe-commits, steven.zhang, shchenz, jsji, jfb, krytarowski, arichardson, nemanjai, emaste.
Herald added a reviewer: jfb.
Herald added projects: clang, Sanitizers, LLVM.
adalava added a reviewer: dim.
Herald added subscribers: wuzish, dexonsmith.
FreeBSD on powerpc 32 bit is moving to LLVM, so I enabled atomic.c on this platform and found it was emiting calls to make decisions about lock/lock free at runtime.
We know in advance 8 byte (64 bits) operations need lock and there's no plans to create something like a "libatomic", so I creates this patch. This is being currently in use on our experimental builds/ISOs, so I ask for your inputs. Thanks!
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D71600
Files:
clang/lib/AST/ExprConstant.cpp
compiler-rt/lib/builtins/atomic.c
Index: compiler-rt/lib/builtins/atomic.c
===================================================================
--- compiler-rt/lib/builtins/atomic.c
+++ compiler-rt/lib/builtins/atomic.c
@@ -119,13 +119,20 @@
return locks + (hash & SPINLOCK_MASK);
}
-/// Macros for determining whether a size is lock free. Clang can not yet
-/// codegen __atomic_is_lock_free(16), so for now we assume 16-byte values are
-/// not lock free.
+/// Macros for determining whether a size is lock free.
#define IS_LOCK_FREE_1 __c11_atomic_is_lock_free(1)
#define IS_LOCK_FREE_2 __c11_atomic_is_lock_free(2)
#define IS_LOCK_FREE_4 __c11_atomic_is_lock_free(4)
+
+/// 32 bit PowerPC doesn't support 8-byte lock_free atomics
+#if !defined(__powerpc64__) && defined(__powerpc__)
+#define IS_LOCK_FREE_8 0
+#else
#define IS_LOCK_FREE_8 __c11_atomic_is_lock_free(8)
+#endif
+
+/// Clang can not yet codegen __atomic_is_lock_free(16), so for now we assume
+/// 16-byte values are not lock free.
#define IS_LOCK_FREE_16 0
/// Macro that calls the compiler-generated lock-free versions of functions
Index: clang/lib/AST/ExprConstant.cpp
===================================================================
--- clang/lib/AST/ExprConstant.cpp
+++ clang/lib/AST/ExprConstant.cpp
@@ -11023,6 +11023,13 @@
}
}
+ // Avoid emiting call for runtime decision on PowerPC 32-bit
+ // The lock free possibilities on this platform are covered by the lines
+ // above and we know in advance other cases require lock
+ if (Info.Ctx.getTargetInfo().getTriple().getArch() == llvm::Triple::ppc) {
+ return Success(0, E);
+ }
+
return BuiltinOp == Builtin::BI__atomic_always_lock_free ?
Success(0, E) : Error(E);
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D71600.234275.patch
Type: text/x-patch
Size: 1732 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20191217/61e2d66b/attachment.bin>
More information about the cfe-commits
mailing list