[LLVMdev] Possible Bad Assertion in Value.cpp
Chris Lattner
sabre at nondot.org
Fri Feb 15 15:06:53 PST 2008
On Feb 15, 2008, at 3:01 PM, John Criswell wrote:
>> The convention is that 'remove' unlinks the object from the IR, and
>> 'erase' does remove and deletes the result.
>>
>> If someone wants to clarify this behavior in http://llvm.org/docs/ProgrammersManual.html#common
>> , it would be nice :)
>>
> No, I understood that part (granted, I read DoxyGen). The part I
> didn't
> understand is that I'm required to erase an instruction that should
> have
> no more uses before deleting the Module.
That's what the assertion is telling you (poorly) :). It is saying
that there is something that uses a value that is attempting to be
deleted. It doesn't know the context, so it can't tell you that the
user is something that was unlinked but not deleted.
If you write your code as an llvm pass, you should automatically get
notified of this stuff in a debug build. If you can't do that,
manually interfacing to the LeakDetector can help.
-Chris
More information about the llvm-dev
mailing list