63 lines
3.1 KiB
C
63 lines
3.1 KiB
C
|
/* TRAX file header definition.
|
||
|
|
||
|
Copyright (c) 2007-2012 Tensilica Inc.
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||
|
a copy of this software and associated documentation files (the
|
||
|
"Software"), to deal in the Software without restriction, including
|
||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||
|
permit persons to whom the Software is furnished to do so, subject to
|
||
|
the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be included
|
||
|
in all copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||
|
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||
|
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||
|
|
||
|
|
||
|
#define TRAX_FHEAD_MAGIC "TRAXdmp"
|
||
|
#define TRAX_FHEAD_VERSION 1
|
||
|
|
||
|
/* Header flags: */
|
||
|
#define TRAX_FHEADF_OCD_ENABLED 0x00000001 /* set if OCD was enabled while capturing trace */
|
||
|
#define TRAX_FHEADF_TESTDUMP 0x00000002 /* set if is a test file
|
||
|
(from 'memsave' instead of 'save') */
|
||
|
#define TRAX_FHEADF_OCD_ENABLED_WHILE_EXIT 0x00000004 /* set if OCD was enabled while capturing trace and
|
||
|
we were exiting the OCD mode */
|
||
|
|
||
|
/* Header at the start of a TRAX dump file. */
|
||
|
typedef struct {
|
||
|
char magic[8]; /* 00: "TRAXdmp\0" (TRAX_FHEAD_MAGIC) */
|
||
|
char endianness; /* 08: 0=little-endian, 1=big-endian */
|
||
|
char version; /* 09: TRAX_FHEAD_VERSION */
|
||
|
char reserved0[2]; /* 0A: ... */
|
||
|
unsigned filesize; /* 0C: size of the trace file, including this header */
|
||
|
unsigned trace_ofs; /* 10: start of trace output, byte offset from start of header */
|
||
|
unsigned trace_size; /* 14: size of trace output in bytes */
|
||
|
unsigned dumptime; /* 18: date/time of capture save (secs since 1970-01-01), 0 if unknown */
|
||
|
unsigned flags; /* 1C: misc flags (TRAX_FHEAD_F_xxx) */
|
||
|
char username[16]; /* 20: user doing the capture/save (up to 15 chars) */
|
||
|
char toolver[24]; /* 30: tool + version used for capture/save (up to 23 chars) */
|
||
|
char reserved2[40]; /* 48: (reserved - could be hostname used for dump (up to 39 chars)) */
|
||
|
unsigned configid[2]; /* 70: processor ConfigID values, 0 if unknown */
|
||
|
unsigned ts_freq; /* 78: timestamp frequency, 0 if not specified */
|
||
|
unsigned reserved3; /* 7C: (reserved) */
|
||
|
unsigned id; /* 80: TRAX registers at time of save (0 if not read) */
|
||
|
unsigned control;
|
||
|
unsigned status;
|
||
|
unsigned reserved4; /* Data register (should not be read) */
|
||
|
unsigned address;
|
||
|
unsigned trigger;
|
||
|
unsigned match;
|
||
|
unsigned delay;
|
||
|
unsigned trax_regs[24]; /*100: (total size) -- dummy allocation (FIXME) */
|
||
|
} trax_file_header;
|
||
|
|