FreeCalypso > hg > fc-selenite
comparison src/cs/riviera/rvt/ti_profiler/ti_profiler.h @ 0:b6a5e36de839
src/cs: initial import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 15 Jul 2018 04:39:26 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:b6a5e36de839 |
---|---|
1 /************************************************************************************ | |
2 * ti_profiler.h : contains ti profiling and Nucleus Monitoring module header * | |
3 * * | |
4 * * | |
5 * Author: Philippe Martinez * | |
6 * * | |
7 * version: 1.1 * | |
8 * * | |
9 * Date: 07/16/2001 * | |
10 * (C) Copyright 2001 by Texas Instruments Incorporated, All Rights Reserved * | |
11 ************************************************************************************/ | |
12 | |
13 | |
14 #ifndef _TI_PROFILER_H_ | |
15 #define _TI_PROFILER_H_ | |
16 | |
17 #define INFINITE_LOOP ( 1 ) | |
18 #define L1_TRACER ( 1 ) // Add debug traces into Layer 1 stream | |
19 | |
20 // Log buffer size in 32 bit words (profiler only) | |
21 #define PR_BUFFER_SIZE ( 20000 ) | |
22 #define PR_BUFFER_THRESHOLD ( PR_BUFFER_SIZE - 95 ) | |
23 | |
24 | |
25 // buffer OP code (profiler only) | |
26 #define C_OP_CODE_START_PR ( 0xfffffff0 ) | |
27 #define C_OP_CODE_STOP_PR ( 0xfffffffe ) | |
28 | |
29 #define C_OP_CODE_BEGIN_BUFFER ( 0xfffffff0 ) | |
30 #define C_OP_CODE_TDMA_BEGIN ( 0xfffffff2 ) | |
31 #define C_OP_CODE_TDMA_END ( 0xfffffff4 ) | |
32 #define C_OP_CODE_END_BUFFER ( 0xfffffff8 ) | |
33 | |
34 // Rx message ID code (profiler only) | |
35 #define TI_PROFILER_END_PROFILING ( 0x0000 ) | |
36 #define TI_PROFILER_START_PROFILING ( 0x0001 ) | |
37 | |
38 #define TI_PROFILER_OUTPUT_BUFFER ( 0xffff ) | |
39 | |
40 | |
41 // Timer used (profiler only) | |
42 #define PR_TIMER_NUM ( 1 ) | |
43 | |
44 #define PR_TIMER_RESET_VALUE ( 21 ) // load value 50 us | |
45 | |
46 // define the length of cutted element buffer in order to | |
47 // Generate rvt messages. (profiler only) | |
48 #define TRACE_MESSAGE_SIZE ( 50 ) // x4 = n bytes | |
49 | |
50 // Nucleus monitoring buffer size (bytes) for rvt (Nucleus Monitoring only) | |
51 #define NUC_MONITOR_BUFFER_SIZE ( 240 ) | |
52 | |
53 // Nucleus Monitoring Buffer (Nucleus Monitoring only) | |
54 #define C_OP_CODE_NUC_MON_THREAD_IDS ( 0xff ) | |
55 #define C_OP_CODE_FN_LOG ( 0x00 ) | |
56 #define C_OP_CODE_LISR_FLAG ( 0xC0 ) | |
57 #define C_OP_CODE_THREAD_FLAG ( 0x80 ) | |
58 #define C_OP_CODE_QUEUE_FLAG ( 0x40 ) | |
59 | |
60 // Rx message ID code (Nucleus Monitoring only) | |
61 #define TI_NUC_MONITOR_OUTPUT_BUFFER ( 0xfff0 ) | |
62 #define TI_NUC_MONITOR_START ( 0x0002 ) | |
63 #define TI_NUC_MONITOR_STOP ( 0x0003 ) | |
64 | |
65 // ID Thread NULL (Nucleus Monitoring only) | |
66 #define NUC_MONITOR_ID_IDLE ( 0xff ) | |
67 | |
68 // Nuleus monitoring : Number max of component of same type | |
69 // that can be monitored (Nucleus Monitoring only) | |
70 #define NUC_MONITOR_MAX_ID ( 64 ) | |
71 | |
72 // Define LISR doubled buffer Size (Nucleus Monitoring only) | |
73 #define C_NUC_LISR_BUF_PG_NB ( 2 ) | |
74 #define C_NUC_LISR_LOG_SZ ( 5 ) // bytes | |
75 | |
76 // Must be strickly < NUC_MONITOR_BUFFER_SIZE (Nucleus Monitoring only) | |
77 #define C_NUC_MAX_LISR ( 20 * C_NUC_LISR_LOG_SZ ) | |
78 | |
79 // Define LISR doubled buffer Size (Nucleus Monitoring only) | |
80 #define C_NUC_THREAD_BUF_PG_NB ( 2 ) | |
81 #define C_NUC_THREAD_LOG_SZ ( 3 ) // bytes | |
82 | |
83 // Must be strickly < NUC_MONITOR_BUFFER_SIZE (Nucleus Monitoring only) | |
84 #define C_NUC_MAX_THREAD ( 30 * C_NUC_THREAD_LOG_SZ ) | |
85 | |
86 // Differents state of profiling | |
87 typedef enum | |
88 { | |
89 PROFILER_STOPPED, | |
90 PROFILER_RUNNING, | |
91 PROFILER_FREEZED, | |
92 PROFILER_TO_BE_RAN, | |
93 PROFILER_TO_BE_UNFREEZED, | |
94 PROFILER_TO_BE_STOPPED | |
95 } T_PROFILER_STATE; | |
96 | |
97 // Differents state of nucleus monitoring (Nucleus Monitoring only) | |
98 typedef enum | |
99 { | |
100 NUC_MONITOR_STOPPED, | |
101 NUC_MONITOR_RUNNING, | |
102 NUC_MONITOR_TO_BE_RUN, | |
103 NUC_MONITOR_TO_BE_STARTED, | |
104 NUC_MONITOR_TO_BE_STOP, | |
105 NUC_MONITOR_WAITING | |
106 } T_NUC_MONITOR_STATE; | |
107 | |
108 typedef enum | |
109 { | |
110 LOGGING, | |
111 FLUSH | |
112 } T_PROFILER_BUFFER_STATE; | |
113 | |
114 typedef enum | |
115 { | |
116 NOT_ACTIVE, | |
117 ACTIVE_BY_TI, | |
118 ACTIVE_BY_EXT, | |
119 ACTIVE_BY_HOST | |
120 } T_PROFILER_HANDLER; | |
121 | |
122 typedef enum | |
123 { | |
124 NO_EVENT, | |
125 NO_SLEEP_EVENT, | |
126 EVENT2, | |
127 EVENT3, | |
128 EVENT4 | |
129 } T_PROFILER_EVENTS; | |
130 | |
131 typedef struct | |
132 { | |
133 SYS_UWORD16 msg_id; | |
134 SYS_UWORD8 event_number; | |
135 SYS_UWORD8 arg1; | |
136 SYS_UWORD8 *p_buffer; | |
137 SYS_UWORD8 buffer_size; | |
138 } T_PROFILER_MSG_UART; | |
139 | |
140 typedef struct | |
141 { | |
142 T_RV_HDR header; | |
143 SYS_UWORD16 msg_id; | |
144 SYS_UWORD8 event_number; | |
145 SYS_UWORD8 arg1; | |
146 SYS_UWORD8 *p_buffer; | |
147 SYS_UWORD8 buffer_size; | |
148 } T_PROFILER_MSG; | |
149 | |
150 #endif | |
151 |