aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGiovanni Di Sirio <gdisirio@gmail.com>2016-04-05 10:47:57 +0000
committerGiovanni Di Sirio <gdisirio@gmail.com>2016-04-05 10:47:57 +0000
commitce4f94eff6a85bd8c93794d0413316e347614f2c (patch)
tree26b478e9b9703465642e5e5a0f8300a72c888831
parentfbb8e866760c1bc605422c92eef756903e5d63df (diff)
downloadChibiOS-ce4f94eff6a85bd8c93794d0413316e347614f2c.tar.gz
ChibiOS-ce4f94eff6a85bd8c93794d0413316e347614f2c.tar.bz2
ChibiOS-ce4f94eff6a85bd8c93794d0413316e347614f2c.zip
Renamed internal tracer functions.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@9242 35acf78f-673a-0410-8e92-d51de3d6d3f4
-rw-r--r--os/rt/include/chsys.h6
-rw-r--r--os/rt/include/chtrace.h32
-rw-r--r--os/rt/rt.mk1
-rw-r--r--os/rt/src/chsys.c6
-rw-r--r--os/rt/src/chtrace.c15
5 files changed, 31 insertions, 29 deletions
diff --git a/os/rt/include/chsys.h b/os/rt/include/chsys.h
index 3f51244d5..aa1bb0312 100644
--- a/os/rt/include/chsys.h
+++ b/os/rt/include/chsys.h
@@ -130,7 +130,7 @@
PORT_IRQ_PROLOGUE(); \
CH_CFG_IRQ_PROLOGUE_HOOK(); \
_stats_increase_irq(); \
- _dbg_trace_isr_enter(__func__); \
+ _trace_isr_enter(__func__); \
_dbg_check_enter_isr()
/**
@@ -143,7 +143,7 @@
*/
#define CH_IRQ_EPILOGUE() \
_dbg_check_leave_isr(); \
- _dbg_trace_isr_leave(__func__); \
+ _trace_isr_leave(__func__); \
CH_CFG_IRQ_EPILOGUE_HOOK(); \
PORT_IRQ_EPILOGUE()
@@ -285,7 +285,7 @@
*/
#define chSysSwitch(ntp, otp) { \
\
- _dbg_trace_switch(otp); \
+ _trace_switch(ntp, otp); \
_stats_ctxswc(ntp, otp); \
CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp); \
port_switch(ntp, otp); \
diff --git a/os/rt/include/chtrace.h b/os/rt/include/chtrace.h
index 43d8a6eac..185ddfe46 100644
--- a/os/rt/include/chtrace.h
+++ b/os/rt/include/chtrace.h
@@ -48,7 +48,7 @@
* @name Events to trace
* @{
*/
-#define CH_DBG_TRACE_MASK_DISABLED -1
+#define CH_DBG_TRACE_MASK_DISABLED 255U
#define CH_DBG_TRACE_MASK_NONE 0U
#define CH_DBG_TRACE_MASK_SWITCH 1U
#define CH_DBG_TRACE_MASK_ISR 2U
@@ -201,20 +201,20 @@ typedef struct {
an empty macro. Note that the macros can be externally redefined in
order to interface 3rd parties tracing tools.*/
#if CH_DBG_TRACE_MASK == CH_DBG_TRACE_MASK_DISABLED
-#if !defined(_dbg_trace_init)
-#define _dbg_trace_init()
+#if !defined(_trace_init)
+#define _trace_init()
#endif
-#if !defined(_dbg_trace_switch)
-#define _dbg_trace_switch(otp)
+#if !defined(_trace_switch)
+#define _trace_switch(ntp, otp)
#endif
-#if !defined(_dbg_trace_isr_enter)
-#define _dbg_trace_isr_enter(isr)
+#if !defined(_trace_isr_enter)
+#define _trace_isr_enter(isr)
#endif
-#if !defined(_dbg_trace_isr_leave)
-#define _dbg_trace_isr_leave(isr)
+#if !defined(_trace_isr_leave)
+#define _trace_isr_leave(isr)
#endif
-#if !defined(_dbg_trace_halt)
-#define _dbg_trace_halt(reason)
+#if !defined(_trace_halt)
+#define _trace_halt(reason)
#endif
#if !defined(chDbgWriteTraceI)
#define chDbgWriteTraceI(up1, up2)
@@ -232,11 +232,11 @@ typedef struct {
extern "C" {
#endif
#if (CH_DBG_TRACE_MASK != CH_DBG_TRACE_MASK_DISABLED) || defined(__DOXYGEN__)
- void _dbg_trace_init(void);
- void _dbg_trace_switch(thread_t *otp);
- void _dbg_trace_isr_enter(const char *isr);
- void _dbg_trace_isr_leave(const char *isr);
- void _dbg_trace_halt(const char *reason);
+ void _trace_init(void);
+ void _trace_switch(thread_t *ntp, thread_t *otp);
+ void _trace_isr_enter(const char *isr);
+ void _trace_isr_leave(const char *isr);
+ void _trace_halt(const char *reason);
void chDbgWriteTraceI(void *up1, void *up2);
void chDbgWriteTrace(void *up1, void *up2);
void chDbgSuspendTraceI(uint16_t mask);
diff --git a/os/rt/rt.mk b/os/rt/rt.mk
index f1a8afe07..4aa74e141 100644
--- a/os/rt/rt.mk
+++ b/os/rt/rt.mk
@@ -51,6 +51,7 @@ endif
else
KERNSRC := $(CHIBIOS)/os/rt/src/chsys.c \
$(CHIBIOS)/os/rt/src/chdebug.c \
+ $(CHIBIOS)/os/rt/src/chtrace.c \
$(CHIBIOS)/os/rt/src/chvt.c \
$(CHIBIOS)/os/rt/src/chschd.c \
$(CHIBIOS)/os/rt/src/chthreads.c \
diff --git a/os/rt/src/chsys.c b/os/rt/src/chsys.c
index 0702b7c18..1d3c7eff6 100644
--- a/os/rt/src/chsys.c
+++ b/os/rt/src/chsys.c
@@ -101,6 +101,7 @@ void chSysInit(void) {
_scheduler_init();
_vt_init();
+ _trace_init();
#if CH_DBG_SYSTEM_STATE_CHECK == TRUE
ch.dbg.isr_cnt = (cnt_t)0;
@@ -118,9 +119,6 @@ void chSysInit(void) {
#if CH_DBG_STATISTICS == TRUE
_stats_init();
#endif
-#if CH_DBG_TRACE_MASK != CH_DBG_TRACE_MASK_DISABLED
- _dbg_trace_init();
-#endif
#if CH_CFG_NO_IDLE_THREAD == FALSE
/* Now this instructions flow becomes the main thread.*/
@@ -199,7 +197,7 @@ void chSysHalt(const char *reason) {
CH_CFG_SYSTEM_HALT_HOOK(reason);
/* Logging the event.*/
- _dbg_trace_halt(reason);
+ _trace_halt(reason);
/* Pointing to the passed message.*/
ch.dbg.panic_msg = reason;
diff --git a/os/rt/src/chtrace.c b/os/rt/src/chtrace.c
index e6f13c6e7..f6c6d8e70 100644
--- a/os/rt/src/chtrace.c
+++ b/os/rt/src/chtrace.c
@@ -82,10 +82,10 @@ static NOINLINE void trace_next(void) {
* @brief Trace circular buffer subsystem initialization.
* @note Internal use only.
*/
-void _dbg_trace_init(void) {
+void _trace_init(void) {
unsigned i;
- ch.dbg.trace_buffer.suspended = CH_DBG_TRACE_MASK;
+ ch.dbg.trace_buffer.suspended = (uint16_t)CH_DBG_TRACE_MASK;
ch.dbg.trace_buffer.size = CH_DBG_TRACE_BUFFER_SIZE;
ch.dbg.trace_buffer.ptr = &ch.dbg.trace_buffer.buffer[0];
for (i = 0U; i < (unsigned)CH_DBG_TRACE_BUFFER_SIZE; i++) {
@@ -96,11 +96,14 @@ void _dbg_trace_init(void) {
/**
* @brief Inserts in the circular debug trace buffer a context switch record.
*
+ * @param[in] ntp the thread being switched in
* @param[in] otp the thread being switched out
*
* @notapi
*/
-void _dbg_trace_switch(thread_t *otp) {
+void _trace_switch(thread_t *ntp, thread_t *otp) {
+
+ (void)ntp;
if ((ch.dbg.trace_buffer.suspended & CH_DBG_TRACE_MASK_SWITCH) == 0U) {
ch.dbg.trace_buffer.ptr->type = CH_TRACE_TYPE_SWITCH;
@@ -118,7 +121,7 @@ void _dbg_trace_switch(thread_t *otp) {
*
* @notapi
*/
-void _dbg_trace_isr_enter(const char *isr) {
+void _trace_isr_enter(const char *isr) {
if ((ch.dbg.trace_buffer.suspended & CH_DBG_TRACE_MASK_ISR) == 0U) {
port_lock_from_isr();
@@ -137,7 +140,7 @@ void _dbg_trace_isr_enter(const char *isr) {
*
* @notapi
*/
-void _dbg_trace_isr_leave(const char *isr) {
+void _trace_isr_leave(const char *isr) {
if ((ch.dbg.trace_buffer.suspended & CH_DBG_TRACE_MASK_ISR) == 0U) {
port_lock_from_isr();
@@ -156,7 +159,7 @@ void _dbg_trace_isr_leave(const char *isr) {
*
* @notapi
*/
-void _dbg_trace_halt(const char *reason) {
+void _trace_halt(const char *reason) {
if ((ch.dbg.trace_buffer.suspended & CH_DBG_TRACE_MASK_HALT) == 0U) {
ch.dbg.trace_buffer.ptr->type = CH_TRACE_TYPE_HALT;