summaryrefslogtreecommitdiffstats
path: root/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/DMSScheduler.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/DMSScheduler.cpp
downloadStudium-master.tar.gz
Studium-master.tar.bz2
add new repoHEADmaster
Diffstat (limited to 'Master/Real-Time Systems/Praktikum1/Aufgabe3/src/DMSScheduler.cpp')
-rw-r--r--Master/Real-Time Systems/Praktikum1/Aufgabe3/src/DMSScheduler.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/DMSScheduler.cpp b/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/DMSScheduler.cpp
new file mode 100644
index 0000000..7c40037
--- /dev/null
+++ b/Master/Real-Time Systems/Praktikum1/Aufgabe3/src/DMSScheduler.cpp
@@ -0,0 +1,57 @@
+/*
+ * DMSScheduler.cpp
+ *
+ * Created on: 02.11.2010
+ * Author: sven
+ */
+#ifndef GLOBAL_H_
+ #include "Global.h"
+#endif
+
+#include "DMSScheduler.h"
+#include <iostream>
+
+DMSScheduler::DMSScheduler() {
+ // TODO Auto-generated constructor stub
+
+}
+
+DMSScheduler::~DMSScheduler() {
+ // TODO Auto-generated destructor stub
+}
+void DMSScheduler::run(task_set& tasks,int ci)
+{
+ cout << "D M S" << endl;
+ for(unsigned int task_count = 0; task_count < tasks.size(); task_count++)
+ {
+ m_queue.push(&tasks[task_count]);
+ }
+ 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;
+ }
+}