public inbox for gdb@sourceware.org
 help / color / mirror / Atom feed
From: "Eli Zaretskii" <eliz@gnu.org>
To: Daniel Jacobowitz <drow@false.org>, gdb@sources.redhat.com
Cc: Reiner.Steib@gmx.de
Subject: Re: Variable "foo" is not available
Date: Mon, 04 Apr 2005 05:14:00 -0000	[thread overview]
Message-ID: <01c538d4$Blat.v2.4$b261c020@zahav.net.il> (raw)
In-Reply-To: <20050402210541.GA16758@nevyn.them.org> (message from Daniel Jacobowitz on Sat, 2 Apr 2005 16:05:42 -0500)

> Date: Sat, 2 Apr 2005 16:05:42 -0500
> From: Daniel Jacobowitz <drow@false.org>
> Cc: gdb@sources.redhat.com, Reiner.Steib@gmx.de
> 
> > We are talking about function call arguments here, not just about any
> > local variables.  Can you tell what compiler optimizations could cause
> > what Reiner reported: that the first argument is available to GDB, but
> > the second is not?
> 
> Very easily.  Suppose you have two incoming arguments in registers; GCC
> will do this automatically for static functions even on i386, which
> normally uses a stack convention.  The first is used after a function
> call, so it is preserved by saving it to the stack.  The second is not
> used after the function call, so the compiler has no reason to allocate
> a save slot for it, and no reason to store it to memory before the
> function call.

The functions present in Reiner's backtraces are not static, they are
external, with the exception of funcall_lambda.  I don't have access
to an x86_64 machine, but at least on an IA32 x86 architecture the
code produced by GCC 3.4.3 for these function calls is quite
straightforward (see one example below), and with GDB 6.3 I couldn't
reproduce the "arg not available" message.

> With stack-based argument passing, GCC may be claiming an argument is
> unavailable when the function's local copy is dead, when a copy still
> exists on the stack somewhere.  I don't know if it will do that or not.
> GDB can not assume that the argument is available in the incoming stack
> slot, since it could be reused for other data.

What, if any, would be the expression of this in the machine code?

Also, I don't quite understand how can a stack slot of a function call
argument be reused before the function returns.  Isn't that slot
outside the function's frame?  Reusing it would be a violation of the
ABI, right?

Here's the disassembly of one of the frames from Reiner's backtrace:
funcall_lambda calls Fbyte_code.  I disassembled on a 32-bit x86
machine (Reiner, perhaps you could show the disassembly on yours).
The source code is:

      val = Fbyte_code (AREF (fun, COMPILED_BYTECODE),
			AREF (fun, COMPILED_CONSTANTS),
			AREF (fun, COMPILED_STACK_DEPTH));
    }

  return unbind_to (count, val);

Reiner's backtrace is:

#2  0x000000000057a1d4 in Fbyte_code (bytestr=9727377, vector=Variable "vector" is not available.
)
    at [...]/emacs/src/bytecode.c:531
#3  0x000000000054d59d in funcall_lambda (fun=29850740, nargs=1, 
    arg_vector=0x7fbfffb198)
    at [...]/emacs/src/eval.c:2974

Here's the disassembly from my machine, with the PC location marked
by "<<<<<<":

0x000c219e <funcall_lambda+510>:        push   %eax
0x000c219f <funcall_lambda+511>:        mov    0x14(%ebx),%edi
0x000c21a2 <funcall_lambda+514>:        push   %edi
0x000c21a3 <funcall_lambda+515>:        mov    0x10(%ebx),%esi
0x000c21a6 <funcall_lambda+518>:        push   %esi
0x000c21a7 <funcall_lambda+519>:        mov    0xc(%ebx),%ebx
0x000c21aa <funcall_lambda+522>:        push   %ebx
0x000c21ab <funcall_lambda+523>:        call   0xed130 <Fbyte_code>
0x000c21b0 <funcall_lambda+528>:        pop    %edx  <<<<<<
0x000c21b1 <funcall_lambda+529>:        pop    %ecx
0x000c21b2 <funcall_lambda+530>:        push   %eax
0x000c21b3 <funcall_lambda+531>:        mov    0xffffffec(%ebp),%eax
0x000c21b6 <funcall_lambda+534>:        push   %eax
0x000c21b7 <funcall_lambda+535>:        call   0xc0dc0 <unbind_to>
0x000c21bc <funcall_lambda+540>:        jmp    0xc201c <funcall_lambda+124>

This is quite traditional stack-based argument passing, unless I'm
missing something.

The code produced for the call to funcall_lambda (not shown) does pass
some arguments via registers, but I still am able to see all the
arguments in the backtrace.

  reply	other threads:[~2005-04-04  5:14 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-04-01 16:40 Reiner Steib
2005-04-01 17:19 ` Daniel Jacobowitz
2005-04-02  9:49   ` Eli Zaretskii
2005-04-02 13:53     ` Reiner Steib
2005-04-02 14:27       ` Daniel Jacobowitz
2005-04-06 16:25         ` Reiner Steib
2005-04-02 14:26     ` Daniel Jacobowitz
2005-04-02 18:17       ` Eli Zaretskii
2005-04-02 18:40         ` Daniel Jacobowitz
2005-04-02 20:58           ` Eli Zaretskii
2005-04-02 21:05             ` Daniel Jacobowitz
2005-04-04  5:14               ` Eli Zaretskii [this message]
2005-04-04  6:00                 ` Mark Kettenis
2005-04-04  7:58                 ` Daniel THOMPSON
2005-04-04 19:28                   ` Eli Zaretskii
2005-04-04 13:37                 ` Daniel Jacobowitz
2005-04-04 19:35                   ` Eli Zaretskii
2005-04-04 19:41                     ` Daniel Jacobowitz
2005-04-03 18:16           ` Reiner Steib
2005-04-08 11:05       ` Eli Zaretskii
2005-04-04  9:26     ` Reiner Steib

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='01c538d4$Blat.v2.4$b261c020@zahav.net.il' \
    --to=eliz@gnu.org \
    --cc=Reiner.Steib@gmx.de \
    --cc=drow@false.org \
    --cc=gdb@sources.redhat.com \
    /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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).