blob: 3a74bf774950b319be4add69bce53af5cdcf661b (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
#ifndef LOGFORMAT_H
#define LOGFORMAT_H
#include <linux/types.h>
#include "litmus.h"
typedef __u8 u8;
typedef __u32 u32;
typedef __u16 u16;
typedef enum {
ST_INVOCATION = 0,
ST_ARRIVAL = 1,
ST_DEPARTURE = 2,
ST_PREEMPTION = 3,
ST_SCHEDULED = 4,
ST_JOB_RELEASE = 5,
ST_JOB_COMPLETION = 6,
ST_CAPACITY_RELEASE = 7,
ST_CAPACITY_ALLOCATION = 8,
ST_LAST_TYPE = 8
} trace_type_t;
typedef struct {
trace_type_t trace:8;
unsigned long long timestamp;
} trace_header_t;
typedef struct {
unsigned int is_rt:1;
unsigned int is_server:1;
task_class_t cls:4;
unsigned int budget:24;
u32 deadline;
pid_t pid;
} task_info_t;
typedef struct {
trace_header_t header;
unsigned long flags;
} invocation_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
} arrival_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
} departure_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
task_info_t by;
} preemption_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
} scheduled_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
u16 period;
u16 wcet;
} release_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
u16 period;
u16 wcet;
int tardiness;
} completion_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
} cap_release_record_t;
typedef struct {
trace_header_t header;
task_info_t task;
u16 budget;
u32 deadline;
pid_t donor;
} cap_allocation_record_t;
typedef union {
trace_header_t header;
invocation_record_t invocation;
arrival_record_t arrival;
preemption_record_t preemption;
scheduled_record_t scheduled;
release_record_t release;
completion_record_t completion;
cap_release_record_t cap_release;
cap_allocation_record_t cap_alloc;
} trace_record_t;
#endif
|