aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJonathan Herman <hermanjl@cs.unc.edu>2012-09-28 16:52:08 -0400
committerJonathan Herman <hermanjl@cs.unc.edu>2012-09-28 16:52:08 -0400
commitfb90f3b6a8a604a9aed7249045bfed77ce42de5b (patch)
treef66d4c410e2ba637884cb232242cc1f4742d6de1
parent9f2cc91ad895214eafafe61eded30ad1c0b145bf (diff)
Move task time accounting into the complete_job method.
-rw-r--r--litmus/jobs.c27
1 files changed, 19 insertions, 8 deletions
diff --git a/litmus/jobs.c b/litmus/jobs.c
index 1dc97d32a35..8a0c889e2cb 100644
--- a/litmus/jobs.c
+++ b/litmus/jobs.c
@@ -5,18 +5,13 @@
5 5
6#include <litmus/litmus.h> 6#include <litmus/litmus.h>
7#include <litmus/jobs.h> 7#include <litmus/jobs.h>
8#include <litmus/trace.h>
8 9
9static inline void setup_release(struct task_struct *t, lt_t release) 10static inline void setup_release(struct task_struct *t, lt_t release)
10{ 11{
11 lt_t exec_time = tsk_rt(t)->job_params.exec_time;
12
13 tsk_rt(t)->tot_exec_time += exec_time;
14 if (tsk_rt(t)->max_exec_time < exec_time)
15 tsk_rt(t)->max_exec_time = exec_time;
16
17 /* prepare next release */ 12 /* prepare next release */
18 tsk_rt(t)->job_params.release = tsk_rt(t)->job_params.deadline; 13 tsk_rt(t)->job_params.release = release;
19 tsk_rt(t)->job_params.deadline += get_rt_period(t); 14 tsk_rt(t)->job_params.deadline += release + get_rt_period(t);
20 tsk_rt(t)->job_params.exec_time = 0; 15 tsk_rt(t)->job_params.exec_time = 0;
21 /* update job sequence number */ 16 /* update job sequence number */
22 tsk_rt(t)->job_params.job_no++; 17 tsk_rt(t)->job_params.job_no++;
@@ -52,6 +47,22 @@ void release_at(struct task_struct *t, lt_t start)
52 */ 47 */
53long complete_job(void) 48long complete_job(void)
54{ 49{
50 lt_t amount;
51 lt_t now = litmus_clock();
52 lt_t exec_time = tsk_rt(current)->job_params.exec_time;
53
54 tsk_rt(current)->tot_exec_time += exec_time;
55 if (lt_before(tsk_rt(current)->max_exec_time, exec_time))
56 tsk_rt(current)->max_exec_time = exec_time;
57
58 if (is_tardy(current, now)) {
59 amount = now - get_deadline(current);
60 if (lt_after(amount, tsk_rt(current)->max_tardy))
61 tsk_rt(current)->max_tardy = amount;
62 tsk_rt(current)->total_tardy += amount;
63 ++tsk_rt(current)->missed;
64 }
65
55 /* Mark that we do not excute anymore */ 66 /* Mark that we do not excute anymore */
56 set_rt_flags(current, RT_F_SLEEP); 67 set_rt_flags(current, RT_F_SLEEP);
57 /* call schedule, this will return when a new job arrives 68 /* call schedule, this will return when a new job arrives