X-Git-Url: https://review.openocd.org/gitweb?p=openocd.git;a=blobdiff_plain;f=src%2Ftarget%2Fbreakpoints.h;h=0246acd3db84dc1f17b5f146d046f7bab50e23ad;hp=fa82c49f4fe77f28536689c478ade8f1b0ee925b;hb=cdd8928a560252e3c7f11911864fe01a1864a0bf;hpb=86173cdbddde781b19ac630602f2d450a59b32b5 diff --git a/src/target/breakpoints.h b/src/target/breakpoints.h index fa82c49f4f..0246acd3db 100644 --- a/src/target/breakpoints.h +++ b/src/target/breakpoints.h @@ -15,53 +15,64 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 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 }; -typedef struct breakpoint_s -{ - u32 address; +struct breakpoint { + uint32_t address; + uint32_t asid; int length; enum breakpoint_type type; int set; uint8_t *orig_instr; - struct breakpoint_s *next; -} breakpoint_t; + struct breakpoint *next; + uint32_t unique_id; + int linked_BRP; +}; -typedef struct watchpoint_s -{ - u32 address; - int length; - u32 mask; - u32 value; +struct watchpoint { + uint32_t address; + uint32_t length; + uint32_t mask; + uint32_t value; enum watchpoint_rw rw; int set; - struct watchpoint_s *next; -} watchpoint_t; + struct watchpoint *next; + int unique_id; +}; + +void breakpoint_clear_target(struct target *target); +int breakpoint_add(struct target *target, + uint32_t address, uint32_t length, enum breakpoint_type type); +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 *target, uint32_t address); + +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 *target, uint32_t address); -extern void breakpoint_clear_target(struct target_s *target); -extern int breakpoint_add(struct target_s *target, u32 address, u32 length, enum breakpoint_type type); -extern void breakpoint_remove(struct target_s *target, u32 address); -extern breakpoint_t* breakpoint_find(struct target_s *target, u32 address); -extern int watchpoint_add(struct target_s *target, u32 address, u32 length, enum watchpoint_rw rw, u32 value, u32 mask); -extern void watchpoint_remove(struct target_s *target, u32 address); -extern void watchpoint_clear_target(struct target_s *target); +/* report type and address of just hit watchpoint */ +int watchpoint_hit(struct target *target, enum watchpoint_rw *rw, uint32_t *address); #endif /* BREAKPOINTS_H */