[PATCH] D129114: llvm-c: Add LLVMDeleteInstruction to fix a test issue
Nicolai Hähnle via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 7 05:29:54 PDT 2022
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rGfdf7e437bfc9: llvm-c: Add LLVMDeleteInstruction to fix a test issue (authored by nhaehnle).
Changed prior to commit:
https://reviews.llvm.org/D129114?vs=442213&id=442869#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D129114/new/
https://reviews.llvm.org/D129114
Files:
llvm/docs/ReleaseNotes.rst
llvm/include/llvm-c/Core.h
llvm/lib/IR/Core.cpp
llvm/tools/llvm-c-test/metadata.c
Index: llvm/tools/llvm-c-test/metadata.c
===================================================================
--- llvm/tools/llvm-c-test/metadata.c
+++ llvm/tools/llvm-c-test/metadata.c
@@ -31,12 +31,11 @@
LLVMValueRef values[] = { LLVMConstInt(LLVMInt32Type(), 0, 0) };
// This used to trigger an assertion
- LLVMSetMetadata(
- LLVMBuildRetVoid(b),
- LLVMGetMDKindID("kind", 4),
- LLVMMDNode(values, 1));
+ LLVMValueRef ret = LLVMBuildRetVoid(b);
+ LLVMSetMetadata(ret, LLVMGetMDKindID("kind", 4), LLVMMDNode(values, 1));
LLVMDisposeBuilder(b);
+ LLVMDeleteInstruction(ret);
return 0;
}
Index: llvm/lib/IR/Core.cpp
===================================================================
--- llvm/lib/IR/Core.cpp
+++ llvm/lib/IR/Core.cpp
@@ -2803,6 +2803,10 @@
unwrap<Instruction>(Inst)->eraseFromParent();
}
+void LLVMDeleteInstruction(LLVMValueRef Inst) {
+ unwrap<Instruction>(Inst)->deleteValue();
+}
+
LLVMIntPredicate LLVMGetICmpPredicate(LLVMValueRef Inst) {
if (ICmpInst *I = dyn_cast<ICmpInst>(unwrap(Inst)))
return (LLVMIntPredicate)I->getPredicate();
Index: llvm/include/llvm-c/Core.h
===================================================================
--- llvm/include/llvm-c/Core.h
+++ llvm/include/llvm-c/Core.h
@@ -3228,7 +3228,7 @@
LLVMValueRef LLVMGetPreviousInstruction(LLVMValueRef Inst);
/**
- * Remove and delete an instruction.
+ * Remove an instruction.
*
* The instruction specified is removed from its containing building
* block but is kept alive.
@@ -3247,6 +3247,16 @@
*/
void LLVMInstructionEraseFromParent(LLVMValueRef Inst);
+/**
+ * Delete an instruction.
+ *
+ * The instruction specified is deleted. It must have previously been
+ * removed from its containing building block.
+ *
+ * @see llvm::Value::deleteValue()
+ */
+void LLVMDeleteInstruction(LLVMValueRef Inst);
+
/**
* Obtain the code opcode for an individual instruction.
*
Index: llvm/docs/ReleaseNotes.rst
===================================================================
--- llvm/docs/ReleaseNotes.rst
+++ llvm/docs/ReleaseNotes.rst
@@ -199,6 +199,9 @@
* ``LLVMConstURem``
* ``LLVMConstSRem``
+* Add ``LLVMDeleteInstruction`` function which allows deleting instructions that
+ are not inserted into a basic block.
+
Changes to the Go bindings
--------------------------
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D129114.442869.patch
Type: text/x-patch
Size: 2351 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220707/f31ba588/attachment.bin>
More information about the llvm-commits
mailing list