Mirror of the gdb mailing list
 help / color / mirror / Atom feed
From: Arnab Bhaduri <arnab@cadence.com>
To: "gdb@sourceware.org" <gdb@sourceware.org>,
	       "mark4th@gmail.com"	<mark4th@gmail.com>
Subject: RE: back into the thread....
Date: Thu, 14 Nov 2013 17:19:00 -0000	[thread overview]
Message-ID: <D3CD0638AD056342925227F12D6A2AB509225B0CDB@MAILSJ3.global.cadence.com> (raw)
In-Reply-To: <CAPGNrUUAaRjEgxj3j4DB3sFbzR2-GHPKjFD9jSeKOdpJy_Qmig@mail.gmail.com>

Perhaps gdb's attempt to inspect the stack is what is causing the "address 0" problem ? I would do this:

- immediately before stepping the "mov pc, r1" instruction, do "set debug remote 1".
- this will produce a verbose log of gdb's interaction with the target.
- post the log to this thread.

Arnab

> -----Original Message-----
> From: Mark Manning [mailto:mark4th@gmail.com]
> Sent: Wednesday, November 13, 2013 4:59 AM
> To: Phi Debian
> Cc: Sterling Augustine; gdb@sourceware.org
> Subject: Re: back into the thread....
> 
> On Wed, Nov 13, 2013 at 7:53 AM, Phi Debian <phi.debian@gmail.com>
> wrote:
> > On Wed, Nov 13, 2013 at 1:29 PM, Mark Manning <mark4th@gmail.com>
> wrote:
> >> On Wed, Nov 13, 2013 at 1:48 AM, Phi Debian <phi.debian@gmail.com>
> wrote:
> >>> Hi All,
> >>>
> >>> Off topic about gdb discution
> >>>
> >>
> >> Not off topic if it shows there is a bug in gdb which for the case of
> >> embedded arm (maybe only in Gentoo?) i believe there is.
> >
> > I meant I was doing an off topic answer (not you your post was off
> topic.
> >
> >> the arm processor im running these things on does have an icache and
> >> i know enough to clear it even if the person who gave me that code to
> >> test forgot that minor detail.
> >
> > Not so minor ;)
> >
> >
> >>
> >> no.  i stepi a "mov pc, r1" where r1 points to the new code.
> >> immediately after single stepping this opcode im presented with the
> >> error message about not being able to access address zero.
> >>
> >> I know the exact address that r1 was pointing to, it was 0xc000
> >> (which is very easy for a ye olde c64 coder to remember because it
> >> was the region of memory at address 49152 that was placed between the
> >> kernel and basic roms).
> >>
> >> Dump the disassembly of where the program counter points to and it
> >> exactly what my compiler was supposed to lay down at address 0xc000.
> >> There is no opcode misalignment.  There are no bogus unimplemented
> >> opcodes, the opcodes are exactly what should have been layed down by
> >> the compiler given the sources that were fed to it.  The program
> >> counter also points to address 0xc000.
> >
> > Again seeing at 0xc000 what you would like to see doesn't mean that
> > what you got in your icache.
> >
> > You could make your dynamic compiler generate few instruction into
> > your buffer followed by a tight loop (while(1);)  Then continue your
> > execution instead of stepi, if whats in the icache is what you expect,
> > then it will loop there and you can ^c to confirm, if you still got
> > xyz gdb error message, you are not executing what you think you would
> >
> > Dynamic (self modifiable) code is tricky, look at emacs generated
> > lisp, or at the kernel a.out loader code, they basically load buffer
> > with data taht will later be executed....
> >
> > Cheers,
> > Phi
> 
> im 90% certain the icache has been cleared...
> 
>   push r0                   @ point r0 at where new word starts in code
>   ldr r2, =old_dp
>   ldr r0, [r2, #BODY]       @ point where new word ends in code
>   ldr r1, =dp
>   ldr r1, [r1, #BODY]
>   str r1, [r2, #BODY]       @ new end = next start
> 
>   movw r7, #2               @ clear icache for selected range
>   movt r7, #15
>   mov r2, #0
>   swi 0
>   ...
> 
> btw, "dp" in forth is a variable called the dictionary pointer, this
> points to the memory where your next piece of compiled code will be
> stored. after compiling something the code compiled will lie between old
> dp and current dp - the above snippet theoretically clears the icache
> between those two memory ranges.
> 
> 
> --
> "When something can be read without effort, great effort has gone into
> its writing."
> 
> -- Enrique Jardiel Poncela --


  reply	other threads:[~2013-11-14 17:19 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-11-12 22:09 Mark Manning
2013-11-12 22:42 ` Sterling Augustine
2013-11-12 22:47   ` Sterling Augustine
2013-11-12 22:59     ` Mark Manning
2013-11-12 23:00       ` Mark Manning
     [not found]         ` <CAPGNrUUYWR7AOcFwTSxdEZa47E8iUJyfhzhWs+6jSc2+f4xqrg@mail.gmail.com>
2013-11-12 23:10           ` Sterling Augustine
2013-11-12 23:09     ` Mark Manning
2013-11-13  6:48     ` Phi Debian
2013-11-13 12:29       ` Mark Manning
2013-11-13 12:54         ` Phi Debian
2013-11-13 12:59           ` Mark Manning
2013-11-14 17:19             ` Arnab Bhaduri [this message]
2013-11-12 22:55   ` Mark Manning
2013-11-13 10:34     ` Pedro Alves

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=D3CD0638AD056342925227F12D6A2AB509225B0CDB@MAILSJ3.global.cadence.com \
    --to=arnab@cadence.com \
    --cc=gdb@sourceware.org \
    --cc=mark4th@gmail.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