cf1272f712afe7540c10da524c8284b0007fe36f
[des2015.git] / mart / ex10 / ex10a.c
1 #include <stdio.h>
2 #include <signal.h>
3 #include <unistd.h>
4 #include <sys/mman.h>
5
6 #include <native/task.h>
7 #include <native/timer.h>
8
9 #include <rtdk.h>
10
11 #define SAMPLES 10000
12 RT_TASK task;
13
14 RTIME times[SAMPLES];
15
16 void taskf(void *arg)
17 {
18 rt_task_set_periodic(NULL, TM_NOW, 1e5);
19
20 unsigned int i;
21 for(i = 0; i<SAMPLES; i++){
22 times[i] = rt_timer_read();
23 rt_task_wait_period(NULL);
24 }
25 FILE *file;
26 file = fopen("ex10ab.csv", "w");
27 for(i = 0; i<SAMPLES-1; i++){
28 fprintf(file, "%u,%llu\n", i, times[i+1]-times[i]);
29 }
30 fclose(file);
31 }
32
33 int main(int argc, char* argv[])
34 {
35 rt_print_auto_init(1);
36 mlockall(MCL_CURRENT | MCL_FUTURE);
37 rt_task_create(&task, NULL, 0, 50, 0);
38 rt_task_start(&task, &taskf, NULL);
39 sleep(2);
40 }