public inbox for gcc-prs@sourceware.org
help / color / mirror / Atom feed
From: enrico.scholz@informatik.tu-chemnitz.de
To: gcc-gnats@gcc.gnu.org
Subject: optimization/8896: '-mcpu=xscale -fno-strict-aliasing -O2' generates wrong code
Date: Tue, 10 Dec 2002 15:46:00 -0000	[thread overview]
Message-ID: <20021210233937.23727.qmail@sources.redhat.com> (raw)


>Number:         8896
>Category:       optimization
>Synopsis:       '-mcpu=xscale -fno-strict-aliasing -O2' generates wrong code
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    unassigned
>State:          open
>Class:          wrong-code
>Submitter-Id:   net
>Arrival-Date:   Tue Dec 10 15:46:01 PST 2002
>Closed-Date:
>Last-Modified:
>Originator:     Enrico Scholz
>Release:        gcc-3.2.1
>Organization:
>Environment:
Reading specs from /usr/lib/gcc-lib/arm-linux/3.2.1/specs
Configured with: ../configure --host=i386-redhat-linux --target=arm-linux --prefix=/usr --mandir=/usr/share/man --disable-checking --with-cpu=strongarm1100 --enable-languages=c
Thread model: posix
gcc version 3.2.1
>Description:
The arm-linux-gcc miscompiles XScale linux-kernels (the attached testcase is derived from fs/binfmt_elf.c of linux-2.5.49 + various ARM patches).

