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==
next 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: linkBe 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).