Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code | Sign in
(637)

Issue 62730043: code review 62730043: cmd/5g: fix regopt bug in copyprop (Closed)

Can't Edit
Can't Publish+Mail
Start Review
Created:
11 years, 2 months ago by rsc
Modified:
11 years, 2 months ago
Reviewers:
dave, ken3
CC:
ken2, golang-codereviews
Visibility:
Public.

Description

cmd/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 #

Unified diffs Side-by-side diffs Delta from patch set Stats (+73 lines, -29 lines) Patch
M src/cmd/5g/peep.c View 1 1 chunk +66 lines, -22 lines 0 comments Download
M src/cmd/5g/reg.c View 1 2 chunks +3 lines, -3 lines 0 comments Download
M src/cmd/6g/reg.c View 1 1 chunk +2 lines, -2 lines 0 comments Download
M src/cmd/8g/reg.c View 1 1 chunk +2 lines, -2 lines 0 comments Download

Messages

Total messages: 4
rsc
Hello ken2 (cc: golang-codereviews@googlegroups.com), I'd like you to review this change to https://code.google.com/p/go
11 years, 2 months ago (2014-02-13 03:54:53 UTC) #1
rsc
*** Submitted as https://code.google.com/p/go/source/detail?r=6d069d383628 *** cmd/5g: fix regopt bug in copyprop copyau1 was assuming that ...
11 years, 2 months ago (2014-02-13 03:55:03 UTC) #2
dave_cheney.net
Thanks Russ On Thu, Feb 13, 2014 at 2:55 PM, <rsc@golang.org> wrote: > *** Submitted ...
11 years, 2 months ago (2014-02-13 03:55:34 UTC) #3
ken3
11 years, 2 months ago (2014-02-14 09:57:43 UTC) #4
Message was sent while issue was closed.
On 2014/02/13 03:55:34, dfc wrote:
> Thanks Russ
> 
> 
> On Thu, Feb 13, 2014 at 2:55 PM, <mailto:rsc@golang.org> wrote:
> 
> > *** Submitted as
> > https://code.google.com/p/go/source/detail?r=6d069d383628 ***
> >
> >
> > cmd/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).
> >
> > TBR=ken2
> > CC=golang-codereviews
> > https://codereview.appspot.com/62730043
> >
> >
> > https://codereview.appspot.com/62730043/
> >
> >
> > --
> > You received this message because you are subscribed to the Google Groups
> > "golang-codereviews" group.
> > To unsubscribe from this group and stop receiving emails from it, send an
> > email to mailto:golang-codereviews+unsubscribe@googlegroups.com.
> > For more options, visit https://groups.google.com/groups/opt_out.
> >

LGTM
Sign in to reply to this message.

Powered by Google App Engine
RSS Feeds Recent Issues | This issue
This is Rietveld f62528b