X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=clockvector.cc;h=0945bcf751dcd7eca5de6159affea9db49c58e3f;hb=5178739a27add5e59a1213c9ac90e73397c1a23d;hp=7d947c63873cc41abc2b0cfb2cff85868ba6765d;hpb=dd7f61668db41bed95b0cbf43f0b2cad5cd41060;p=model-checker.git diff --git a/clockvector.cc b/clockvector.cc index 7d947c6..0945bcf 100644 --- a/clockvector.cc +++ b/clockvector.cc @@ -37,21 +37,25 @@ ClockVector::~ClockVector() * resulting vector length will be the maximum length of the two being merged. * @param cv is the ClockVector being merged into this vector. */ -void ClockVector::merge(const ClockVector *cv) +bool ClockVector::merge(const ClockVector *cv) { ASSERT(cv != NULL); - + bool changed = false; if (cv->num_threads > num_threads) { clock = (modelclock_t *)snapshot_realloc(clock, cv->num_threads * sizeof(modelclock_t)); - for (int i= num_threads; i < cv->num_threads; i++) + for (int i = num_threads; i < cv->num_threads; i++) clock[i] = 0; num_threads = cv->num_threads; } /* Element-wise maximum */ for (int i = 0; i < cv->num_threads; i++) - if (cv->clock[i] > clock[i]) + if (cv->clock[i] > clock[i]) { clock[i] = cv->clock[i]; + changed = true; + } + + return changed; } /** @@ -75,17 +79,6 @@ bool ClockVector::synchronized_since(const ModelAction *act) const return false; } -bool ClockVector::has_synchronized_with(const ClockVector *cv) const -{ - ASSERT(cv); - if (cv->num_threads > num_threads) - return false; - for (int i = 0; i < cv->num_threads; i++) - if (cv->clock[i] > clock[i]) - return false; - return true; -} - /** Gets the clock corresponding to a given thread id from the clock vector. */ modelclock_t ClockVector::getClock(thread_id_t thread) { int threadid = id_to_int(thread); @@ -100,7 +93,7 @@ modelclock_t ClockVector::getClock(thread_id_t thread) { void ClockVector::print() const { int i; - printf("CV: ("); + model_print("CV: ("); for (i = 0; i < num_threads; i++) - printf("%2u%s", clock[i], (i == num_threads - 1) ? ")\n" : ", "); + model_print("%2u%s", clock[i], (i == num_threads - 1) ? ")\n" : ", "); }