public inbox for gcc-prs@sourceware.org help / color / mirror / Atom feed
From: Kazu Hirata <kazu@cs.umass.edu> To: kazu@gcc.gnu.org Cc: gcc-prs@gcc.gnu.org, Subject: Re: target/10205: Incorrect code generated for H8300 "normal" mode Date: Fri, 28 Mar 2003 15:07:00 -0000 [thread overview] Message-ID: <20030328131602.31350.qmail@sources.redhat.com> (raw) The following reply was made to PR target/10205; it has been noted by GNATS. From: Kazu Hirata <kazu@cs.umass.edu> To: dhananjayd@kpit.com Cc: gcc-bugs@gcc.gnu.org, mnmoran@bellsouth.net, gcc-gnats@gcc.gnu.org, gcc-patches@gcc.gnu.org Subject: Re: target/10205: Incorrect code generated for H8300 "normal" mode Date: Fri, 28 Mar 2003 08:14:31 -0500 (EST) Hi Dhananjay, > The patch below fixes this. If it is OK, it should be applied to > both mainline and 3.3 branch. Actually, I have come up with a basically identical patch, which I am asking the submitter to test in private mail. When he responds, I'll add your name in the ChangeLog entry. Mine looks like this, but I like your POINTER_SIZE approach. Kazu Hirata Index: h8300.c =================================================================== RCS file: /cvs/gcc/gcc/gcc/config/h8300/h8300.c,v retrieving revision 1.221 diff -c -r1.221 h8300.c *** h8300.c 22 Mar 2003 15:22:37 -0000 1.221 --- h8300.c 28 Mar 2003 03:33:36 -0000 *************** *** 1715,1723 **** int from, to; { int offset = 0; if (from == ARG_POINTER_REGNUM && to == FRAME_POINTER_REGNUM) ! offset = UNITS_PER_WORD + frame_pointer_needed * UNITS_PER_WORD; else if (from == RETURN_ADDRESS_POINTER_REGNUM && to == FRAME_POINTER_REGNUM) offset = frame_pointer_needed * UNITS_PER_WORD; else --- 1715,1726 ---- int from, to; { int offset = 0; + /* The number of bytes that the return address takes on the stack. */ + int pc_size = (((TARGET_H8300H || TARGET_H8300S) && TARGET_NORMAL_MODE) + ? (UNITS_PER_WORD / 2) : UNITS_PER_WORD); if (from == ARG_POINTER_REGNUM && to == FRAME_POINTER_REGNUM) ! offset = pc_size + frame_pointer_needed * UNITS_PER_WORD; else if (from == RETURN_ADDRESS_POINTER_REGNUM && to == FRAME_POINTER_REGNUM) offset = frame_pointer_needed * UNITS_PER_WORD; else *************** *** 1734,1744 **** offset += round_frame_size (get_frame_size ()); if (from == ARG_POINTER_REGNUM && to == STACK_POINTER_REGNUM) ! offset += UNITS_PER_WORD; /* Skip saved PC */ } - - if ((TARGET_H8300H || TARGET_H8300S) && TARGET_NORMAL_MODE) - offset -= 2; return offset; } --- 1737,1744 ---- offset += round_frame_size (get_frame_size ()); if (from == ARG_POINTER_REGNUM && to == STACK_POINTER_REGNUM) ! offset += pc_size; /* Skip saved PC */ } return offset; }
next reply other threads:[~2003-03-28 13:16 UTC|newest] Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top 2003-03-28 15:07 Kazu Hirata [this message] -- strict thread matches above, loose matches on Subject: below -- 2003-03-28 16:56 Kazu Hirata 2003-03-28 15:26 kazu 2003-03-28 7:56 Dhananjay R. Deshpande 2003-03-27 20:12 kazu 2003-03-27 13:12 kazu 2003-03-25 5:46 mnmoran
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=20030328131602.31350.qmail@sources.redhat.com \ --to=kazu@cs.umass.edu \ --cc=gcc-prs@gcc.gnu.org \ --cc=kazu@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).