This is the mail archive of the gcc-prs@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]

c++/2372: const struct parameter causes incorrect code with -O2.



>Number:         2372
>Category:       c++
>Synopsis:       const struct parameter causes incorrect code with -O2.
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    unassigned
>State:          open
>Class:          wrong-code
>Submitter-Id:   net
>Arrival-Date:   Fri Mar 23 20:26:01 PST 2001
>Closed-Date:
>Last-Modified:
>Originator:     suckfish@ihug.co.nz
>Release:        2001-03-20 snapshot.
>Organization:
>Environment:
Linux i686.
>Description:
The function "miscompiled" in the attached file is not
compiled correctly with -O2 -march=i686.

By inspecting the assembler output for the function "miscompiled", one can see that a temporary stack variable is loaded without being set. 

I discovered this in code using std::make_pair. The current prototype (with __GLIBCPP_RESOLVE_LIB_DEFECTS) has extraneous "const" decorations. Removing those would stop the use std::make_pair from triggering this bug. 
>How-To-Repeat:
Compile attached file on Linux with -O2 -march=i686.

Confirm bug by running program or visually inspecting assembler. 

Running the program prints "***Buggy***".  It should
print "OK".
>Fix:

>Release-Note:
>Audit-Trail:
>Unformatted:
----gnatsweb-attachment----
Content-Type: application/octet-stream; name="temp.cc"
Content-Transfer-Encoding: base64
Content-Disposition: attachment; filename="temp.cc"

Ly8gREVDTEFSQVRJT05TCgpzdHJ1Y3QgUmVjb3JkIHsKICAgUmVjb3JkIChpbnQgYmIpIDoKICAg
ICAgYiAoYmIpCiAgICAgIHsgfQogICBpbnQgZXh0cmE7ICAgLy8gSGF2aW5nIGFuIGV4dHJhIG1l
bWJlciBpbiByZWNvcmQgaXMgY3J1Y2lhbC4KICAgaW50IGI7Cn07CiAgICAgIApzdHJ1Y3QgQ29u
dGFpbmVyIHsKICAgUmVjb3JkIHJlY29yZDsKICAgLy8gVGhlIGNvbnN0IG9uIHRoZSBuZXh0IGxp
bmUgaXMgY3J1Y2lhbC4KICAgQ29udGFpbmVyICggY29uc3QgUmVjb3JkICBiKSA6IHJlY29yZChi
KSB7fQp9OwoKCnZvaWQgdXNlX3BhaXIgKGNvbnN0IENvbnRhaW5lciAmKTsKCi8vIE1JU0NPTVBJ
TEVEIEZVTkNUSU9OCnZvaWQgbWlzY29tcGlsZWQgKGludCBuKQp7CiAgIHVzZV9wYWlyIChDb250
YWluZXIgKG4pKTsKfQoKCi8vIFRFU1QgRk9SIENPUlJFQ1QgQkVIQVZJT1VSCgppbnQgbXlBcnJh
eVszXTsKaW50ICogaW50cCA9IG15QXJyYXk7Cgp2b2lkIHVzZV9wYWlyIChjb25zdCBDb250YWlu
ZXIgJiBjKQp7CiAgICppbnRwKysgPSBjLnJlY29yZC5iOwp9CgpleHRlcm4gIkMiIGludCBwcmlu
dGYgKGNvbnN0IGNoYXIgKiwuLi4pOwoKaW50IG1haW4oKQp7CiAgIG1pc2NvbXBpbGVkICgxMjM0
KTsKICAgbWlzY29tcGlsZWQgKDU0MzIpOwogICBtaXNjb21waWxlZCAoMjQ2OCk7CgogICBpZiAo
bXlBcnJheVswXSA9PSAxMjM0ICYmCiAgICAgICBteUFycmF5WzFdID09IDU0MzIgJiYKICAgICAg
IG15QXJyYXlbMl0gPT0gMjQ2OCkgewogICAgICBwcmludGYgKCJPay5cbiIpOwogICB9CiAgIGVs
c2UgewogICAgICBwcmludGYgKCIqKipCVUdHWSoqKlxuIik7CiAgIH0KICAgcmV0dXJuIDA7Cn0K


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]