X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=schedule.h;h=c18953d44824d09782e1cd389becbb96c181fb4c;hb=e6789461057e3395ba78575b85c114b553f4ed19;hp=035ee78caadcedfc3119939a8f29028c5e269de7;hpb=221ebda053805a3a0f8353c282bf4f9988a7291b;p=model-checker.git diff --git a/schedule.h b/schedule.h index 035ee78..c18953d 100644 --- a/schedule.h +++ b/schedule.h @@ -5,8 +5,8 @@ #ifndef __SCHEDULE_H__ #define __SCHEDULE_H__ -#include #include "mymemory.h" +#include "modeltypes.h" /* Forward declaration */ class Thread; @@ -18,6 +18,8 @@ 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 { @@ -27,7 +29,8 @@ public: 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; }; @@ -38,6 +41,8 @@ public: bool is_enabled(const Thread *t) const; bool is_enabled(thread_id_t tid) const; bool is_sleep_set(const Thread *t) const; + bool all_threads_sleeping() const; + void set_scheduler_thread(thread_id_t tid); SNAPSHOTALLOC private: