Descriptioncmd/5g: fix regopt bug in copyprop
copyau1 was assuming that it could deduce the type of the
middle register p->reg from the type of the left or right
argument: in CMPF F1, F2, the p->reg==2 must be a D_FREG
because p->from is F1, and in CMP R1, R2, the p->reg==2 must
be a D_REG because p->from is R1.
This heuristic fails for CMP $0, R2, which was causing copyau1
not to recognize p->reg==2 as a reference to R2, which was
keeping it from properly renaming the register use when
substituting registers.
cmd/5c has the right approach: look at the opcode p->as to
decide the kind of register. It is unclear where 5g's copyau1
came from; perhaps it was an attempt to avoid expanding 5c's
a2type to include new instructions used only by 5g.
Copy a2type from cmd/5c, expand to include additional instructions,
and make it crash the compiler if asked about an instruction
it does not understand (avoid silent bugs in the future if new
instructions are added).
Should fix current arm build breakage.
While we're here, fix the print statements dumping the pred and
succ info in the asm listing to pass an int arg to %.4ud
(Prog.pc is a vlong now, due to the liblink merge).
Patch Set 1 #Patch Set 2 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 3 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 4 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 5 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 6 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 7 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 8 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 9 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 10 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 11 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 12 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 13 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 14 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 15 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 16 : diff -r 568c5852f48e https://code.google.com/p/go #Patch Set 17 : diff -r 51d9b0cf3b8d https://code.google.com/p/go #
MessagesTotal messages: 4
|