embedded system and "target remote"

Yao Qi qiyaoltc@gmail.com
Tue Nov 8 11:14:00 GMT 2016


On Tue, Nov 8, 2016 at 10:30 AM, Matthias Pfaller <leo@marco.de> wrote:
> Hi,
>
> I'm currently implementing gdb server support for our cortex-m3/m4 based
> embedded systems.
>

Out of curiosity, is it like openocd?

>
> At the moment I'm implementing break points using the FPB unit.
>

I don't know much about FPB unit.

> I would like to setup the FPB unit at context switch time for thread
> specific break points. Is there a way to pass the referenced thread id
> with the 'Z' commands?
>
The remote protocol is not aware of thread specific breakpoint.
Thread specific breakpoint just works, "b foo if thread 1", but it is not
efficient.  What do you want to achieve?

> Is there a way to modify the behaviour of the break point commands to
> always reference the currently selected thread? Gobal breakpoints do not
> make sense in my usage case.

What do you mean by "always reference the currently selected thread"?
Always set thread specific breakpoint for current selected thread?
You can get current thread via $_thread and $_gthread,
https://sourceware.org/gdb/download/onlinedocs/gdb/Convenience-Vars.html

>
> Another thing I'd really like to do is to enforce non-stop and
> target-async from the target side. Is there a way to do this?

See the first paragraph in GDB manual below,
https://sourceware.org/gdb/download/onlinedocs/gdb/Remote-Non_002dStop.html

IIUC, GDB thinks async is on in remote (if the serial device is
async).

>
> regards, Matthias
>
> PS: How does gdb recoginze the initial stack frame? At the moment stack
> trace backs of stopped threads will not stop at correct frame.

Do you have an example?

-- 
Yao (齐尧)



More information about the Gdb mailing list