87c90393fe
Remove a use of AH_BOTTOM from configure.ac. This macro is used by autoheader to add '#include' of some include file to the end of config.h.in and then to config.h. OpenOCD can be built with a custom config.h, so it's preferable to move these '#include' statement directly in the C files that need them dropping this unneeded dependency. It also causes problems when I want to use the gnulib library (which comes with its own Makefile, and does not have the same include path as the top-level Makefile). So this change touches a lot of files, but is actually really simple. It does not affect functionality at all. Change-Id: I52c70bf15eb2edc1dd10e0fde23b2bcd4caec000 Signed-off-by: Tim Newsome <tim@sifive.com> Reviewed-on: http://openocd.zylin.com/6171 Tested-by: jenkins Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com>
62 lines
2.3 KiB
C
62 lines
2.3 KiB
C
/***************************************************************************
|
|
* Copyright (C) 2007 by Dominic Rath *
|
|
* Dominic.Rath@gmx.de *
|
|
* *
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
* it under the terms of the GNU General Public License as published by *
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
* (at your option) any later version. *
|
|
* *
|
|
* This program is distributed in the hope that it will be useful, *
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
|
* 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, see <http://www.gnu.org/licenses/>. *
|
|
***************************************************************************/
|
|
|
|
#ifndef OPENOCD_TARGET_TRACE_H
|
|
#define OPENOCD_TARGET_TRACE_H
|
|
|
|
#include "helper/types.h"
|
|
|
|
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,
|
|
TRACE_COMPLETED = 0x4,
|
|
TRACE_OVERFLOWED = 0x8,
|
|
} trace_status_t;
|
|
|
|
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 */
|