[prev in list] [next in list] [prev in thread] [next in thread] 

List:       gdb
Subject:    Re: ProcessRecord problem with recursion
From:       Hui Zhu <teawater () gmail ! com>
Date:       2009-03-21 8:54:12
Message-ID: daef60380903210154g532d541bod7dc6d27aa66f80c () mail ! gmail ! com
[Download RAW message or body]

Hi Marc,

I had post a patch for it in
http://sourceware.org/ml/gdb-patches/2009-03/msg00428.html

Thanks,
Hui

On Fri, Mar 20, 2009 at 09:13, Marc Khouzam <marc.khouzam@ericsson.com> wrote:
> Hi,
>
> I'm having problems with ProcessRecord and recursion.
> It looks like the reverse-next operation behaves like
> reverse-step when dealing with a recursive method.
>
> I have GDB HEAD from the 18th of March, with the patches included in
> http://sourceware.org/ml/gdb-patches/2009-03/msg00375.html
> http://sourceware.org/ml/gdb-patches/2009-03/msg00005.html
> http://sourceware.org/ml/gdb-patches/2009-01/msg00444.html
>
> Here is a program and session that shows the problem:
>
> GNU gdb (GDB) 6.8.50.20090318-cvs
> [...]
> (gdb) l
> 1       int factorial(int x) {
> 2          if (x == 1) return 1;
> 3          int result = x * factorial(x-1);
> 4          return result;
> 5       }
> 6
> 7       int main() {
> 8           factorial(5);
> 9           return 0;
> 10      }
> (gdb) start
> Temporary breakpoint 1 at 0x804847b: file a.cc, line 8.
> Starting program: /local/home/lmckhou/testing/a.out
>
> Temporary breakpoint 1, main () at a.cc:8
> 8           factorial(5);
> (gdb) rec
> (gdb) s
> factorial (x=5) at a.cc:2
> 2          if (x == 1) return 1;
> (gdb) n
> 3          int result = x * factorial(x-1);
> (gdb) n
> 4          return result;
> (gdb) rn
> factorial (x=4) at a.cc:5
> 5       }
>
> Notice how the reverse-next(rn) command jumped to the end
> of the next factorial method on the stack (x=4 instead of x=5).
>
> Thanks
>
> Marc
>
>

[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic