[lld] f8685a8 - [NFC][ELF] Wrap invokeELFT in do { } while (0) so it behaves as a function (#150119)
via llvm-commits
llvm-commits at lists.llvm.org
Sat Jul 26 16:20:59 PDT 2025
Author: Jessica Clarke
Date: 2025-07-27T00:20:55+01:00
New Revision: f8685a8533dd90d31ead8c631337a798012533e0
URL: https://github.com/llvm/llvm-project/commit/f8685a8533dd90d31ead8c631337a798012533e0
DIFF: https://github.com/llvm/llvm-project/commit/f8685a8533dd90d31ead8c631337a798012533e0.diff
LOG: [NFC][ELF] Wrap invokeELFT in do { } while (0) so it behaves as a function (#150119)
The current implementation is dangerous if used in contexts that need a
single statement, since invokeELFT(...); is in fact two statements, a
switch statement and an empty statement.
Added:
Modified:
lld/ELF/Target.h
Removed:
################################################################################
diff --git a/lld/ELF/Target.h b/lld/ELF/Target.h
index 93f15920bfedb..f4a6d83dafad2 100644
--- a/lld/ELF/Target.h
+++ b/lld/ELF/Target.h
@@ -338,21 +338,23 @@ inline uint64_t overwriteULEB128(uint8_t *bufLoc, uint64_t val) {
#pragma clang diagnostic ignored "-Wgnu-zero-variadic-macro-arguments"
#endif
#define invokeELFT(f, ...) \
- switch (ctx.arg.ekind) { \
- case lld::elf::ELF32LEKind: \
- f<llvm::object::ELF32LE>(__VA_ARGS__); \
- break; \
- case lld::elf::ELF32BEKind: \
- f<llvm::object::ELF32BE>(__VA_ARGS__); \
- break; \
- case lld::elf::ELF64LEKind: \
- f<llvm::object::ELF64LE>(__VA_ARGS__); \
- break; \
- case lld::elf::ELF64BEKind: \
- f<llvm::object::ELF64BE>(__VA_ARGS__); \
- break; \
- default: \
- llvm_unreachable("unknown ctx.arg.ekind"); \
- }
+ do { \
+ switch (ctx.arg.ekind) { \
+ case lld::elf::ELF32LEKind: \
+ f<llvm::object::ELF32LE>(__VA_ARGS__); \
+ break; \
+ case lld::elf::ELF32BEKind: \
+ f<llvm::object::ELF32BE>(__VA_ARGS__); \
+ break; \
+ case lld::elf::ELF64LEKind: \
+ f<llvm::object::ELF64LE>(__VA_ARGS__); \
+ break; \
+ case lld::elf::ELF64BEKind: \
+ f<llvm::object::ELF64BE>(__VA_ARGS__); \
+ break; \
+ default: \
+ llvm_unreachable("unknown ctx.arg.ekind"); \
+ } \
+ } while (0)
#endif
More information about the llvm-commits
mailing list