aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Schink <openocd-dev@marcschink.de>2019-02-14 16:11:44 +0100
committerTomas Vanek <vanekt@fbl.cz>2020-03-26 19:30:34 +0000
commit9960e805b389b3ff46801b336772ab31d35a31a6 (patch)
treed52f10008e4327c4e272c98d25f544e7474188be
parentd9ffe75e257aa4005dd34603860e45c57b1765b6 (diff)
downloadriscv-openocd-9960e805b389b3ff46801b336772ab31d35a31a6.zip
riscv-openocd-9960e805b389b3ff46801b336772ab31d35a31a6.tar.gz
riscv-openocd-9960e805b389b3ff46801b336772ab31d35a31a6.tar.bz2
target: Add function to remove all breakpoints
Change-Id: I4718926844a2c8bcfd78d7a8792f6ded293548ef Signed-off-by: Marc Schink <openocd-dev@marcschink.de> Reviewed-on: http://openocd.zylin.com/4915 Tested-by: jenkins Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com> Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
-rw-r--r--src/target/breakpoints.c30
-rw-r--r--src/target/breakpoints.h1
2 files changed, 30 insertions, 1 deletions
diff --git a/src/target/breakpoints.c b/src/target/breakpoints.c
index 7ad1942..c060c7c 100644
--- a/src/target/breakpoints.c
+++ b/src/target/breakpoints.c
@@ -332,6 +332,18 @@ static int breakpoint_remove_internal(struct target *target, target_addr_t addre
return 0;
}
}
+
+static void breakpoint_remove_all_internal(struct target *target)
+{
+ struct breakpoint *breakpoint = target->breakpoints;
+
+ while (breakpoint) {
+ struct breakpoint *tmp = breakpoint;
+ breakpoint = breakpoint->next;
+ breakpoint_free(target, tmp);
+ }
+}
+
void breakpoint_remove(struct target *target, target_addr_t address)
{
int found = 0;
@@ -350,7 +362,23 @@ void breakpoint_remove(struct target *target, target_addr_t address)
breakpoint_remove_internal(target, address);
}
-void breakpoint_clear_target_internal(struct target *target)
+void breakpoint_remove_all(struct target *target)
+{
+ if (target->smp) {
+ struct target_list *head;
+ struct target *curr;
+ head = target->head;
+ while (head != (struct target_list *)NULL) {
+ curr = head->target;
+ breakpoint_remove_all_internal(curr);
+ head = head->next;
+ }
+ } else {
+ breakpoint_remove_all_internal(target);
+ }
+}
+
+static void breakpoint_clear_target_internal(struct target *target)
{
LOG_DEBUG("Delete all breakpoints for target: %s",
target_name(target));
diff --git a/src/target/breakpoints.h b/src/target/breakpoints.h
index 51bd05a..20faf4e 100644
--- a/src/target/breakpoints.h
+++ b/src/target/breakpoints.h
@@ -63,6 +63,7 @@ int context_breakpoint_add(struct target *target,
int hybrid_breakpoint_add(struct target *target,
target_addr_t address, uint32_t asid, uint32_t length, enum breakpoint_type type);
void breakpoint_remove(struct target *target, target_addr_t address);
+void breakpoint_remove_all(struct target *target);
struct breakpoint *breakpoint_find(struct target *target, target_addr_t address);