Implement simple register assignment for inline asms. This allows us to compile:
authorChris Lattner <sabre@nondot.org>
Wed, 1 Feb 2006 18:59:47 +0000 (18:59 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 1 Feb 2006 18:59:47 +0000 (18:59 +0000)
commit4e4b576e2edfc7d40a3d7177c639acbe91cfd45f
tree7be41a7159abe524bab57d77188059268f41a734
parent20ea062192778c5cc1d05f771fbc58a6e99d753c
Implement simple register assignment for inline asms.  This allows us to compile:

int %test(int %A, int %B) {
  %C = call int asm "xyz $0, $1, $2", "=r,r,r"(int %A, int %B)
  ret int %C
}

into:

 (0x8906130, LLVM BB @0x8902220):
        %r2 = OR4 %r3, %r3
        %r3 = OR4 %r4, %r4
        INLINEASM <es:xyz $0, $1, $2>, %r2<def>, %r2, %r3
        %r3 = OR4 %r2, %r2
        BLR

which asmprints as:

_test:
        or r2, r3, r3
        or r3, r4, r4
        xyz $0, $1, $2      ;; need to print the operands now :)
        or r3, r2, r2
        blr

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25878 91177308-0d34-0410-b5e6-96231b3b80d8
lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp