X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=promise.cc;h=68290eecefac6c7ed72673e01a941e9f0afda3be;hb=17b667f2d53729212d23e62a3f9464b8180e01f6;hp=5197ed3a1e0376d1ea4f6060bcfa042f7cd4f0e9;hpb=b4a228de75d93aad50a07b3b048f69bc57ba2dd8;p=model-checker.git diff --git a/promise.cc b/promise.cc index 5197ed3..68290ee 100644 --- a/promise.cc +++ b/promise.cc @@ -4,7 +4,7 @@ bool Promise::increment_threads(thread_id_t tid) { unsigned int id=id_to_int(tid); - if (id>=synced_thread.size()) { + if ( id >= synced_thread.size() ) { synced_thread.resize(id+1, false); } if (synced_thread[id]) @@ -12,10 +12,23 @@ bool Promise::increment_threads(thread_id_t tid) { synced_thread[id]=true; enabled_type_t * enabled=model->get_scheduler()->get_enabled(); + unsigned int sync_size=synced_thread.size(); + int promise_tid=id_to_int(read->get_tid()); + for(unsigned int i=1;iget_num_threads();i++) { + if ((i >= sync_size || !synced_thread[i]) && ( (int)i != promise_tid ) && (enabled[i] != THREAD_DISABLED)) { + return false; + } + } + return true; +} - for(unsigned int i=0;iget_num_threads();i++) { - if (!synced_thread[id] && (enabled[id] == THREAD_ENABLED)) +bool Promise::check_promise() { + enabled_type_t * enabled=model->get_scheduler()->get_enabled(); + unsigned int sync_size=synced_thread.size(); + for(unsigned int i=1;iget_num_threads();i++) { + if ((i >= sync_size || !synced_thread[i]) && (enabled[i] != THREAD_DISABLED)) { return false; + } } return true; }