projects
/
cdsspec-compiler.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add example from java showing legit satisfaction cycle
[cdsspec-compiler.git]
/
action.cc
diff --git
a/action.cc
b/action.cc
index e2557f0ad9fe3bac1083aca81fc67749dc6e8e82..3d38e81c93d1111bf8828448fd5a52718c17eea6 100644
(file)
--- a/
action.cc
+++ b/
action.cc
@@
-478,7
+478,10
@@
void ModelAction::set_read_from(const ModelAction *act)
reads_from = act;
reads_from_promise = NULL;
if (act->is_uninitialized())
reads_from = act;
reads_from_promise = NULL;
if (act->is_uninitialized())
- model->assert_bug("May read from uninitialized atomic\n");
+ model->assert_bug("May read from uninitialized atomic:\n"
+ " action %d, thread %d, location %p (%s, %s)",
+ seq_number, id_to_int(tid), location,
+ get_type_str(), get_mo_str());
}
/**
}
/**
@@
-566,25
+569,25
@@
void ModelAction::print() const
{
const char *type_str = get_type_str(), *mo_str = get_mo_str();
{
const char *type_str = get_type_str(), *mo_str = get_mo_str();
- model_print("
(%4d) Thread: %-2d Action: %-13s MO: %7s Loc: %14p Value:
%-#18" PRIx64,
+ model_print("
%-4d %-2d %-13s %7s %14p
%-#18" PRIx64,
seq_number, id_to_int(tid), type_str, mo_str, location, get_return_value());
if (is_read()) {
if (reads_from)
seq_number, id_to_int(tid), type_str, mo_str, location, get_return_value());
if (is_read()) {
if (reads_from)
- model_print("
Rf:
%-3d", reads_from->get_seq_number());
+ model_print(" %-3d", reads_from->get_seq_number());
else if (reads_from_promise) {
int idx = reads_from_promise->get_index();
if (idx >= 0)
else if (reads_from_promise) {
int idx = reads_from_promise->get_index();
if (idx >= 0)
- model_print("
Rf:
P%-2d", idx);
+ model_print(" P%-2d", idx);
else
else
- model_print("
Rf:
P? ");
+ model_print(" P? ");
} else
} else
- model_print("
Rf:
? ");
+ model_print(" ? ");
}
if (cv) {
if (is_read())
model_print(" ");
else
}
if (cv) {
if (is_read())
model_print(" ");
else
- model_print("
");
+ model_print(" ");
cv->print();
} else
model_print("\n");
cv->print();
} else
model_print("\n");