rust/compiler/rustc_llvm/llvm-wrapper
Mark Rousskov bf3deccdad Fix UB in LLVM FFI when passing zero or >1 bundle
Rust passes a *const &OperandBundleDef to these APIs, usually from a
Vec<&OperandBundleDef> or so. Previously we were dereferencing that
pointer and passing it to the ArrayRef constructor with some length (N).

This meant that if the length was 0, we were dereferencing a pointer to
nowhere, and if the length was >1 then loading the *second* element
somewhere in LLVM would've been reading past the end.

Since Rust can't hold OperandBundleDef by-value we're forced to indirect
through a vector that copies out the OperandBundleDefs from the
by-reference list on the Rust side in order to match the LLVM expected
API.
2024-04-14 22:18:33 -04:00
..
.editorconfig Move rustllvm into rustc_llvm 2020-09-09 23:05:43 +03:00
ArchiveWrapper.cpp update messages 2024-04-03 19:03:12 -04:00
CoverageMappingWrapper.cpp Rollup merge of #123437 - Zalathar:clang-format, r=cuviper 2024-04-04 21:16:57 -04:00
Linker.cpp suppress warnings on msvc 2023-11-22 09:10:53 -08:00
LLVMWrapper.h Remove ffi_returns_twice feature 2024-01-30 22:09:09 +00:00
PassWrapper.cpp Update the minimum external LLVM to 17 2024-03-17 10:11:04 -07:00
README Move rustllvm into rustc_llvm 2020-09-09 23:05:43 +03:00
RustWrapper.cpp Fix UB in LLVM FFI when passing zero or >1 bundle 2024-04-14 22:18:33 -04:00
SuppressLLVMWarnings.h fix long lines 2023-11-22 10:17:50 -08:00
SymbolWrapper.cpp Explicitly assign constructed C++ classes 2024-03-05 21:15:56 -08:00

This directory currently contains some LLVM support code. This will generally
be sent upstream to LLVM in time; for now it lives here.

NOTE: the LLVM C++ ABI is subject to between-version breakage and must *never*
be exposed to Rust. To allow for easy auditing of that, all Rust-exposed types
must be typedef-ed as "LLVMXyz", or "LLVMRustXyz" if they were defined here.

Functions that return a failure status and leave the error in
the LLVM last error should return an LLVMRustResult rather than an
int or anything to avoid confusion.

When translating enums, add a single `Other` variant as the first
one to allow for new variants to be added. It should abort when used
as an input.

All other types must not be typedef-ed as such.