summaryrefslogtreecommitdiffstats
path: root/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp
diff options
context:
space:
mode:
authorSven Eisenhauer <sven@sven-eisenhauer.net>2023-11-10 15:11:48 +0100
committerSven Eisenhauer <sven@sven-eisenhauer.net>2023-11-10 15:11:48 +0100
commit33613a85afc4b1481367fbe92a17ee59c240250b (patch)
tree670b842326116b376b505ec2263878912fca97e2 /Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp
downloadStudium-master.tar.gz
Studium-master.tar.bz2
add new repoHEADmaster
Diffstat (limited to 'Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp')
-rw-r--r--Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp64
1 files changed, 64 insertions, 0 deletions
diff --git a/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp b/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp
new file mode 100644
index 0000000..df1bcdd
--- /dev/null
+++ b/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/RMSScheduler.cpp
@@ -0,0 +1,64 @@
+/*
+ * RMSScheduler.cpp
+ *
+ * Created on: 02.11.2010
+ * Author: sven
+ */
+
+#include "RMSScheduler.h"
+
+#ifndef RESPONSETIMEANALYSIS_H_
+ #include "ResponseTimeAnalysis.h"
+#endif
+
+#include <iostream>
+
+RMSScheduler::RMSScheduler() {
+ // TODO Auto-generated constructor stub
+
+}
+
+RMSScheduler::~RMSScheduler() {
+ // TODO Auto-generated destructor stub
+}
+void RMSScheduler::run(task_set& tasks,int ci)
+{
+ cout << "R M S" << endl;
+ for(unsigned int task_count = 0; task_count < tasks.size(); task_count++)
+ {
+ m_queue.push(&tasks[task_count]);
+ }
+ ResponseTimeAnalysis rta;
+ if(!rta.analyse(m_queue)) {
+ cout << "Task set not runnable. RTA failed" << endl;
+ return;
+ }
+ while (!m_queue.empty()) {
+ Task* t = m_queue.top();
+ t->dump();
+ m_queue.pop();
+ }
+ for(int step= 0; step < ci; step++)
+ {
+ cout << (step + 1) << " ";
+ for(unsigned int task_count = 0; task_count < tasks.size(); task_count++)
+ {
+ m_queue.push(&tasks[task_count]);
+ }
+ bool scheduledAtask = false;
+ while (!m_queue.empty()) {
+ Task* t = m_queue.top();
+ if(!scheduledAtask && (t->getActC() > 0) ) {
+ t->execute();
+ scheduledAtask = true;
+ } else {
+ t->requeue();
+ }
+ m_queue.pop();
+ }
+ if (!scheduledAtask) {
+ cout << "no task needs to run";
+ }
+ cout << endl;
+ }
+}