changes to fix at least a bug
[model-checker.git] / schedule.cc
index f68cb528a16b846a2f2653ecd3336b6ca496fee8..1cd5b0f1a9f3db7410965a8afad7e67f27a360d3 100644 (file)
@@ -43,7 +43,9 @@ bool Scheduler::is_enabled(Thread *t) const
 }
 
 enabled_type_t Scheduler::get_enabled(Thread *t) {
-       return enabled[id_to_int(t->get_id())];
+       int id = id_to_int(t->get_id());
+       ASSERT(id<enabled_len);
+       return enabled[id];
 }
 
 void Scheduler::update_sleep_set(Node *n) {
@@ -148,7 +150,7 @@ Thread * Scheduler::next_thread(Thread *t)
                        thread_id_t curr_tid=int_to_id(curr_thread_index);
                        if (enabled[curr_thread_index]==THREAD_ENABLED&&
                                        (!have_enabled_thread_with_priority||n->has_priority(curr_tid))) {
-                               t = model->get_thread(int_to_id(curr_tid));
+                               t = model->get_thread(curr_tid);
                                break;
                        }
                        if (curr_thread_index == old_curr_thread) {