Because of other environment-problems, I do not have a complete test-program, but the miscompilation is visible in the disassembled .o-file. The interesting code is:

 ---- objdump -d binfmt_elf.o
  70:   e3a04002        mov     r4, #2  ; 0x2
  7c:   e0844004        add     r4, r4, r4
  84:   e1a0e004        mov     lr, r4
  e0:   e50be0b0        str     lr, [fp, -#176]


These statements are the result of:

|  60          elf_info[ei_index++] =  3; ...

which is wrong. Other ELF-tags are incorrect too, but this is the most obvious one.
>How-To-Repeat:
Compile the testprogram with

| arm-linux-gcc -O2 -fno-strict-aliasing -mcpu=xscale -c binfmt_elf.c

Watch the output with 'objdump -d binfmt_elf.o'
>Fix:

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

dHlwZWRlZiBzdHJ1Y3QgZWxmMzJfaGRyewogIHVuc2lnbmVkIGludCBlX2VudHJ5OwogIHVuc2ln
bmVkIGludCBlX3Bob2ZmOwogIHVuc2lnbmVkIHNob3J0IGVfcGhudW07Cn0gRWxmMzJfRWhkcjsK
CmV4dGVybiB1bnNpZ25lZCBpbnQgZWxmX2h3Y2FwOwpleHRlcm4gY2hhciBlbGZfcGxhdGZvcm1b
XTsKCnN0cnVjdCBsaW51eF9iaW5wcm17CiAgICAgICAgdW5zaWduZWQgbG9uZyBwOwogICAgICAg
IGludCBhcmdjLCBlbnZjOwp9OwoKc3RydWN0IHRhc2tfc3RydWN0IHsKICAgICAgICB1bnNpZ25l
ZCBpbnQgdWlkLGV1aWQ7CiAgICAgICAgdW5zaWduZWQgaW50IGdpZCxlZ2lkOwp9OwoKc3RydWN0
IHRocmVhZF9pbmZvIHsKICAgICAgICBzdHJ1Y3QgdGFza19zdHJ1Y3QgKnRhc2s7Cn07CgpzdGF0
aWMgaW5saW5lIHN0cnVjdCB0aHJlYWRfaW5mbyAqY3VycmVudF90aHJlYWRfaW5mbyh2b2lkKQp7
CiAgICAgICAgcmVnaXN0ZXIgdW5zaWduZWQgbG9uZyBzcCBhc20gKCJzcCIpOwogICAgICAgIHJl
dHVybiAoc3RydWN0IHRocmVhZF9pbmZvICopKHNwICYgfjB4MWZmZik7Cn0KCnN0YXRpYyBpbmxp
bmUgc3RydWN0IHRhc2tfc3RydWN0ICpnZXRfY3VycmVudCh2b2lkKQp7IAogICAgICAgIHJldHVy
biBjdXJyZW50X3RocmVhZF9pbmZvKCktPnRhc2s7Cn0gCgpleHRlcm4gdm9pZApkb2l0KHVuc2ln
bmVkIGxvbmcgKik7Cgp2b2lkCmNyZWF0ZV9lbGZfdGFibGVzKHN0cnVjdCBsaW51eF9iaW5wcm0g
KmJwcm0sIHN0cnVjdCBlbGYzMl9oZHIgKiBleGVjLAogICAgICAgICAgICAgICAgaW50IGludGVy
cF9hb3V0LCB1bnNpZ25lZCBsb25nIGxvYWRfYWRkciwKICAgICAgICAgICAgICAgIHVuc2lnbmVk
IGxvbmcgaW50ZXJwX2xvYWRfYWRkcikKewogICAgICAgIHVuc2lnbmVkIGxvbmcgcCA9IGJwcm0t
PnA7CiAgICAgICAgaW50IGFyZ2MgPSBicHJtLT5hcmdjOwogICAgICAgIGludCBlbnZjID0gYnBy
bS0+ZW52YzsKICAgICAgICB1bnNpZ25lZCBsb25nICpzcCwgKnVfcGxhdGZvcm07CiAgICAgICAg
Y29uc3QgY2hhciAqa19wbGF0Zm9ybSA9IChlbGZfcGxhdGZvcm0pOwogICAgICAgIGludCBpdGVt
czsKICAgICAgICB1bnNpZ25lZCBsb25nIGVsZl9pbmZvWzQwXTsKICAgICAgICBpbnQgZWlfaW5k
ZXggPSAwOwogICAgICAgIHVfcGxhdGZvcm0gPSAoKHZvaWQgKikwKTsKCiAgICAgICAgaWYgKGtf
cGxhdGZvcm0pIHsKICAgICAgICAgICAgICAgIHVfcGxhdGZvcm0gPSAodW5zaWduZWQgbG9uZyAq
KSBwIC09IDE7CiAgICAgICAgfQoKICAgICAgICBlbGZfaW5mb1tlaV9pbmRleCsrXSA9IDE2OyBl
bGZfaW5mb1tlaV9pbmRleCsrXSA9IChlbGZfaHdjYXApOwogICAgICAgIGVsZl9pbmZvW2VpX2lu
ZGV4KytdID0gIDY7IGVsZl9pbmZvW2VpX2luZGV4KytdID0gNDA5NjsKICAgICAgICBlbGZfaW5m
b1tlaV9pbmRleCsrXSA9IDE3OyBlbGZfaW5mb1tlaV9pbmRleCsrXSA9ICgxMDApOwogICAgICAg
IGVsZl9pbmZvW2VpX2luZGV4KytdID0gIDM7IGVsZl9pbmZvW2VpX2luZGV4KytdID0gbG9hZF9h
ZGRyICsgZXhlYy0+ZV9waG9mZjsKICAgICAgICBlbGZfaW5mb1tlaV9pbmRleCsrXSA9ICA0OyBl
bGZfaW5mb1tlaV9pbmRleCsrXSA9IDMyOwogICAgICAgIGVsZl9pbmZvW2VpX2luZGV4KytdID0g
IDU7IGVsZl9pbmZvW2VpX2luZGV4KytdID0gZXhlYy0+ZV9waG51bTsKICAgICAgICBlbGZfaW5m
b1tlaV9pbmRleCsrXSA9ICA3OyBlbGZfaW5mb1tlaV9pbmRleCsrXSA9IGludGVycF9sb2FkX2Fk
ZHI7CiAgICAgICAgZWxmX2luZm9bZWlfaW5kZXgrK10gPSAgODsgZWxmX2luZm9bZWlfaW5kZXgr
K10gPSAwOwogICAgICAgIGVsZl9pbmZvW2VpX2luZGV4KytdID0gIDk7IGVsZl9pbmZvW2VpX2lu
ZGV4KytdID0gZXhlYy0+ZV9lbnRyeTsKICAgICAgICBlbGZfaW5mb1tlaV9pbmRleCsrXSA9IDEx
OyBlbGZfaW5mb1tlaV9pbmRleCsrXSA9ICh1bnNpZ25lZCBsb25nKSAoZ2V0X2N1cnJlbnQoKSkt
PnVpZDsKICAgICAgICBlbGZfaW5mb1tlaV9pbmRleCsrXSA9IDEyOyBlbGZfaW5mb1tlaV9pbmRl
eCsrXSA9ICh1bnNpZ25lZCBsb25nKSAoZ2V0X2N1cnJlbnQoKSktPmV1aWQ7CiAgICAgICAgZWxm
X2luZm9bZWlfaW5kZXgrK10gPSAxMzsgZWxmX2luZm9bZWlfaW5kZXgrK10gPSAodW5zaWduZWQg
bG9uZykgKGdldF9jdXJyZW50KCkpLT5naWQ7CiAgICAgICAgZWxmX2luZm9bZWlfaW5kZXgrK10g
PSAxNDsgZWxmX2luZm9bZWlfaW5kZXgrK10gPSAodW5zaWduZWQgbG9uZykgKGdldF9jdXJyZW50
KCkpLT5lZ2lkOwogICAgICAgIGlmIChrX3BsYXRmb3JtKSB7CiAgICAgICAgICAgICAgICBlbGZf
aW5mb1tlaV9pbmRleCsrXSA9IDE1OyBlbGZfaW5mb1tlaV9pbmRleCsrXSA9ICh1bnNpZ25lZCBs
b25nKShsb25nKXVfcGxhdGZvcm07CiAgICAgICAgfQogICAgICAgIGVsZl9pbmZvW2VpX2luZGV4
KytdID0gIDA7IGVsZl9pbmZvW2VpX2luZGV4KytdID0gMDsKCiAgICAgICAgc3AgPSAoKHVuc2ln
bmVkIGxvbmcgKikocCkgLSAoZWlfaW5kZXgpKTsKCiAgICAgICAgaXRlbXMgPSAoYXJnYyArIDEp
ICsgKGVudmMgKyAxKTsKICAgICAgICBpZiAoaW50ZXJwX2FvdXQpIHsKICAgICAgICAgICAgICAg
IGl0ZW1zICs9IDM7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgICAgIGl0ZW1zICs9IDE7
CiAgICAgICAgfQogICAgICAgIGJwcm0tPnAgPSAoKCh1bnNpZ25lZCBsb25nKSAoc3AgLSBpdGVt
cykpICZ+IDE1VUwpOwoKCWRvaXQoZWxmX2luZm8pOwp9Cg==


             reply	other threads:[~2002-12-10 23:46 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2002-12-10 15:46 enrico.scholz [this message]
2002-12-11  9:57 rearnsha
2002-12-12  7:03 rearnsha
2002-12-12  7:16 Richard Earnshaw
2002-12-16 10:06 Enrico Scholz
2003-03-22 10:05 steven
2003-03-22 13:36 Richard Earnshaw
2003-03-22 13:36 Steven Bosscher
2003-03-22 13:54 steven
2003-05-14 17:46 Dara Hazeghi
2003-05-15 18:46 Daniel Jacobowitz

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20021210233937.23727.qmail@sources.redhat.com \
    --to=enrico.scholz@informatik.tu-chemnitz.de \
    --cc=gcc-gnats@gcc.gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).