[CIR] Fix heap-use-after-free in IndirectBrOp lowering (#191949) The previous code called op->getBlock()->eraseArgument(0) to remove a block argument when the poison attribute was set (unreachable block with no predecessors). This directly mutated the IR, freeing the BlockArgument while the MLIR dialect conversion framework still held references to it. When the framework later replayed changes in applyRewrites(), it dereferenced the freed BlockArgument, causing a heap-use-after-free detected by ASAN. Found by running check-clang-cir under ASAN (test: clang/test/CIR/CodeGen/label-values.c). The fix removes the eraseArgument call entirely. The MLIR conversion framework tracks block arguments and handles their lifecycle. A block with no predecessors naturally produces no PHI node in LLVM IR, so manual removal was unnecessary. Additional cleanup: - Use adaptor.getAddr() directly instead of creating an unnecessary BitcastOp (CIR ptr already converts to LLVM ptr). - Use adaptor.getSuccOperands() instead of op.getSuccOperands() to ensure successor operands go through type conversion. - Use replaceOpWithNewOp instead of separate create + replaceOp.
Welcome to the LLVM project!
This repository contains the source code for LLVM, a toolkit for the construction of highly optimized compilers, optimizers, and run-time environments.
The LLVM project has multiple components. The core of the project is itself called “LLVM”. This contains all of the tools, libraries, and header files needed to process intermediate representations and convert them into object files. Tools include an assembler, disassembler, bitcode analyzer, and bitcode optimizer.
C-like languages use the Clang frontend. This component compiles C, C++, Objective-C, and Objective-C++ code into LLVM bitcode -- and from there into object files, using LLVM.
Other components include: the libc++ C++ standard library, the LLD linker, and more.
Consult the Getting Started with LLVM page for information on building and running LLVM.
For information on how to contribute to the LLVM project, please take a look at the Contributing to LLVM guide.
Join the LLVM Discourse forums, Discord chat, LLVM Office Hours or Regular sync-ups.
The LLVM project has adopted a code of conduct for participants to all modes of communication within the project.