X-Git-Url: https://review.openocd.org/gitweb?a=blobdiff_plain;f=src%2Ftarget%2Fbreakpoints.h;h=a019e967b39d98f2488a9c4cd9cea265b3c99bbf;hb=f4f87cb4726fbba4a03e2eda1759faf1c47ab4ba;hp=2a79a9ad43c9744713beb77ca4f948903a4e66ef;hpb=53c05c8b1d5718b2acf5dbe0eb517dd427340041;p=openocd.git diff --git a/src/target/breakpoints.h b/src/target/breakpoints.h index 2a79a9ad43..a019e967b3 100644 --- a/src/target/breakpoints.h +++ b/src/target/breakpoints.h @@ -17,37 +17,34 @@ * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ + #ifndef BREAKPOINTS_H #define BREAKPOINTS_H -#include "types.h" - -struct target_s; +struct target; -enum breakpoint_type -{ +enum breakpoint_type { BKPT_HARD, BKPT_SOFT, }; -enum watchpoint_rw -{ +enum watchpoint_rw { WPT_READ = 0, WPT_WRITE = 1, WPT_ACCESS = 2 }; -struct breakpoint -{ +struct breakpoint { uint32_t address; + uint32_t asid; int length; enum breakpoint_type type; int set; uint8_t *orig_instr; struct breakpoint *next; - int unique_id; + uint32_t unique_id; + int linked_BRP; }; -struct watchpoint -{ +struct watchpoint { uint32_t address; uint32_t length; uint32_t mask; @@ -58,17 +55,21 @@ struct watchpoint int unique_id; }; -void breakpoint_clear_target(struct target_s *target); -int breakpoint_add(struct target_s *target, +void breakpoint_clear_target(struct target *target); +int breakpoint_add(struct target *target, uint32_t address, uint32_t length, enum breakpoint_type type); -void breakpoint_remove(struct target_s *target, uint32_t address); +int context_breakpoint_add(struct target *target, + uint32_t asid, uint32_t length, enum breakpoint_type type); +int hybrid_breakpoint_add(struct target *target, + uint32_t address, uint32_t asid, uint32_t length, enum breakpoint_type type); +void breakpoint_remove(struct target *target, uint32_t address); -struct breakpoint* breakpoint_find(struct target_s *target, uint32_t address); +struct breakpoint *breakpoint_find(struct target *target, uint32_t address); -void watchpoint_clear_target(struct target_s *target); -int watchpoint_add(struct target_s *target, +void watchpoint_clear_target(struct target *target); +int watchpoint_add(struct target *target, uint32_t address, uint32_t length, enum watchpoint_rw rw, uint32_t value, uint32_t mask); -void watchpoint_remove(struct target_s *target, uint32_t address); +void watchpoint_remove(struct target *target, uint32_t address); #endif /* BREAKPOINTS_H */