ARM11 command handling fixes
[fw/openocd] / src / target / trace.h
index ec4a4c38fc2df035feb1c1a55c44b06442a9b0af..0a9ccc55f531ac7de698b8dc810f207d9206b9b6 100644 (file)
 #ifndef TRACE_H
 #define TRACE_H
 
-#include "target.h"
+#include "types.h"
+
+struct target_s;
+struct command_context_s;
+
+typedef struct trace_point_s
+{
+       uint32_t address;
+       uint64_t hit_counter;
+} trace_point_t;
+
+typedef struct trace_s
+{
+       uint32_t num_trace_points;
+       uint32_t trace_points_size;
+       trace_point_t *trace_points;
+       uint32_t trace_history_size;
+       uint32_t *trace_history;
+       uint32_t trace_history_pos;
+       int trace_history_overflowed;
+} trace_t;
 
 typedef enum trace_status
 {
@@ -31,7 +51,10 @@ typedef enum trace_status
        TRACE_OVERFLOWED = 0x8,
 } trace_status_t;
 
-#define ERROR_TRACE_IMAGE_UNAVAILABLE  -(1500)
-#define ERROR_TRACE_INSTRUCTION_UNAVAILABLE    -(1500)
+extern int trace_point(struct target_s *target, uint32_t number);
+extern int trace_register_commands(struct command_context_s *cmd_ctx);
+
+#define ERROR_TRACE_IMAGE_UNAVAILABLE          -(1500)
+#define ERROR_TRACE_INSTRUCTION_UNAVAILABLE    -(1501)
 
 #endif /* TRACE_H */