aboutsummaryrefslogtreecommitdiffstats
path: root/logformat.h
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