Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: Joel Brobecker <brobecker@adacore.com>
To: Mark Kettenis <mark.kettenis@xs4all.nl>
Cc: gdb-patches@sourceware.org
Subject: Re: PING: [RFA/i386] 2 more patterns in i386_analyze_stack_align
Date: Fri, 05 Jan 2007 14:36:00 -0000	[thread overview]
Message-ID: <20070105143728.GV17211@adacore.com> (raw)
In-Reply-To: <200701051104.l05B4xl1024647@brahms.sibelius.xs4all.nl>

[-- Attachment #1: Type: text/plain, Size: 486 bytes --]

> Ah wait, that's true even for "absolute" code.  I had a quick look at
> the GCC code and it seems to always treat %ebx as callee-saved.  So
> I'm happy with leaving it out, but you could add a comment saying so
> to prevent us from having this same discussion in about two months
> ;-).

Sure! How does the attached patch look? Does it contain enough info?

2007-01-05  Joel Brobecker  <brobecker@adacore.com>

        * i386-tdep.c (i386_analyze_stack_align): Add comment.

-- 
Joel

[-- Attachment #2: comment.diff --]
[-- Type: text/plain, Size: 840 bytes --]

Index: i386-tdep.c
===================================================================
RCS file: /cvs/src/src/gdb/i386-tdep.c,v
retrieving revision 1.227
diff -u -p -r1.227 i386-tdep.c
--- i386-tdep.c	3 Jan 2007 19:01:25 -0000	1.227
+++ i386-tdep.c	5 Jan 2007 14:22:11 -0000
@@ -497,6 +497,10 @@ static CORE_ADDR
 i386_analyze_stack_align (CORE_ADDR pc, CORE_ADDR current_pc,
 			  struct i386_frame_cache *cache)
 {
+  /* The register used by the compiler to perform the stack re-alignment 
+     is, in order of preference, either %ecx, %edx, or %eax. GCC should
+     never use %ebx as it always treats it as callee-saved, whereas
+     the compiler can only use caller-saved registers.  */
   static const gdb_byte insns_ecx[10] = { 
     0x8d, 0x4c, 0x24, 0x04,	/* leal  4(%esp), %ecx */
     0x83, 0xe4, 0xf0,		/* andl  $-16, %esp */

  reply	other threads:[~2007-01-05 14:36 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-12-20 10:49 Joel Brobecker
2006-12-31  6:08 ` PING: " Joel Brobecker
2006-12-31 12:15   ` Mark Kettenis
2006-12-31 14:39     ` Joel Brobecker
2007-01-05  6:48     ` Joel Brobecker
2007-01-05 11:05       ` Mark Kettenis
2007-01-05 14:36         ` Joel Brobecker [this message]
2007-01-05 14:58           ` Mark Kettenis
2007-01-05 16:42             ` Joel Brobecker

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=20070105143728.GV17211@adacore.com \
    --to=brobecker@adacore.com \
    --cc=gdb-patches@sourceware.org \
    --cc=mark.kettenis@xs4all.nl \
    /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