]> git.sur5r.net Git - openocd/blobdiff - src/target/trace.h
target/aarch64: Call aarch64_init_debug_access() earlier in aarch64_deassert_reset()
[openocd] / src / target / trace.h
index 2994f10e97c4aea03531ba90eb7046134496a015..2966bbd94c34b5f51dde56269ca6f98d7cff932c 100644 (file)
  *   GNU General Public License for more details.                          *
  *                                                                         *
  *   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.             *
+ *   along with this program.  If not, see <http://www.gnu.org/licenses/>. *
  ***************************************************************************/
-#ifndef TRACE_H
-#define TRACE_H
 
-#include "target.h"
+#ifndef OPENOCD_TARGET_TRACE_H
+#define OPENOCD_TARGET_TRACE_H
 
-typedef enum trace_status
-{
+struct target;
+struct command_context;
+
+struct trace_point {
+       uint32_t address;
+       uint64_t hit_counter;
+};
+
+struct trace {
+       uint32_t num_trace_points;
+       uint32_t trace_points_size;
+       struct trace_point *trace_points;
+       uint32_t trace_history_size;
+       uint32_t *trace_history;
+       uint32_t trace_history_pos;
+       int trace_history_overflowed;
+};
+
+/**
+ * \todo This enum is one of the few things in this file related
+ * to *hardware* tracing ... split such "real" tracing out from
+ * the contrib/libdcc support.
+ */
+typedef enum trace_status {
        TRACE_IDLE = 0x0,
        TRACE_RUNNING = 0x1,
        TRACE_TRIGGERED = 0x2,
@@ -31,4 +50,10 @@ typedef enum trace_status
        TRACE_OVERFLOWED = 0x8,
 } trace_status_t;
 
-#endif /* TRACE_H */
+int trace_point(struct target *target, uint32_t number);
+int trace_register_commands(struct command_context *cmd_ctx);
+
+#define ERROR_TRACE_IMAGE_UNAVAILABLE          (-1500)
+#define ERROR_TRACE_INSTRUCTION_UNAVAILABLE    (-1501)
+
+#endif /* OPENOCD_TARGET_TRACE_H */