Skip to content

Commit

Permalink
Fix CC1Main setting trigger undefined behavior
Browse files Browse the repository at this point in the history
This is caused by setting a temporary lambda to a `llvm::function_ref`.
The fix is to assign the lambda into a variable that outlives the `llvm::function_ref`.
  • Loading branch information
bricknerb committed Jan 3, 2025
1 parent 725e80f commit e8d9029
Showing 1 changed file with 2 additions and 1 deletion.
3 changes: 2 additions & 1 deletion toolchain/driver/clang_runner.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -146,13 +146,14 @@ auto ClangRunner::Run(llvm::ArrayRef<llvm::StringRef> args) -> bool {
// Note the subprocessing will effectively call `clang -cc1`, which turns into
// `carbon-busybox clang -cc1`, which results in an equivalent `clang_main`
// call.
driver.CC1Main = [](llvm::SmallVectorImpl<const char*>& cc1_args) -> int {
auto cc1_main = [](llvm::SmallVectorImpl<const char*>& cc1_args) -> int {
// cc1_args[0] will be the `clang_path` so we don't need the prepend arg.
llvm::ToolContext tool_context = {
.Path = cc1_args[0], .PrependArg = "clang", .NeedsPrependArg = false};
return clang_main(cc1_args.size(), const_cast<char**>(cc1_args.data()),
tool_context);
};
driver.CC1Main = cc1_main;

std::unique_ptr<clang::driver::Compilation> compilation(
driver.BuildCompilation(cstr_args));
Expand Down

0 comments on commit e8d9029

Please sign in to comment.