fix mutex_trylock bug
[c11tester.git] / schedule.h
index 83b25c61cdc1d296f404fe244d185db4e6f3d7f7..8e5554aec049ceee46f7bc1e4bf4cc9aa17b7c9f 100644 (file)
@@ -6,10 +6,8 @@
 #define __SCHEDULE_H__
 
 #include "mymemory.h"
-
-/* Forward declaration */
-class Thread;
-class Node;
+#include "modeltypes.h"
+#include "classlist.h"
 
 typedef enum enabled_type {
        THREAD_DISABLED,
@@ -17,29 +15,37 @@ typedef enum enabled_type {
        THREAD_SLEEP_SET
 } enabled_type_t;
 
+void enabled_type_to_string(enabled_type_t e, char *str);
+
 /** @brief The Scheduler class performs the mechanics of Thread execution
  * scheduling. */
 class Scheduler {
 public:
        Scheduler();
+       void register_engine(ModelExecution *execution);
+
        void add_thread(Thread *t);
        void remove_thread(Thread *t);
        void sleep(Thread *t);
        void wake(Thread *t);
-       Thread * next_thread(Thread *t);
+       Thread * select_next_thread();
+       void set_current_thread(Thread *t);
        Thread * get_current_thread() const;
        void print() const;
        enabled_type_t * get_enabled_array() const { return enabled; };
        void remove_sleep(Thread *t);
        void add_sleep(Thread *t);
        enabled_type_t get_enabled(const Thread *t) const;
-       void update_sleep_set(Node *n);
        bool is_enabled(const Thread *t) const;
        bool is_enabled(thread_id_t tid) const;
        bool is_sleep_set(const Thread *t) const;
+       bool is_sleep_set(thread_id_t tid) const;
+       bool all_threads_sleeping() const;
+       void set_scheduler_thread(thread_id_t tid);
 
        SNAPSHOTALLOC
 private:
+       ModelExecution *execution;
        /** The list of available Threads that are not currently running */
        enabled_type_t *enabled;
        int enabled_len;
@@ -50,4 +56,4 @@ private:
        Thread *current;
 };
 
-#endif /* __SCHEDULE_H__ */
+#endif /* __SCHEDULE_H__ */