seventh moon
2009-May-05  14:00 UTC
[LLVMdev] A problem creating operands for a new IR instruction to the mailing list
I have a question about inserting instructions into the LLVM IR.  I can insert
instructions, but my operands do not have the right type, so it fails an
assertion at runtime.
I am trying to insert an immediate load instructions, as a means of claiming a
new register.
Here is what I do:
    Builder.SetInsertPoint(LLVMBB, I);
// The following line looks to me like it would have a chance of loading either
// address 5, or else immediate value 5. Unfortunately, it does neither. It
compiles
// but crashes at runtime, that the type of the operand is incompatible
        Instruction *newI=Builder.CreateLoad(5,"");
// I also tested this, just to do a little sanity check. It also compiles then
// crashes, for the obvious reason that the operand is a register, but an
address
// or an immediate value is expected.
        //Instruction
*newI=Builder.CreateLoad(I->getOperand(1),""); // also wrong
So to say it simply, my question is, "How can I create a new Value*, which
indicates
an immediate value, such as immediate value 5?"
Thank you for your assistance,
Kao Chang
_________________________________________________________________
用部落格分享照片、影音、趣味小工具和最愛清單,盡情秀出你自己 — Windows Live Spaces
http://home.spaces.live.com/?showUnauth=1&lc=1028
-------------- next part --------------
An HTML attachment was scrubbed...
URL:
<http://lists.llvm.org/pipermail/llvm-dev/attachments/20090505/1affa5a3/attachment.html>
To"ro"k Edwin
2009-May-05  14:07 UTC
[LLVMdev] A problem creating operands for a new IR instruction to the mailing list
On 2009-05-05 17:00, seventh moon wrote:> I have a question about inserting instructions into the LLVM IR. I can > insert instructions, but my operands do not have the right type, so it > fails an assertion at runtime. > > I am trying to insert an immediate load instructions, as a means of > claiming a new register. > > Here is what I do: > Builder.SetInsertPoint(LLVMBB, I); > > // The following line looks to me like it would have a chance o! f > loading either > // address 5, or else immediate value 5. Unfortunately, it does > neither. It compiles > // but crashes at runtime, that the type of the operand is incompatible > Instruction *newI=Builder.CreateLoad(5,""); > > // I also tested this, just to do a little sanity check. It also > compiles then > // crashes, for the obvious reason that the operand is a register, but > an address > // or an immediate value is expected. > //Instruction *newI=Builder.CreateLoad(I->getOperand(1),""); // also > wrong > > So to say it simply, my question is, "How can I create a new Value*, > which indicates > an immediate value, such as immediate value 5?"You should use a constant instead of a load: Constant *C = ConstantInt::get(Type::Int32Ty, 5); Note that the constant is not an instruction, but it can be used like any other Value*. Best regards, --Edwin
Olivier Meurant
2009-May-05  14:07 UTC
[LLVMdev] A problem creating operands for a new IR instruction to the mailing list
If you want an immediate constant value, ConstantInt::get(APInt(32, 5, false)) will perhaps help you ? Olivier. 2009/5/5 seventh moon <suigintou_ at hotmail.com>> I have a question about inserting instructions into the LLVM IR. I can > insert instructions, but my operands do not have the right type, so it fails > an assertion at runtime. > > I am trying to insert an immediate load instructions, as a means of > claiming a new register. > > Here is what I do: > Builder.SetInsertPoint(LLVMBB, I); > > // The following line looks to me like it would have a chance o! f loading > either > // address 5, or else immediate value 5. Unfortunately, it does neither. It > compiles > // but crashes at runtime, that the type of the operand is incompatible > Instruction *newI=Builder.CreateLoad(5,""); > > // I also tested this, just to do a little sanity check. It also compiles > then > // crashes, for the obvious reason that the operand is a register, but an > address > // or an immediate value is expected. > //Instruction *newI=Builder.CreateLoad(I->getOperand(1),""); // > also wrong > > So to say it simply, my question is, "How can I create a new Value*, which > indicates > an immediate value, such as immediate value 5?" > > Thank you for your assistance, > Kao Chang > ------------------------------ > 用部落格分享照片、影音、趣味小工具和最愛清單,盡情秀出! 你自己 — Windows Live Spaces<http://home.spaces.live.com/?showUnauth=1&lc=1028> > > _______________________________________________ > LLVM Developers mailing list > LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu > http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev > >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20090505/ba9c9881/attachment.html>
John Criswell
2009-May-05  16:42 UTC
[LLVMdev] A problem creating operands for a new IR instruction to the mailing list
seventh moon wrote:> [snip] > > So to say it simply, my question is, "How can I create a new Value*, which indicates > an immediate value, such as immediate value 5?" >I don't know much about LLVM's code generators, but if all you need is to create a Value * for an immediate constant, you might try using the ConstantInt::get() method (http://llvm.org/doxygen/classllvm_1_1ConstantInt.html#77cd822480bc78732c84a9619e49e14a). A ConstantInt is a subclass of Value, and you can use it to create constant integer values in the LLVM IR. -- John T.
seventh moon
2009-May-06  03:59 UTC
[LLVMdev] A problem creating operands for a new IR instruction to the mailing list
Thank you for your answer.  But there is still a problem.
You seem correct about how to define a constant operand.  So I added it into my
code, like so:
       Builder.SetInsertPoint(LLVMBB, I);
       Constant *C = ConstantInt::get(APInt(32, 5, false));
        Instruction *newI=Builder.CreateLoad(C,"");
It compiles. But it still aborts at runtime with a complaint that the type is
not right.
This leads me to think that immediate loads are not generated with the
CreateLoad
instruction?
Another person's reply to my question indicated that a way to avoid
inserting the
immediate load entirely; but that is also not what I want, because my explicit
purpose
in inserting this load is to claim a register.
Thank you,
Kao Chang
Date: Tue, 5 May 2009 16:07:33 +0200
From: meurant.olivier at gmail.com
To: llvmdev at cs.uiuc.edu
Subject: Re: [LLVMdev] A problem creating operands for a new IR instruction	to
the mailing list
If you want an immediate constant value, ConstantInt::get(APInt(32, 5, false))
will perhaps help you ?
Olivier.
2009/5/5 seventh moon <suigintou_ at hotmail.com>
I have a question about inserting instructions into the LLVM IR.  I can insert
instructions, but my operands do not have the right type, so it fails an
assertion at runtime.
I am trying to insert an immediate load instructions, as a means of claiming a
new register.
Here is what I do:
    Builder.SetInsertPoint(LLVMBB, I);
// The following line looks to me like it would have a chance o!
 f loading either
// address 5, or else immediate value 5. Unfortunately, it does neither. It
compiles
// but crashes at runtime, that the type of the operand is incompatible
        Instruction *newI=Builder.CreateLoad(5,"");
// I also tested this, just to do a little sanity check. It also compiles then
// crashes, for the obvious reason that the operand is a register, but an
address
// or an immediate value is expected.
        //Instruction
*newI=Builder.CreateLoad(I->getOperand(1),""); // also wrong
So to say it simply, my question is, "How can I create a new Value*, which
indicates
an immediate value, such as immediate value 5?"
Thank you for your assistance,
Kao Chang
用部落格分享照片、影音、趣味小工具和最愛清單,盡情秀出!
 你自己 — Windows Live Spaces
_______________________________________________
LLVM Developers mailing list
LLVMdev at cs.uiuc.edu         http://llvm.cs.uiuc.edu
http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev
_________________________________________________________________
隨身的 Windows Live Messenger 和 Hotmail,不限時地掌握資訊盡在指間 — Windows Live for Mobile
http://3c.msn.com.tw/mobile/
-------------- next part --------------
An HTML attachment was scrubbed...
URL:
<http://lists.llvm.org/pipermail/llvm-dev/attachments/20090506/3a96d73d/attachment.html>
Reasonably Related Threads
- [LLVMdev] A problem creating operands for a new IR instruction to the mailing list
- [LLVMdev] A problem creating operands for a new IR instruction to the mailing list
- [LLVMdev] A question about printout the SeletionDAG
- [LLVMdev] how can I compile an ARM assembly file produced by llc into ARM binary ?
- [LLVMdev] Need help in converting int to double