From a2c23081d59e6f8eb32102da7cd49d9fbade3ebf Mon Sep 17 00:00:00 2001 From: Geoffrey Noer Date: Tue, 12 Aug 1997 21:38:54 +0000 Subject: [PATCH] Tue Aug 12 14:37:18 1997 Geoffrey Noer * ocd.c (ocd_wait): loop until we're in BDM mode instead of assuming control has returned to GDB. --- gdb/ChangeLog | 5 +++++ gdb/ocd.c | 18 +++++++++++------- 2 files changed, 16 insertions(+), 7 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index cd4528532b..ed6635dc87 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +Tue Aug 12 14:37:18 1997 Geoffrey Noer + + * ocd.c (ocd_wait): loop until we're in BDM mode instead of + assuming control has returned to GDB. + start-sanitize-gdbtk Tue Aug 12 16:35:21 1997 Ian Lance Taylor diff --git a/gdb/ocd.c b/gdb/ocd.c index 721ae3fff7..a853080fe0 100644 --- a/gdb/ocd.c +++ b/gdb/ocd.c @@ -453,7 +453,10 @@ ocd_wait () /* Target may already be stopped by the time we get here. */ - if (!(last_run_status & OCD_FLAG_BDM)) +/* if (!(last_run_status & OCD_FLAG_BDM)) */ + + /* Loop until we've dropped back into BDM mode */ + while (!(last_run_status & OCD_FLAG_BDM)) { ofunc = (void (*)()) signal (SIGINT, ocd_interrupt); @@ -464,19 +467,20 @@ ocd_wait () if (pktlen < 2) error ("Truncated response packet from OCD device"); - status = p[1]; + last_run_status = p[1]; error_code = p[2]; if (error_code != 0) ocd_error ("target_wait:", error_code); - if (status & OCD_FLAG_PWF) + if (last_run_status & OCD_FLAG_PWF) error ("OCD device lost VCC at BDM interface."); - else if (status & OCD_FLAG_CABLE_DISC) - error ("BDM cable appears to have been disconnected."); - - if (!(status & OCD_FLAG_BDM)) + else if (last_run_status & OCD_FLAG_CABLE_DISC) + error ("OCD device cable appears to have been disconnected."); +#if 0 + if (!(last_run_status & OCD_FLAG_BDM)) error ("OCD device woke up, but wasn't stopped: 0x%x", status); +#endif } if (ocd_interrupt_flag)