[LLVMdev] copy instructions
Cochran, Wayne Owen
wcochran at vancouver.wsu.edu
Sat Apr 23 11:40:46 PDT 2011
That's cool. The students grok the SSA thing fine -- especially since all the var's
in the language we're translating from are immutable (functional style) which makes SSA fairly
straight forward; the phi instruction is needed in a few places where branching occurs.
Wayne O. Cochran
Assistant Professor Computer Science
wcochran at vancouver.wsu.edu
-----Original Message-----
From: Reid Kleckner [mailto:reid.kleckner at gmail.com]
Sent: Sat 4/23/2011 11:28 AM
To: Cochran, Wayne Owen
Cc: Eli Friedman; llvmdev at cs.uiuc.edu
Subject: Re: [LLVMdev] copy instructions
The mem2reg pass will rewrite allocas and loads and stores to SSA
virtual registers. Essentially it's a transformation from non-SSA to
SSA form. That said, I don't know if you want your students to
implement their own SSA transformation.
Reid
On Sat, Apr 23, 2011 at 1:57 PM, Cochran, Wayne Owen
<wcochran at vancouver.wsu.edu> wrote:
> It is my understanding, the alloca memory routines are used
> for forcing variables to be allocated on the stack frame -- which
> you would want for source level debugging.
> When SSA registers are used, LLVM will decide what goes into
> registers and what will spill over to the stack frame.
> I want the latter.
> --w
>
> Wayne O. Cochran
> Assistant Professor Computer Science
> wcochran at vancouver.wsu.edu
>
>
>
> -----Original Message-----
> From: Eli Friedman [mailto:eli.friedman at gmail.com]
> Sent: Fri 4/22/2011 5:53 PM
> To: Cochran, Wayne Owen
> Cc: llvmdev at cs.uiuc.edu
> Subject: Re: [LLVMdev] copy instructions
>
> On Fri, Apr 22, 2011 at 10:40 AM, Wayne Cochran
> <wcochran at vancouver.wsu.edu> wrote:
>> This is a simple SSA code generation 101 question.
>>
>> If I follow the IR code generation techniques in the Dragon book the
>> statement
>> x = y + z
>> would translate into something like this in SSA/LLVM
>> %0 = add %y, %z
>> %x = %0
>> Obviously "copy instructions" like %foo = %bar are senseless in SSA
>> since %foo and %bar are immutably fixed to the same value and there
>> is no need for two aliases for the same thing (this is my own observation,
>> please tell me if my thinking is off).
>>
>> What are the general code generation techniques to avoid "copy
>> instructions"?
>>
>> For example, the simple code generation methods that yield the translation
>> above might look like the following:
>>
>> Value *AddExpression::codeGen() {
>> Value *l = left->codeGen();
>> Value *r = right->codeGen();
>> Value *result = new TempValue; // get unique temporary
>> emit(result->str() + " add " + l->str() + ", " r-str());
>> return result;
>> }
>>
>> Value *assignExpression::codeGen() {
>> Value *rval = rvalue->codeGen();
>> Value *lval = new NameValue(ident);
>> emit(lval->str() + " = " + rval->str()); // emit (silly) copy
>> instruction
>> return lval;
>> }
>>
>> What I have suggested to my students is to omit the (non-existent) copy
>> instruction
>> and use the "rval" above as a replacement for all future occurrences of
>> "ident."
>> i.e., something like the following:
>>
>> Value *assignExpression::codeGen() {
>> Value *rval = rvalue->codeGen();
>> update symbol table so that all future reference to "ident" are replaced
>> with rval
>> return rval;
>> }
>>
>> Using this scheme, the following
>> x = y + z
>> u = x * y + foo(x)
>> would be translated into
>> %0 = add %y, %z
>> %1 = mul %0, %y
>> %2 = call foo(%0)
>> %3 = add %1, %2
>>
>>
>> Is there a more obvious approach to avoiding "copy instructions"?
>
> The recommended approach to generating LLVM IR is simply not to try to
> generate code in SSA form; see
> http://llvm.org/docs/tutorial/LangImpl7.html#memory .
>
> -Eli
>
>
> _______________________________________________
> 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/20110423/b3cd4261/attachment.html>
More information about the llvm-dev
mailing list