forked from ManuelvOK/cbs-with-runtime-prediction
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ctask.cc
78 lines (64 loc) · 2.19 KB
/
ctask.cc
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
#include "task.h"
#include "ctask.h"
#include <functional>
#include <vector>
using namespace std::chrono_literals;
using time_point = std::chrono::time_point<std::chrono::steady_clock>;
using duration = typename std::chrono::nanoseconds;
std::vector<Task<void *> *> tasks;
static std::vector<unsigned> get_cpus(int cpus) {
std::vector<unsigned> ret;
for (int i = 0; i < 8; ++i) {
if ((cpus >> i) % 2) {
ret.push_back(i);
}
}
return ret;
}
static std::vector<double> generate_metrics(struct metrics(*generate)(void *), void *data) {
std::vector<double> metrics;
if (generate == nullptr) {
return metrics;
}
struct metrics metrics_struct = generate(data);
for (int i = 0; i < metrics_struct.size; ++i) {
metrics.push_back(metrics_struct.data[i]);
}
delete metrics_struct.data;
return metrics;
}
int create_non_rt_task(int cpus, int id, void (*execute)(void *)) {
Task<void *> *task = new Task<void *>(id, std::function<void(void *)>(execute), get_cpus(cpus));
int handle = tasks.size();
tasks.push_back(task);
return handle;
}
int create_task(int cpus, int id, int period, void (*execute)(void *), int execution_time) {
Task<void *> *task = new Task<void *>(id, duration(period), std::function<void(void *)>(execute), duration(execution_time), get_cpus(cpus));
int handle = tasks.size();
tasks.push_back(task);
return handle;
}
int create_task_with_prediction(int cpus, int id, int period, void (*execute)(void *), struct metrics(*generate)(void *)) {
auto gen_metrics = std::bind(generate_metrics, generate, std::placeholders::_1);
Task<void *> *task = new Task<void *>(id, duration(period), std::function<void(void *)>(execute), gen_metrics, get_cpus(cpus));
int handle = tasks.size();
tasks.push_back(task);
return handle;
}
void add_job_to_task(int task, void *arg) {
tasks[task]->add_job(arg);
tasks[task]->sem().release();
}
void join_task(int task) {
tasks[task]->join();
}
int task_id(int task) {
return tasks[task]->id();
}
void release_sem(int task) {
tasks[task]->sem().release();
}
int task_period(int task) {
return tasks[task]->period() / 1ns;
}