diff options
author | A. Wilcox <AWilcox@Wilcox-Tech.com> | 2024-07-06 20:37:32 -0500 |
---|---|---|
committer | A. Wilcox <AWilcox@Wilcox-Tech.com> | 2024-08-07 10:08:22 -0500 |
commit | e2ec142d7bfd9f2465c62900a03e3accf4adf572 (patch) | |
tree | e1f4499d59088adf1da20797fb9f260c2e87bf05 /user/llvm18/dwarf-info.patch | |
parent | c5c08854322efc2aea8f8bcf51a544976fd86a12 (diff) | |
download | packages-e2ec142d7bfd9f2465c62900a03e3accf4adf572.tar.gz packages-e2ec142d7bfd9f2465c62900a03e3accf4adf572.tar.bz2 packages-e2ec142d7bfd9f2465c62900a03e3accf4adf572.tar.xz packages-e2ec142d7bfd9f2465c62900a03e3accf4adf572.zip |
user/llvm18: New package
Diffstat (limited to 'user/llvm18/dwarf-info.patch')
-rw-r--r-- | user/llvm18/dwarf-info.patch | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/user/llvm18/dwarf-info.patch b/user/llvm18/dwarf-info.patch new file mode 100644 index 000000000..9357c6519 --- /dev/null +++ b/user/llvm18/dwarf-info.patch @@ -0,0 +1,28 @@ +Author: A. Wilcox <awilfox@adelielinux.org> + +This isn't the proper fix, but debugging the LLVM formatter is a bit +above my paygrade at the moment. + +The issue shows up in the DWARF X86 test on ppc and armv7: + +error: Simplified template DW_AT_name could not be reconstituted: + original: f3<char, '\x00', '\x01', '\x06', '\a', '\r', '\x0e', '\x1f', ' ', '!', '\x7f', '\x80'> + reconstituted: f3<char, '\x00', '\x00', '\x00', '\a', '\r', '\x00', '\x00', ' ', '!', '\x00', '\x00'> + +With this patch, this error does not occur. Debugging shows that the +llvm::format overload called in the error case is <long long>, so I +think it is having an issue converting a 64-bit value on platforms +where char is default-unsigned. + +(pmmx does not show this issue, and has signed char.) +--- llvm-14.0.6.src/lib/DebugInfo/DWARF/DWARFDie.cpp.old 2022-06-22 16:46:24.000000000 +0000 ++++ llvm-14.0.6.src/lib/DebugInfo/DWARF/DWARFDie.cpp 2022-11-28 10:32:05.573627744 +0000 +@@ -506,7 +506,7 @@ + OS << (char)Val; + OS << "'"; + } else if (Val < 256) +- OS << to_string(llvm::format("'\\x%02x'", Val)); ++ OS << to_string(llvm::format("'\\x%02x'", (unsigned char)Val)); + else if (Val <= 0xFFFF) + OS << to_string(llvm::format("'\\u%04x'", Val)); + else |