aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2001-04-25 14:56:54 -0700
committerRichard Henderson <rth@gcc.gnu.org>2001-04-25 14:56:54 -0700
commit84e306b45a480df7ece37c21419192b243a4c322 (patch)
tree3ee320e66a76e12536715c4ad5ede80409517f64 /gcc
parentdd6f366250e93414a7996ec8d28a9332a1ce8478 (diff)
downloadgcc-84e306b45a480df7ece37c21419192b243a4c322.zip
gcc-84e306b45a480df7ece37c21419192b243a4c322.tar.gz
gcc-84e306b45a480df7ece37c21419192b243a4c322.tar.bz2
i386.c (ix86_expand_epilogue): Properly compute size of registers to restore along non eh_return path.
* config/i386/i386.c (ix86_expand_epilogue): Properly compute size of registers to restore along non eh_return path. From-SVN: r41555
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/config/i386/i386.c10
2 files changed, 13 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 323dc83..7e58efa 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2001-04-25 Richard Henderson <rth@redhat.com>
+
+ * config/i386/i386.c (ix86_expand_epilogue): Properly compute size
+ of registers to restore along non eh_return path.
+
2001-04-25 Jakub Jelinek <jakub@redhat.com>
* c-format.c (check_format_info_recurse): Handle
diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
index 5e5b5a5..a0e40ba 100644
--- a/gcc/config/i386/i386.c
+++ b/gcc/config/i386/i386.c
@@ -2591,8 +2591,14 @@ ix86_expand_epilogue (style)
ix86_compute_frame_layout (&frame);
- /* Calculate start of saved registers relative to ebp. */
- offset = -frame.nregs * UNITS_PER_WORD;
+ /* Calculate start of saved registers relative to ebp. Special care
+ must be taken for the normal return case of a function using
+ eh_return: the eax and edx registers are marked as saved, but not
+ restored along this path. */
+ offset = frame.nregs;
+ if (current_function_calls_eh_return && style != 2)
+ offset -= 2;
+ offset *= -UNITS_PER_WORD;
#ifdef FUNCTION_BLOCK_PROFILER_EXIT
if (profile_block_flag == 2)