Remove the link register from the GPR classes on PowerPC.
authorBill Schmidt <wschmidt@linux.vnet.ibm.com>
Wed, 27 Mar 2013 02:40:14 +0000 (02:40 +0000)
committerBill Schmidt <wschmidt@linux.vnet.ibm.com>
Wed, 27 Mar 2013 02:40:14 +0000 (02:40 +0000)
commita1b72d0f6a6b3db28cbec2500112d1914bae9662
tree6ed9026a51f5d0db81d881f31106c2285579080a
parentd00294483e77932bf5b9cf46262759554373ef79
Remove the link register from the GPR classes on PowerPC.

Some implementation detail in the forgotten past required the link
register to be placed in the GPRC and G8RC register classes.  This is
just wrong on the face of it, and causes several extra intersection
register classes to be generated.  I found this was having evil
effects on instruction scheduling, by causing the wrong register class
to be consulted for register pressure decisions.

No code generation changes are expected, other than some minor changes
in instruction order.  Seven tests in the test bucket required minor
tweaks to adjust to the new normal.

llvm-svn: 178114
llvm/lib/Target/PowerPC/PPCRegisterInfo.td
llvm/test/CodeGen/PowerPC/jaggedstructs.ll
llvm/test/CodeGen/PowerPC/structsinmem.ll
llvm/test/CodeGen/PowerPC/structsinregs.ll
llvm/test/CodeGen/PowerPC/tls-gd.ll
llvm/test/CodeGen/PowerPC/tls-ld-2.ll
llvm/test/CodeGen/PowerPC/tls-ld.ll
llvm/test/CodeGen/PowerPC/tls.ll