From: "Andrea Corallo via gdb-patches" <gdb-patches@sourceware.org>
To: "gdb-patches@sourceware.org" <gdb-patches@sourceware.org>
Subject: [PATCH] sim: microblaze: breakpoint inst check + a couple of questions
Date: Wed, 07 Jun 2017 06:19:00 -0000 [thread overview]
Message-ID: <486877990.6234663.1496816355818@mail.yahoo.com> (raw)
In-Reply-To: <5416db91-3a90-7f4a-c901-97921aab1f9c@yahoo.it>
Any commnet on this?
Best
Andrea
Il Domenica 4 Giugno 2017 10:14, Andrea Corallo <andrea_corallo@yahoo.it> ha scritto:
Ok understand.
I think the best solution for now would be to apply this one here.
In the simulator we stop executing just when we find a brki rD, 0x18 as
the manual says, all other brk instructions are normal sw breakpoints
and are gonna be executed.
But we still want to check against any software breakpoint in the
delayed slot cause is bad anyway.
The next step will be to let gdb insert brki r0, 0x18 instead of brki
r14, 96 when running on the simulator.
Does all this make sense?
I understand the sim was not developed since a while, anyway if
appreciated I can put some effort to try to put it in a working state
again. I'll have some more question but I guess is better to go step by
step.
Best
Andrea
sim/microblaze/ChangeLog:
2017-06-04 Andrea Corallo<andrea_corallo@yahoo.it>
* interp.c (sim_engine_run): breakpoint check condition fix.
---
sim/microblaze/interp.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/sim/microblaze/interp.c b/sim/microblaze/interp.c
index 75fc98b..48cc8cb 100644
--- a/sim/microblaze/interp.c
+++ b/sim/microblaze/interp.c
@@ -161,8 +161,8 @@ sim_engine_run (SIM_DESC sd,
oldpc = PC;
delay_slot_enable = 0;
branch_taken = 0;
- if (op == microblaze_brk)
- sim_engine_halt (sd, NULL, NULL, NULL_CIA, sim_stopped, SIM_SIGTRAP);
+ if (op == brki && IMM == 0x18)
+ sim_engine_halt (sd, NULL, NULL, NULL_CIA, sim_stopped,
SIM_SIGTRAP);
else if (inst == MICROBLAZE_HALT_INST)
{
insts += 1;
@@ -228,7 +228,7 @@ sim_engine_run (SIM_DESC sd,
rb = GET_RB;
ra = GET_RA;
/* immword = IMM_W; */
- if (op == microblaze_brk)
+ if (op == microblaze_brk || op == brki)
{
if (STATE_VERBOSE_P (sd))
fprintf (stderr, "Breakpoint set in delay slot "
On 03/06/2017 21:18, Michael Eager wrote:
> On 06/03/2017 03:59 AM, Andrea Corallo via gdb-patches wrote:
>> I have couple of questions related to microblaze debugging and its
>> simulator:
>
> I can help with questions about MicroBlaze GDB, but can't say much
> about the simulator. I looked at it briefly a long time, but most of
> my debugging was on a development board.
>
> I don't believe that there has been any development on the MB sim for
> many years. The QEMU simulator is much more up to date.
>
>> When gdb add a breakpoint writes to memory the following word
>> 0xb9cc0060, this is defined in gdb/microblaze-tdep.h:120
>>
>> /* MICROBLAZE_BREAKPOINT defines the breakpoint that should be used.
>> Only used for native debugging. */
>> #define MICROBLAZE_BREAKPOINT {0xb9, 0xcc, 0x00, 0x60}
>>
>> This brki instruction cause the cpu to jump to 0x60
>> I guess this is because there is supposed to start a monitor program
>> in some configuration correct?
>> Because the simulator is not expecting any monitor program wouldn't
>> be more appropriate to use hardware breakpoints instead?
>
> There is a note in the MicroBlaze Processor Reference Guide about the
> use of "brk" and "brki" instructions:
>
> As a special case, when C_USE_DEBUG is set, and “brki rD, 0x18” is
> executed, a
> software breakpoint is signaled to the Xilinx Microprocesor
> Debugger (XMD) tool,
> irrespective of the value of C_BASE_VECTORS.
>
> (XMD is the JTAG pod used to debug using the GDB remote protocol.)
>
> Sim should do the something similar to this when running under GDB.
>
>> The other question is: the simulator is checking against the presence
>> of a brk instruction but not brki making gdb not stopping on the
>> breakpoint just inserted.
>> Would make sense to check against both as in the following patch?
>>
>> sim/microblaze/ChangeLog:
>> 2017-06-01 Andrea Corallo <andrea_corallo@yahoo.it>
>>
>> * interp.c (sim_engine_run): check also for breakpoint instruction brki.
>> ---
>> sim/microblaze/interp.c | 2 +-
>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/sim/microblaze/interp.c b/sim/microblaze/interp.c
>> index 75fc98b..d094a69 100644
>> --- a/sim/microblaze/interp.c
>> +++ b/sim/microblaze/interp.c
>> @@ -161,7 +161,7 @@ sim_engine_run (SIM_DESC sd,
>> oldpc = PC;
>> delay_slot_enable = 0;
>> branch_taken = 0;
>> - if (op == microblaze_brk)
>> + if (op == microblaze_brk || op == brki)
>> sim_engine_halt (sd, NULL, NULL, NULL_CIA, sim_stopped, SIM_SIGTRAP);
>> else if (inst == MICROBLAZE_HALT_INST)
>> {
>
> There is another use of microblaze_brk where a check is made whether a
> "brk" instruction is being inserted in a delay slot. I believe that
> this should also be updated to also check for a "brki" instruction.
>
next prev parent reply other threads:[~2017-06-07 6:19 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <295196608.1570236.1496487588855.ref@mail.yahoo.com>
2017-06-03 11:00 ` Andrea Corallo via gdb-patches
2017-06-03 19:18 ` Michael Eager
2017-06-04 8:14 ` Andrea Corallo via gdb-patches
2017-06-07 6:19 ` Andrea Corallo via gdb-patches [this message]
2017-06-07 16:54 ` Michael Eager
2021-02-01 3:04 ` Mike Frysinger via Gdb-patches
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=486877990.6234663.1496816355818@mail.yahoo.com \
--to=gdb-patches@sourceware.org \
--cc=andrea_corallo@yahoo.it \
/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