OpenCSD - CoreSight Trace Decode Library  0.14.3
trc_pkt_types_etmv4.h
Go to the documentation of this file.
1 /*
2  * \file trc_pkt_types_etmv4.h
3  * \brief OpenCSD : ETMv4 packet info
4  *
5  * \copyright Copyright (c) 2015,2019 ARM Limited. All Rights Reserved.
6  */
7 
8 
9 /*
10  * Redistribution and use in source and binary forms, with or without modification,
11  * are permitted provided that the following conditions are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright notice,
14  * this list of conditions and the following disclaimer.
15  *
16  * 2. Redistributions in binary form must reproduce the above copyright notice,
17  * this list of conditions and the following disclaimer in the documentation
18  * and/or other materials provided with the distribution.
19  *
20  * 3. Neither the name of the copyright holder nor the names of its contributors
21  * may be used to endorse or promote products derived from this software without
22  * specific prior written permission.
23  *
24  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' AND
25  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
26  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
27  * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
28  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
31  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34  */
35 
36 #ifndef ARM_TRC_PKT_TYPES_ETMV4_H_INCLUDED
37 #define ARM_TRC_PKT_TYPES_ETMV4_H_INCLUDED
38 
39 #include "opencsd/trc_pkt_types.h"
40 
49 {
50 /* state of decode markers */
55 /* markers for unknown/bad packets */
61 /* I stream packet types. */
62  /* extension header. */
65  /* sync */
67  // timestamp
71  // Exceptions
75  /* unused encodings 0x08-0xB b00001000 to b00001011 */
76 
77  /* cycle count packets */
82  // data synchronisation markers
86  // speculation
94  /* conditional instruction tracing */
98  /* unused encoding 0x47 b01000111 */
100  /* unused encodings 0x4B,0x4F b01001011, b01001111 */
102  /* unused encodings 0x60-0x67 b01100xxx */
107  // event trace
111  /* address and context */
115  /* unused encoding 0x84 b10000100 */
118  /* unused encoding 0x87 b10000111 */
119  /* unused encodings 0x88-0x8F b10001xxx */
121  /* unused encodings 0x93-0x94 b10010011 to b10010010 */
124  /* unused encodings 0x97 b10010111 to b10011001 0x99 */
127  /* unused encoding 0x9C b10011100 */
130  /* unused encoding 0x9F b10011111 */
131 
132  /* Q packets */
133  ETM4_PKT_I_Q = 0xA0,
135  /* unused encodings 0xB0-0xBF b1011xxxx */
136 
137  /* Atom packets */
145  // extension packets - follow 0x00 header
149 
151 
152 typedef union _etmv4_trace_info_t {
153  uint32_t val;
154  struct {
155  uint32_t cc_enabled:1;
156  uint32_t cond_enabled:3;
157  uint32_t p0_load:1;
158  uint32_t p0_store:1;
159  } bits;
161 
162 typedef struct _etmv4_context_t {
163  struct {
164  uint32_t EL:2;
165  uint32_t SF:1;
166  uint32_t NS:1;
167  uint32_t updated:1;
168  uint32_t updated_c:1;
169  uint32_t updated_v:1;
170  };
171  uint32_t ctxtID;
172  uint32_t VMID;
174 
176 typedef struct _etmv4_addr_val_t {
178  uint8_t isa;
180 
181 typedef struct _ocsd_etmv4_i_pkt
182 {
185  //** intra-packet data - valid across packets.
186 
188  uint8_t v_addr_ISA;
189 
191 
192  struct {
193  uint64_t timestamp;
194  uint8_t bits_changed;
195  } ts;
196 
197  uint32_t cc_threshold;
198 
199  // single packet data - only valid for specific packet types on packet instance.
201  uint32_t cycle_count;
202 
203  uint32_t curr_spec_depth;
204  uint32_t p0_key;
205 
206  uint32_t commit_elements; //<! commit elements indicated by this packet - valid dependent on the packet type.
207  uint32_t cancel_elements; //<! cancel elements indicated by this packet - valid dependent on the packet type.
208 
210 
211  struct {
212  uint32_t exceptionType:10;
213  uint32_t addr_interp:2;
214  uint32_t m_fault_pending:1;
215  uint32_t m_type:1;
217 
218 
220  uint8_t dsm_val;
221  uint8_t event_val;
222 
223  struct {
224  uint32_t cond_c_key;
225  uint8_t num_c_elem;
226  struct {
227  uint32_t cond_key_set:1;
228  uint32_t f3_final_elem:1;
229  uint32_t f2_cond_incr:1;
230  };
232 
233  struct {
234  uint32_t cond_r_key_0;
235  uint32_t cond_r_key_1;
236  struct {
237  uint32_t res_0:4;
238  uint32_t res_1:4;
239  uint32_t ci_0:1;
240  uint32_t ci_1:1;
241  uint32_t key_res_0_set:1;
242  uint32_t key_res_1_set:1;
243  uint32_t f2_key_incr:2;
244  uint32_t f2f4_token:2;
245  uint32_t f3_tokens:12;
246  };
248 
249  struct {
250  uint32_t q_count;
251  struct {
252  uint32_t addr_present:1;
253  uint32_t addr_match:1;
254  uint32_t count_present:1;
255  uint32_t q_type:4;
256  };
257  } Q_pkt;
258 
260  union {
261  uint32_t val;
262  struct {
263  uint32_t context_valid:1;
264  uint32_t ts_valid:1;
265  uint32_t spec_depth_valid:1;
266  uint32_t p0_key_valid:1;
267  uint32_t cond_c_key_valid:1;
268  uint32_t cond_r_key_valid:1;
269  uint32_t trace_info_valid:1;
270  uint32_t cc_thresh_valid:1;
271  uint32_t cc_valid:1;
272  uint32_t commit_elem_valid:1;
273  } bits;
275 
276  // original header type when packet type changed to error on decode error.
278  uint8_t err_hdr_val;
279 
281 
282 
283 // D stream packets
285 {
286 // markers for unknown/bad packets
294 
295  // data sync markers
296  ETM4_PKT_DNUM_DS_MKR = 0x111, // ext packet, b0001xxx1
297  // extension header
299 
301  // event trace
303  // timestamp
305  // P1 Data address
313  // P2 Data value
320  // suppression
322  // synchronisation- extension packets - follow 0x00 header
324 
325  // extension packets - follow 0x00 header
328  ETM4_PKT_D_OVERFLOW = 0x105
329 
331 
332 
333 typedef struct _ocsd_etmv4_d_pkt
334 {
336 
338 
339  uint64_t pkt_val;
342 
344 
345 typedef struct _ocsd_etmv4_cfg
346 {
347  uint32_t reg_idr0;
348  uint32_t reg_idr1;
349  uint32_t reg_idr2;
350  uint32_t reg_idr8;
351  uint32_t reg_idr9;
352  uint32_t reg_idr10;
353  uint32_t reg_idr11;
354  uint32_t reg_idr12;
355  uint32_t reg_idr13;
356  uint32_t reg_configr;
357  uint32_t reg_traceidr;
361 
362 
365 #endif // ARM_TRC_PKT_TYPES_ETMV4_H_INCLUDED
366 
367 /* End of File trc_pkt_types_etmv4.h */
368 
ETM4_PKT_D_RESERVED
@ ETM4_PKT_D_RESERVED
packet type reserved.
Definition: trc_pkt_types_etmv4.h:290
ETM4_PKT_I_ADDR_CTXT_L_64IS1
@ ETM4_PKT_I_ADDR_CTXT_L_64IS1
Definition: trc_pkt_types_etmv4.h:117
_etmv4_context_t::NS
uint32_t NS
none secure
Definition: trc_pkt_types_etmv4.h:166
ETM4_PKT_DADDR_P1_F7
@ ETM4_PKT_DADDR_P1_F7
b11110101
Definition: trc_pkt_types_etmv4.h:312
_etmv4_trace_info_t::cc_enabled
uint32_t cc_enabled
1 if cycle count enabled
Definition: trc_pkt_types_etmv4.h:155
ETM4_PKT_I_TIMESTAMP
@ ETM4_PKT_I_TIMESTAMP
Definition: trc_pkt_types_etmv4.h:68
_ocsd_etmv4_i_pkt::cond_r_key_1
uint32_t cond_r_key_1
Definition: trc_pkt_types_etmv4.h:235
ETM4_PKT_DADDR_P1_F6
@ ETM4_PKT_DADDR_P1_F6
b1111011x
Definition: trc_pkt_types_etmv4.h:311
_ocsd_etmv4_i_pkt::num_c_elem
uint8_t num_c_elem
Definition: trc_pkt_types_etmv4.h:225
ETM4_PKT_I_INCOMPLETE_EOT
@ ETM4_PKT_I_INCOMPLETE_EOT
Definition: trc_pkt_types_etmv4.h:52
_ocsd_etmv4_cfg
Definition: trc_pkt_types_etmv4.h:346
ETM4_PKT_I_ATOM_F4
@ ETM4_PKT_I_ATOM_F4
Definition: trc_pkt_types_etmv4.h:141
ETM4_PKT_I_ATOM_F3
@ ETM4_PKT_I_ATOM_F3
Definition: trc_pkt_types_etmv4.h:143
ETM4_PKT_I_CANCEL_F3
@ ETM4_PKT_I_CANCEL_F3
Definition: trc_pkt_types_etmv4.h:92
ETM4_PKT_D_BAD_SEQUENCE
@ ETM4_PKT_D_BAD_SEQUENCE
invalid sequence for packet type
Definition: trc_pkt_types_etmv4.h:288
_ocsd_etmv4_i_pkt::timestamp
uint64_t timestamp
current timestamp value
Definition: trc_pkt_types_etmv4.h:193
_ocsd_etmv4_i_pkt::val
uint32_t val
Definition: trc_pkt_types_etmv4.h:261
_ocsd_etmv4_i_pkt::cancel_elements
uint32_t cancel_elements
Definition: trc_pkt_types_etmv4.h:207
ETM4_PKT_I_EVENT
@ ETM4_PKT_I_EVENT
Definition: trc_pkt_types_etmv4.h:109
_ocsd_etmv4_i_pkt::exception_info
struct _ocsd_etmv4_i_pkt::@13 exception_info
ETM4_PKT_DVAL_P2_F3
@ ETM4_PKT_DVAL_P2_F3
b010xxxxx
Definition: trc_pkt_types_etmv4.h:316
ETM4_PKT_D_ASYNC
@ ETM4_PKT_D_ASYNC
b00000000
Definition: trc_pkt_types_etmv4.h:326
ETM4_PKT_I_ADDR_S_IS0
@ ETM4_PKT_I_ADDR_S_IS0
Definition: trc_pkt_types_etmv4.h:122
_ocsd_etmv4_i_pkt::v_addr
ocsd_pkt_vaddr v_addr
most recently broadcast address packet
Definition: trc_pkt_types_etmv4.h:187
ETM4_PKT_DADDR_P1_F4
@ ETM4_PKT_DADDR_P1_F4
b0110xxxx
Definition: trc_pkt_types_etmv4.h:309
_etmv4_context_t::updated
uint32_t updated
updated this context packet (otherwise same as last time)
Definition: trc_pkt_types_etmv4.h:167
ETM4_PKT_I_TRACE_ON
@ ETM4_PKT_I_TRACE_ON
Definition: trc_pkt_types_etmv4.h:69
_etmv4_trace_info_t
Definition: trc_pkt_types_etmv4.h:152
_etmv4_context_t::SF
uint32_t SF
sixty four bit
Definition: trc_pkt_types_etmv4.h:165
ETM4_PKT_I_DISCARD
@ ETM4_PKT_I_DISCARD
b00000011
Definition: trc_pkt_types_etmv4.h:147
_ocsd_etmv4_i_pkt::commit_elem_valid
uint32_t commit_elem_valid
Definition: trc_pkt_types_etmv4.h:272
ETM4_PKT_D_NO_ERR_TYPE
@ ETM4_PKT_D_NO_ERR_TYPE
error packet has no header based type. Use with unknown/res packet types.
Definition: trc_pkt_types_etmv4.h:293
_ocsd_etmv4_cfg::reg_idr1
uint32_t reg_idr1
Definition: trc_pkt_types_etmv4.h:348
ETM4_PKT_I_COND_FLUSH
@ ETM4_PKT_I_COND_FLUSH
Definition: trc_pkt_types_etmv4.h:96
ETM4_PKT_I_CANCEL_F1_MISPRED
@ ETM4_PKT_I_CANCEL_F1_MISPRED
Definition: trc_pkt_types_etmv4.h:89
_ocsd_etmv4_cfg::reg_idr9
uint32_t reg_idr9
Definition: trc_pkt_types_etmv4.h:351
ETM4_PKT_DVAL_P2_F6
@ ETM4_PKT_DVAL_P2_F6
b00111xxx
Definition: trc_pkt_types_etmv4.h:319
ETM4_PKT_D_OVERFLOW
@ ETM4_PKT_D_OVERFLOW
b00000101
Definition: trc_pkt_types_etmv4.h:328
_ocsd_etmv4_cfg::arch_ver
ocsd_arch_version_t arch_ver
Definition: trc_pkt_types_etmv4.h:358
_etmv4_trace_info_t::p0_store
uint32_t p0_store
1 if tracing with P0 store elements (for data trace)
Definition: trc_pkt_types_etmv4.h:158
_ocsd_etmv4_i_pkt::cond_instr
struct _ocsd_etmv4_i_pkt::@14 cond_instr
_ocsd_etmv4_i_pkt::cond_r_key_0
uint32_t cond_r_key_0
Definition: trc_pkt_types_etmv4.h:234
_ocsd_etmv4_i_pkt::q_type
uint32_t q_type
Definition: trc_pkt_types_etmv4.h:255
ETM4_PKT_I_COND_RES_F2
@ ETM4_PKT_I_COND_RES_F2
Definition: trc_pkt_types_etmv4.h:99
ETM4_PKT_I_ADDR_S_IS1
@ ETM4_PKT_I_ADDR_S_IS1
Definition: trc_pkt_types_etmv4.h:123
ETM4_PKT_I_UNNUM_DS_MKR
@ ETM4_PKT_I_UNNUM_DS_MKR
Definition: trc_pkt_types_etmv4.h:84
_ocsd_etmv4_cfg::reg_traceidr
uint32_t reg_traceidr
Definition: trc_pkt_types_etmv4.h:357
ETM4_PKT_I_ADDR_L_32IS0
@ ETM4_PKT_I_ADDR_L_32IS0
Definition: trc_pkt_types_etmv4.h:125
_ocsd_etmv4_i_pkt::cond_result
struct _ocsd_etmv4_i_pkt::@15 cond_result
_ocsd_etmv4_cfg::reg_idr0
uint32_t reg_idr0
Definition: trc_pkt_types_etmv4.h:347
ocsd_core_profile_t
enum _ocsd_core_profile ocsd_core_profile_t
_ocsd_etmv4_i_pkt::ci_1
uint32_t ci_1
Definition: trc_pkt_types_etmv4.h:240
ETM4_PKT_I_ATOM_F1
@ ETM4_PKT_I_ATOM_F1
Definition: trc_pkt_types_etmv4.h:142
_ocsd_etmv4_i_pkt::cond_r_key_valid
uint32_t cond_r_key_valid
Definition: trc_pkt_types_etmv4.h:268
ETM4_PKT_I_COND_RES_F4
@ ETM4_PKT_I_COND_RES_F4
Definition: trc_pkt_types_etmv4.h:97
_ocsd_etmv4_i_pkt::ts
struct _ocsd_etmv4_i_pkt::@12 ts
_etmv4_context_t::updated_v
uint32_t updated_v
updated VMID
Definition: trc_pkt_types_etmv4.h:169
ETM4_PKT_I_CANCEL_F1
@ ETM4_PKT_I_CANCEL_F1
Definition: trc_pkt_types_etmv4.h:88
_ocsd_etmv4_d_pkt::type
ocsd_etmv4_d_pkt_type type
Definition: trc_pkt_types_etmv4.h:335
ETM4_PKT_I_RESERVED
@ ETM4_PKT_I_RESERVED
Definition: trc_pkt_types_etmv4.h:58
ETM4_PKT_DADDR_P1_F2
@ ETM4_PKT_DADDR_P1_F2
b10xxxxxx
Definition: trc_pkt_types_etmv4.h:307
_ocsd_etmv4_i_pkt::res_1
uint32_t res_1
Definition: trc_pkt_types_etmv4.h:238
ETM4_PKT_I_COND_I_F2
@ ETM4_PKT_I_COND_I_F2
Definition: trc_pkt_types_etmv4.h:95
_ocsd_etmv4_i_pkt::dsm_val
uint8_t dsm_val
Data Sync Marker number, or unnumbered atom count - packet type determines.
Definition: trc_pkt_types_etmv4.h:220
_ocsd_etmv4_i_pkt::type
ocsd_etmv4_i_pkt_type type
Definition: trc_pkt_types_etmv4.h:183
ETM4_PKT_I_EXCEPT
@ ETM4_PKT_I_EXCEPT
Definition: trc_pkt_types_etmv4.h:72
ETM4_PKT_DSUPPRESSION
@ ETM4_PKT_DSUPPRESSION
b00000011
Definition: trc_pkt_types_etmv4.h:321
_ocsd_etmv4_i_pkt::f2_key_incr
uint32_t f2_key_incr
Definition: trc_pkt_types_etmv4.h:243
_ocsd_etmv4_i_pkt::f2_cond_incr
uint32_t f2_cond_incr
Definition: trc_pkt_types_etmv4.h:229
_ocsd_etmv4_i_pkt::context_valid
uint32_t context_valid
Definition: trc_pkt_types_etmv4.h:263
_ocsd_etmv4_i_pkt::addr_exact_match_idx
uint8_t addr_exact_match_idx
address match index in this packet.
Definition: trc_pkt_types_etmv4.h:219
_ocsd_etmv4_i_pkt::m_type
uint32_t m_type
1 if M class exception.
Definition: trc_pkt_types_etmv4.h:215
ETM4_PKT_DTIMESTAMP
@ ETM4_PKT_DTIMESTAMP
b00000010
Definition: trc_pkt_types_etmv4.h:304
_etmv4_trace_info_t::cond_enabled
uint32_t cond_enabled
conditional trace enabeld type
Definition: trc_pkt_types_etmv4.h:156
_ocsd_etmv4_cfg::reg_configr
uint32_t reg_configr
Definition: trc_pkt_types_etmv4.h:356
_etmv4_addr_val_t::val
ocsd_vaddr_t val
Address value.
Definition: trc_pkt_types_etmv4.h:177
_ocsd_etmv4_d_pkt::d_addr
ocsd_pkt_vaddr d_addr
Definition: trc_pkt_types_etmv4.h:337
_ocsd_etmv4_i_pkt::spec_depth_valid
uint32_t spec_depth_valid
Definition: trc_pkt_types_etmv4.h:265
_ocsd_etmv4_i_pkt::m_fault_pending
uint32_t m_fault_pending
M class fault pending.
Definition: trc_pkt_types_etmv4.h:214
_ocsd_etmv4_i_pkt::exceptionType
uint32_t exceptionType
exception number
Definition: trc_pkt_types_etmv4.h:212
ETM4_PKT_DEVENT
@ ETM4_PKT_DEVENT
b00000100
Definition: trc_pkt_types_etmv4.h:302
ETM4_PKT_DVAL_P2_F2
@ ETM4_PKT_DVAL_P2_F2
b00110xxx
Definition: trc_pkt_types_etmv4.h:315
ocsd_arch_version_t
enum _ocsd_arch_version ocsd_arch_version_t
_etmv4_context_t::ctxtID
uint32_t ctxtID
Current ctxtID.
Definition: trc_pkt_types_etmv4.h:171
_etmv4_context_t::updated_c
uint32_t updated_c
updated CtxtID
Definition: trc_pkt_types_etmv4.h:168
_etmv4_addr_val_t
Definition: trc_pkt_types_etmv4.h:176
_ocsd_etmv4_i_pkt::cc_thresh_valid
uint32_t cc_thresh_valid
Definition: trc_pkt_types_etmv4.h:270
ETM4_PKT_DTRACE_INFO
@ ETM4_PKT_DTRACE_INFO
b00000001
Definition: trc_pkt_types_etmv4.h:323
ETM4_PKT_I_ADDR_L_64IS1
@ ETM4_PKT_I_ADDR_L_64IS1
Definition: trc_pkt_types_etmv4.h:129
ETM4_PKT_DVAL_P2_F1
@ ETM4_PKT_DVAL_P2_F1
b0010xxxx
Definition: trc_pkt_types_etmv4.h:314
_ocsd_etmv4_i_pkt::p0_key_valid
uint32_t p0_key_valid
Definition: trc_pkt_types_etmv4.h:266
ETM4_PKT_D_NO_HEADER
@ ETM4_PKT_D_NO_HEADER
waiting for a header byte
Definition: trc_pkt_types_etmv4.h:292
_ocsd_etmv4_i_pkt::cond_c_key_valid
uint32_t cond_c_key_valid
Definition: trc_pkt_types_etmv4.h:267
_etmv4_context_t::VMID
uint32_t VMID
current VMID
Definition: trc_pkt_types_etmv4.h:172
_ocsd_etmv4_i_pkt::pkt_valid
union _ocsd_etmv4_i_pkt::@17 pkt_valid
valid bits for packet elements (addresses have their own valid bits).
_ocsd_etmv4_i_pkt::count_present
uint32_t count_present
Definition: trc_pkt_types_etmv4.h:254
ocsd_vaddr_t
uint64_t ocsd_vaddr_t
Definition: ocsd_if_types.h:308
ETM4_PKT_I_ADDR_CTXT_L_32IS1
@ ETM4_PKT_I_ADDR_CTXT_L_32IS1
Definition: trc_pkt_types_etmv4.h:114
_ocsd_etmv4_i_pkt::err_type
ocsd_etmv4_i_pkt_type err_type
Definition: trc_pkt_types_etmv4.h:277
ETM4_PKT_I_ADDR_L_32IS1
@ ETM4_PKT_I_ADDR_L_32IS1
Definition: trc_pkt_types_etmv4.h:126
_ocsd_etmv4_i_pkt::f3_final_elem
uint32_t f3_final_elem
Definition: trc_pkt_types_etmv4.h:228
_etmv4_addr_val_t::isa
uint8_t isa
instruction set.
Definition: trc_pkt_types_etmv4.h:178
_ocsd_etmv4_cfg::reg_idr12
uint32_t reg_idr12
Definition: trc_pkt_types_etmv4.h:354
ETM4_PKT_I_EXCEPT_RTN
@ ETM4_PKT_I_EXCEPT_RTN
Definition: trc_pkt_types_etmv4.h:73
_ocsd_etmv4_i_pkt::cycle_count
uint32_t cycle_count
cycle count
Definition: trc_pkt_types_etmv4.h:201
ETM4_PKT_DVAL_P2_F5
@ ETM4_PKT_DVAL_P2_F5
b00011xxx
Definition: trc_pkt_types_etmv4.h:318
ETM4_PKT_I_ADDR_CTXT_L_64IS0
@ ETM4_PKT_I_ADDR_CTXT_L_64IS0
Definition: trc_pkt_types_etmv4.h:116
_etmv4_context_t::EL
uint32_t EL
exception level.
Definition: trc_pkt_types_etmv4.h:164
_etmv4_trace_info_t::p0_load
uint32_t p0_load
1 if tracing with P0 load elements (for data trace)
Definition: trc_pkt_types_etmv4.h:157
ETM4_PKT_D_NOTSYNC
@ ETM4_PKT_D_NOTSYNC
no sync found yet
Definition: trc_pkt_types_etmv4.h:287
ETM4_PKT_I_CCNT_F1
@ ETM4_PKT_I_CCNT_F1
Definition: trc_pkt_types_etmv4.h:79
_ocsd_etmv4_i_pkt::ci_0
uint32_t ci_0
Definition: trc_pkt_types_etmv4.h:239
_ocsd_etmv4_i_pkt::q_count
uint32_t q_count
Definition: trc_pkt_types_etmv4.h:250
ETM4_PKT_D_EXTENSION
@ ETM4_PKT_D_EXTENSION
b00000000
Definition: trc_pkt_types_etmv4.h:298
ETM4_PKT_D_BAD_TRACEMODE
@ ETM4_PKT_D_BAD_TRACEMODE
invalid packet type for this trace mode.
Definition: trc_pkt_types_etmv4.h:289
_ocsd_etmv4_i_pkt::atom
ocsd_pkt_atom atom
atom elements - number of atoms indicates validity of packet
Definition: trc_pkt_types_etmv4.h:200
_ocsd_etmv4_i_pkt::cc_valid
uint32_t cc_valid
Definition: trc_pkt_types_etmv4.h:271
_ocsd_etmv4_d_pkt_type
_ocsd_etmv4_d_pkt_type
Definition: trc_pkt_types_etmv4.h:285
ETM4_PKT_I_TRACE_INFO
@ ETM4_PKT_I_TRACE_INFO
Definition: trc_pkt_types_etmv4.h:66
_ocsd_etmv4_i_pkt::key_res_1_set
uint32_t key_res_1_set
Definition: trc_pkt_types_etmv4.h:242
_ocsd_etmv4_i_pkt
Definition: trc_pkt_types_etmv4.h:182
ETM4_PKT_I_NO_ERR_TYPE
@ ETM4_PKT_I_NO_ERR_TYPE
Definition: trc_pkt_types_etmv4.h:53
_ocsd_etmv4_i_pkt::bits
struct _ocsd_etmv4_i_pkt::@17::@24 bits
_ocsd_pkt_vaddr
Definition: trc_pkt_types.h:59
_ocsd_etmv4_i_pkt::cond_c_key
uint32_t cond_c_key
Definition: trc_pkt_types_etmv4.h:224
_ocsd_etmv4_i_pkt::commit_elements
uint32_t commit_elements
Definition: trc_pkt_types_etmv4.h:206
_ocsd_etmv4_d_pkt::err_type
ocsd_etmv4_d_pkt_type err_type
Definition: trc_pkt_types_etmv4.h:341
ETM4_PKT_I_CTXT
@ ETM4_PKT_I_CTXT
Definition: trc_pkt_types_etmv4.h:112
ETM4_PKT_DADDR_P1_F3
@ ETM4_PKT_DADDR_P1_F3
b000101xx
Definition: trc_pkt_types_etmv4.h:308
ETM4_PKT_I_ATOM_F5
@ ETM4_PKT_I_ATOM_F5
Definition: trc_pkt_types_etmv4.h:139
ETM4_PKT_I_COMMIT
@ ETM4_PKT_I_COMMIT
Definition: trc_pkt_types_etmv4.h:87
ETM4_PKT_I_COND_I_F3
@ ETM4_PKT_I_COND_I_F3
Definition: trc_pkt_types_etmv4.h:105
ETM4_PKT_D_DISCARD
@ ETM4_PKT_D_DISCARD
b00000011
Definition: trc_pkt_types_etmv4.h:327
ETM4_PKT_I_ATOM_F6
@ ETM4_PKT_I_ATOM_F6
Definition: trc_pkt_types_etmv4.h:138
ETM4_PKT_I_EXTENSION
@ ETM4_PKT_I_EXTENSION
Definition: trc_pkt_types_etmv4.h:63
ETM4_PKT_I_Q
@ ETM4_PKT_I_Q
Definition: trc_pkt_types_etmv4.h:133
ETM4_PKT_I_ASYNC
@ ETM4_PKT_I_ASYNC
b00000000
Definition: trc_pkt_types_etmv4.h:146
ocsd_etmv4_i_pkt
struct _ocsd_etmv4_i_pkt ocsd_etmv4_i_pkt
_ocsd_etmv4_i_pkt::addr_match
uint32_t addr_match
Definition: trc_pkt_types_etmv4.h:253
_etmv4_trace_info_t::val
uint32_t val
trace info full value.
Definition: trc_pkt_types_etmv4.h:153
ETM4_PKT_I_OVERFLOW
@ ETM4_PKT_I_OVERFLOW
b00000101
Definition: trc_pkt_types_etmv4.h:148
ocsd_etmv4_cfg
struct _ocsd_etmv4_cfg ocsd_etmv4_cfg
etmv4_trace_info_t
union _etmv4_trace_info_t etmv4_trace_info_t
_ocsd_etmv4_i_pkt::Q_pkt
struct _ocsd_etmv4_i_pkt::@16 Q_pkt
_ocsd_etmv4_i_pkt::addr_present
uint32_t addr_present
Definition: trc_pkt_types_etmv4.h:252
ETM4_PKT_I_NOTSYNC
@ ETM4_PKT_I_NOTSYNC
Definition: trc_pkt_types_etmv4.h:51
_ocsd_etmv4_i_pkt::f3_tokens
uint32_t f3_tokens
Definition: trc_pkt_types_etmv4.h:245
ETM4_PKT_I_CCNT_F3
@ ETM4_PKT_I_CCNT_F3
Definition: trc_pkt_types_etmv4.h:80
_ocsd_etmv4_cfg::reg_idr13
uint32_t reg_idr13
Definition: trc_pkt_types_etmv4.h:355
ETM4_PKT_DVAL_P2_F4
@ ETM4_PKT_DVAL_P2_F4
b000100xx
Definition: trc_pkt_types_etmv4.h:317
_ocsd_etmv4_i_pkt::ts_valid
uint32_t ts_valid
Definition: trc_pkt_types_etmv4.h:264
ETM4_PKT_I_FUNC_RET
@ ETM4_PKT_I_FUNC_RET
Definition: trc_pkt_types_etmv4.h:70
ETM4_PKT_I_ADDR_MATCH
@ ETM4_PKT_I_ADDR_MATCH
Definition: trc_pkt_types_etmv4.h:120
ETM4_PKT_I_ADDR_L_64IS0
@ ETM4_PKT_I_ADDR_L_64IS0
Definition: trc_pkt_types_etmv4.h:128
trc_pkt_types.h
OpenCSD: Common "C" types for trace packets.
ocsd_etmv4_i_pkt_type
enum _ocsd_etmv4_i_pkt_type ocsd_etmv4_i_pkt_type
_ocsd_etmv4_cfg::reg_idr8
uint32_t reg_idr8
Definition: trc_pkt_types_etmv4.h:350
_ocsd_etmv4_i_pkt::err_hdr_val
uint8_t err_hdr_val
Definition: trc_pkt_types_etmv4.h:278
ETM4_PKT_I_BAD_SEQUENCE
@ ETM4_PKT_I_BAD_SEQUENCE
Definition: trc_pkt_types_etmv4.h:56
ETM4_PKT_DUNNUM_DS_MKR
@ ETM4_PKT_DUNNUM_DS_MKR
b00000001
Definition: trc_pkt_types_etmv4.h:300
_ocsd_etmv4_i_pkt::cond_key_set
uint32_t cond_key_set
Definition: trc_pkt_types_etmv4.h:227
etmv4_context_t
struct _etmv4_context_t etmv4_context_t
_ocsd_pkt_atom
Definition: trc_pkt_types.h:85
_ocsd_etmv4_i_pkt::res_0
uint32_t res_0
Definition: trc_pkt_types_etmv4.h:237
ETM4_PKT_I_ATOM_F2
@ ETM4_PKT_I_ATOM_F2
Definition: trc_pkt_types_etmv4.h:140
_ocsd_etmv4_i_pkt::context
etmv4_context_t context
current context for PE
Definition: trc_pkt_types_etmv4.h:190
_etmv4_context_t
Definition: trc_pkt_types_etmv4.h:162
ETM4_PKT_I_COND_RES_F1
@ ETM4_PKT_I_COND_RES_F1
Definition: trc_pkt_types_etmv4.h:103
_ocsd_etmv4_cfg::reg_idr11
uint32_t reg_idr11
Definition: trc_pkt_types_etmv4.h:353
ETM4_PKT_DADDR_P1_F5
@ ETM4_PKT_DADDR_P1_F5
b11111xxx
Definition: trc_pkt_types_etmv4.h:310
ocsd_etmv4_d_pkt
struct _ocsd_etmv4_d_pkt ocsd_etmv4_d_pkt
ETM4_PKT_D_INCOMPLETE_EOT
@ ETM4_PKT_D_INCOMPLETE_EOT
flushing incomplete packet at end of trace.
Definition: trc_pkt_types_etmv4.h:291
_ocsd_etmv4_cfg::reg_idr10
uint32_t reg_idr10
Definition: trc_pkt_types_etmv4.h:352
ocsd_etmv4_d_pkt_type
enum _ocsd_etmv4_d_pkt_type ocsd_etmv4_d_pkt_type
ETM4_PKT_I_NUM_DS_MKR
@ ETM4_PKT_I_NUM_DS_MKR
Definition: trc_pkt_types_etmv4.h:83
ETM4_PKT_I_CCNT_F2
@ ETM4_PKT_I_CCNT_F2
Definition: trc_pkt_types_etmv4.h:78
_ocsd_etmv4_i_pkt::event_val
uint8_t event_val
Event value on event packet.
Definition: trc_pkt_types_etmv4.h:221
_ocsd_etmv4_i_pkt::curr_spec_depth
uint32_t curr_spec_depth
current speculation depth
Definition: trc_pkt_types_etmv4.h:203
ETM4_PKT_I_COND_RES_F3
@ ETM4_PKT_I_COND_RES_F3
Definition: trc_pkt_types_etmv4.h:101
_ocsd_etmv4_i_pkt::p0_key
uint32_t p0_key
current P0 key value for data packet synchronisation
Definition: trc_pkt_types_etmv4.h:204
ETM4_PKT_I_ADDR_CTXT_L_32IS0
@ ETM4_PKT_I_ADDR_CTXT_L_32IS0
Definition: trc_pkt_types_etmv4.h:113
ETM4_PKT_I_BAD_TRACEMODE
@ ETM4_PKT_I_BAD_TRACEMODE
Definition: trc_pkt_types_etmv4.h:57
ETM4_PKT_DADDR_P1_F1
@ ETM4_PKT_DADDR_P1_F1
b0111xxxx
Definition: trc_pkt_types_etmv4.h:306
ETM4_PKT_I_RESERVED_CFG
@ ETM4_PKT_I_RESERVED_CFG
Definition: trc_pkt_types_etmv4.h:59
_etmv4_trace_info_t::bits
struct _etmv4_trace_info_t::@9 bits
bitfields for trace info value.
ETM4_PKT_DNUM_DS_MKR
@ ETM4_PKT_DNUM_DS_MKR
Definition: trc_pkt_types_etmv4.h:296
_ocsd_etmv4_i_pkt::key_res_0_set
uint32_t key_res_0_set
Definition: trc_pkt_types_etmv4.h:241
_ocsd_etmv4_i_pkt::bits_changed
uint8_t bits_changed
bits updated in this timestamp packet.
Definition: trc_pkt_types_etmv4.h:194
_ocsd_etmv4_cfg::reg_idr2
uint32_t reg_idr2
Definition: trc_pkt_types_etmv4.h:349
_ocsd_etmv4_d_pkt::pkt_val
uint64_t pkt_val
Definition: trc_pkt_types_etmv4.h:339
_ocsd_etmv4_i_pkt::cc_threshold
uint32_t cc_threshold
cycle count threshold - from trace info.
Definition: trc_pkt_types_etmv4.h:197
_ocsd_etmv4_cfg::core_prof
ocsd_core_profile_t core_prof
Definition: trc_pkt_types_etmv4.h:359
etmv4_addr_val_t
struct _etmv4_addr_val_t etmv4_addr_val_t
ETM4_PKT_I_MISPREDICT
@ ETM4_PKT_I_MISPREDICT
Definition: trc_pkt_types_etmv4.h:90
_ocsd_etmv4_i_pkt_type
_ocsd_etmv4_i_pkt_type
Definition: trc_pkt_types_etmv4.h:49
ETM4_PKT_I_COND_I_F1
@ ETM4_PKT_I_COND_I_F1
Definition: trc_pkt_types_etmv4.h:104
_ocsd_etmv4_d_pkt
Definition: trc_pkt_types_etmv4.h:334
_ocsd_etmv4_i_pkt::v_addr_ISA
uint8_t v_addr_ISA
ISA for the address packet. (0 = IS0 / 1 = IS1)
Definition: trc_pkt_types_etmv4.h:188
_ocsd_etmv4_i_pkt::trace_info
etmv4_trace_info_t trace_info
trace info structure - programmed configuration of trace capture.
Definition: trc_pkt_types_etmv4.h:209
_ocsd_etmv4_i_pkt::addr_interp
uint32_t addr_interp
address value interpretation
Definition: trc_pkt_types_etmv4.h:213
ETM4_PKT_I_IGNORE
@ ETM4_PKT_I_IGNORE
Definition: trc_pkt_types_etmv4.h:108
_ocsd_etmv4_i_pkt::trace_info_valid
uint32_t trace_info_valid
Definition: trc_pkt_types_etmv4.h:269
_ocsd_etmv4_i_pkt::f2f4_token
uint32_t f2f4_token
Definition: trc_pkt_types_etmv4.h:244
ETM4_PKT_I_CANCEL_F2
@ ETM4_PKT_I_CANCEL_F2
Definition: trc_pkt_types_etmv4.h:91