X-Git-Url: http://plrg.eecs.uci.edu/git/?p=model-checker.git;a=blobdiff_plain;f=schedule.h;h=c18953d44824d09782e1cd389becbb96c181fb4c;hp=da91fddf976c8dd880a57b98476b9e3af76cdffd;hb=28617f0ed2d16491c86d040b323bfe07dcdf2421;hpb=c633515be9def3f6fd74843974b36d923d7b44a4 diff --git a/schedule.h b/schedule.h index da91fdd..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,16 +29,20 @@ 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() { return enabled; }; + enabled_type_t * get_enabled_array() const { return enabled; }; void remove_sleep(Thread *t); void add_sleep(Thread *t); - enabled_type_t get_enabled(Thread *t); + enabled_type_t get_enabled(const Thread *t) const; void update_sleep_set(Node *n); - bool is_enabled(Thread *t) const; + 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: