Subversion Repositories shark

Rev

Rev 377 | Rev 445 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
352 giacomo 1
/*
2
 
3
  Events List File, from York University and F.I.R.S.T project
4
 
5
*/
6
 
7
 
8
#ifndef __FTrace__
9
#define __FTrace__
10
 
11
 
12
// List of events, these are 8 bit constants, the 
13
// the low 4 bits, indicates its class, 
14
// the high 4 bits indicate the type of event in the class.
15
// (This allows an easy mechanisms for filtering events)
16
 
17
// general trace events
18
#define FTrace_EVT_ticks_per_sec      0x00
19
#define FTrace_EVT_cycles_per_tick    0x10
20
#define FTrace_EVT_trace_start        0x20
21
#define FTrace_EVT_trace_stop         0x30
22
#define FTrace_EVT_blackout_start     0x40
23
#define FTrace_EVT_blackout_end       0x50
24
#define FTrace_EVT_id                 0x60 //??
25
#define FTrace_EVT_numeevents         0x70
26
 
27
// lightweight tracing events
28
#define FTrace_EVT_ipoint             0x01
29
 
30
// Task related events
31
#define FTrace_EVT_task_create        0x02
32
#define FTrace_EVT_task_activate      0x12
33
#define FTrace_EVT_task_dispatch      0x22
34
#define FTrace_EVT_task_epilogue      0x32
35
#define FTrace_EVT_task_end           0x42
36
#define FTrace_EVT_task_begin_cycle   0x52
37
#define FTrace_EVT_task_end_cycle     0x62
38
#define FTrace_EVT_task_sleep         0x72
39
#define FTrace_EVT_task_schedule      0x82
355 giacomo 40
#define FTrace_EVT_task_timer         0x92
41
#define FTrace_EVT_task_disable       0xA2
352 giacomo 42
 
43
// interrupt events, even more lightweight than ipoints
44
#define FTrace_EVT_interrupt_start    0x03
45
#define FTrace_EVT_interrupt_end      0x13
46
#define FTrace_EVT_interrupt_hit      0x23 // instant where interrupt was hit (no end)
47
#define FTrace_EVT_interrupt_count    0x33 // number of interrupts raised since last interrupt_count
48
 
49
// other CPU specific events
50
#define FTrace_EVT_to_real_mode       0x04
51
#define FTrace_EVT_to_protected_mode  0x14
52
#define FTrace_EVT_CLI                0x24
53
#define FTrace_EVT_STI                0x34
54
 
55
// Changes on task attributes and state
56
#define FTrace_EVT_set_priority       0x05
57
#define FTrace_EVT_context_switch     0x15
386 giacomo 58
#define FTrace_EVT_inheritance        0x25
59
 
352 giacomo 60
// mutex events
61
#define FTrace_EVT_set_mutex_create   0x06
62
#define FTrace_EVT_set_mutex_lock     0x16
63
#define FTrace_EVT_set_mutex_inherit  0x26
64
#define FTrace_EVT_set_mutex_unlock   0x36
355 giacomo 65
#define FTrace_EVT_set_mutex_wait     0x46
352 giacomo 66
 
67
// signal events
68
#define FTrace_EVT_signal             0x07
69
// more here (MarteOS)
70
 
71
// specific server events
72
#define FTrace_EVT_server_create      0x08
73
#define FTrace_EVT_server_replenish   0x18
74
#define FTrace_EVT_server_exhaust     0x28
362 giacomo 75
#define FTrace_EVT_server_reclaiming  0x38
377 giacomo 76
#define FTrace_EVT_server_remove      0x48
77
#define FTrace_EVT_server_active      0x58
386 giacomo 78
#define FTrace_EVT_server_using_rec   0x68
352 giacomo 79
 
80
// user defined events
81
#define FTrace_EVT_user_event_0       0x09
82
#define FTrace_EVT_user_event_1       0x19
83
#define FTrace_EVT_user_event_2       0x29
84
#define FTrace_EVT_user_event_3       0x39
85
#define FTrace_EVT_user_event_4       0x49
86
#define FTrace_EVT_user_event_5       0x59
87
#define FTrace_EVT_user_event_6       0x69
88
#define FTrace_EVT_user_event_7       0x79
89
#define FTrace_EVT_user_event_8       0x89
90
#define FTrace_EVT_user_event_9       0x99
91
#define FTrace_EVT_user_event_10      0xA9
92
#define FTrace_EVT_user_event_11      0xB9
93
#define FTrace_EVT_user_event_12      0xC9
94
#define FTrace_EVT_user_event_13      0xD9
95
#define FTrace_EVT_user_event_14      0xE9
96
#define FTrace_EVT_user_event_15      0xF9
97
 
98
// Timer Events
99
#define FTrace_EVT_timer_post         0x0B
100
#define FTrace_EVT_timer_delete       0x1B
101
#define FTrace_EVT_timer_wakeup_start 0x2B
102
#define FTrace_EVT_timer_wakeup_end   0x3B
103
 
104
// generic data events
105
#define FTrace_EVT_data_pointer       0x1A // holds a pointer of data from 
106
// previous event
107
 
108
// types of the data pointer
109
#define FTrace_DATA_int               1
110
#define FTrace_DATA_char              2
111
 
112
// filter definitions
113
#define FTrace_filter_trace_Events    0xF0
114
#define FTrace_filter_ipoint          0xF1
115
#define FTrace_filter_task            0xF2
116
#define FTrace_filter_interrupt       0xF3
117
#define FTrace_filter_CPU             0xF4
118
#define FTrace_filter_priority        0xF5
119
#define FTrace_filter_mutex           0xF6
120
#define FTrace_filter_signal          0xF7
121
#define FTrace_filter_server          0xF8
122
#define FTrace_filter_user            0xF9
123
#define FTrace_filter_data            0xFA
124
#define FTrace_filter_timer           0xFB
125
 
126
#endif