public inbox for gcc-prs@sourceware.org
help / color / mirror / Atom feed
* Re: target/6040: [ARM] interrupt attribute generats wrong code (3.1-cvs)
@ 2003-05-17  3:06 Dara Hazeghi
  0 siblings, 0 replies; 3+ messages in thread
From: Dara Hazeghi @ 2003-05-17  3:06 UTC (permalink / raw)
  To: nobody; +Cc: gcc-prs

The following reply was made to PR target/6040; it has been noted by GNATS.

From: Dara Hazeghi <dhazeghi@yahoo.com>
To: tori@unhappy.mine.nu, gcc-gnats@gcc.gnu.org, nobody@gcc.gnu.org
Cc:  
Subject: Re: target/6040: [ARM] interrupt attribute generats wrong code (3.1-cvs)
Date: Fri, 16 May 2003 19:59:20 -0700

 http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit- 
 trail&database=gcc&pr=6040
 
 Hello,
 
 here's another bug against a fairly old version of gcc. Gcc 3.3  
 produces:
          .file   "junk.c"
          .text
          .align  2
          .global foo
          .type   foo, %function
 foo:
          @ Interrupt Service Routine.
          @ args = 0, pretend = 0, frame = 4
          @ frame_needed = 1, uses_anonymous_args = 0
          str     ip, [sp, #-4]!
          mov     ip, sp
          sub     lr, lr, #4
          stmfd   sp!, {r3, fp, ip, lr, pc}
          sub     fp, ip, #4
          sub     sp, sp, #4
          mov     r3, #0
          str     r3, [fp, #-24]
          ldmea   fp, {r3, fp, ip, pc}^
          .size   foo, .-foo
          .ident  "GCC: (GNU) 3.3 20030508 (prerelease)"
 
 with gcc mainline:
          .file   "junk.c"
          .text
          .align  2
          .global foo
          .type   foo, %function
 foo:
          @ Interrupt Service Routine.
          @ args = 0, pretend = 0, frame = 4
          @ frame_needed = 1, uses_anonymous_args = 0
          str     ip, [sp, #-4]!
          mov     ip, sp
          stmfd   sp!, {r3, fp, ip, lr, pc}
          sub     fp, ip, #4
          sub     sp, sp, #4
          mov     r3, #0
          str     r3, [fp, #-24]
          ldmea   fp, {r3, fp, sp, lr}
          ldmfd   sp!, {ip}
          subs    pc, lr, #4
          .size   foo, .-foo
          .ident  "GCC: (GNU) 3.4 20030508 (experimental)"
 
 can you determine if this is correct? Thanks,
 
 Dara
 


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: target/6040: ARM interrupt attribute generats wrong code (3.1-cvs)
@ 2002-04-18  9:04 mmitchel
  0 siblings, 0 replies; 3+ messages in thread
From: mmitchel @ 2002-04-18  9:04 UTC (permalink / raw)
  To: gcc-bugs, gcc-prs, nobody, tori

Synopsis: ARM interrupt attribute generats wrong code (3.1-cvs)

State-Changed-From-To: open->analyzed
State-Changed-By: mmitchel
State-Changed-When: Thu Apr 18 09:04:02 2002
State-Changed-Why:
    Confirmed.

http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=6040


^ permalink raw reply	[flat|nested] 3+ messages in thread

* target/6040: ARM interrupt attribute generats wrong code (3.1-cvs)
@ 2002-03-22  8:06 tori
  0 siblings, 0 replies; 3+ messages in thread
From: tori @ 2002-03-22  8:06 UTC (permalink / raw)
  To: gcc-gnats


>Number:         6040
>Category:       target
>Synopsis:       ARM interrupt attribute generats wrong code (3.1-cvs)
>Confidential:   no
>Severity:       critical
>Priority:       high
>Responsible:    unassigned
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Fri Mar 22 08:06:01 PST 2002
>Closed-Date:
>Last-Modified:
>Originator:     Tobias Ringstrom
>Release:        gcc version 3.1 20020321 (prerelease)
>Organization:
>Environment:
Crosscompiler for arm-elf
>Description:
Compile the following code with "arm-elf-gcc -S"

void foo(void) __attribute__((__interrupt__));
void foo()
{
        int a=0;
}

gives the following assembler code:

        .file   "tmp2.c"
        .text
        .align  2
        .global foo
        .type   foo,function
foo:
        @ Interrupt Service Routine.
        @ args = 0, pretend = 0, frame = 4
        @ frame_needed = 1, uses_anonymous_args = 0
        str     ip, [sp, #-4]!
        mov     ip, sp
        sub     lr, lr, #4
        stmfd   sp!, {r3, fp, ip, lr, pc}
        sub     fp, ip, #4
        sub     sp, sp, #4
        mov     r3, #0
        str     r3, [fp, #-24]
        ldmea   fp, {r3, fp, ip, pc}^
.Lfe1:
        .size   foo,.Lfe1-foo
        .ident  "GCC: (GNU) 3.1 20020321 (prerelease)"

Major problem:
The stack pointer (sp) is never restored!

Comment/question:
There are four lost bytes, but that might be due to alignment of the stack.  Is it?

/Tobias
>How-To-Repeat:
See Description above!
>Fix:

>Release-Note:
>Audit-Trail:
>Unformatted:


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2003-05-17  3:06 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-05-17  3:06 target/6040: [ARM] interrupt attribute generats wrong code (3.1-cvs) Dara Hazeghi
  -- strict thread matches above, loose matches on Subject: below --
2002-04-18  9:04 target/6040: ARM " mmitchel
2002-03-22  8:06 tori

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).