From: Brian Norris Date: Tue, 20 Nov 2012 03:04:33 +0000 (-0800) Subject: model: add model_snapshot_members constructor/destructor X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=f0e93ec8d751c713fee90aa537025ff2e4a56daa;p=cdsspec-compiler.git model: add model_snapshot_members constructor/destructor --- diff --git a/model.cc b/model.cc index 8aef67d..4fdd860 100644 --- a/model.cc +++ b/model.cc @@ -37,6 +37,23 @@ struct bug_message { * Structure for holding small ModelChecker members that should be snapshotted */ struct model_snapshot_members { + model_snapshot_members() : + current_action(NULL), + /* First thread created will have id INITIAL_THREAD_ID */ + next_thread_id(INITIAL_THREAD_ID), + used_sequence_numbers(0), + nextThread(NULL), + next_backtrack(NULL), + bugs(), + stats() + { } + + ~model_snapshot_members() { + for (unsigned int i = 0; i < bugs.size(); i++) + delete bugs[i]; + bugs.clear(); + } + ModelAction *current_action; unsigned int next_thread_id; modelclock_t used_sequence_numbers; @@ -44,6 +61,8 @@ struct model_snapshot_members { ModelAction *next_backtrack; std::vector< bug_message *, SnapshotAlloc > bugs; struct execution_stats stats; + + SNAPSHOTALLOC }; /** @brief Constructor */ @@ -64,17 +83,13 @@ ModelChecker::ModelChecker(struct model_params params) : pending_rel_seqs(new std::vector< struct release_seq *, SnapshotAlloc >()), thrd_last_action(new std::vector< ModelAction *, SnapshotAlloc >(1)), node_stack(new NodeStack()), + priv(new struct model_snapshot_members()), mo_graph(new CycleGraph()), failed_promise(false), too_many_reads(false), asserted(false), bad_synchronization(false) { - /* Allocate this "size" on the snapshotting heap */ - priv = (struct model_snapshot_members *)snapshot_calloc(1, sizeof(*priv)); - /* First thread created will have id INITIAL_THREAD_ID */ - priv->next_thread_id = INITIAL_THREAD_ID; - /* Initialize a model-checker thread, for special ModelActions */ model_thread = new Thread(get_next_id()); thread_map->put(id_to_int(model_thread->get_id()), model_thread); @@ -103,11 +118,7 @@ ModelChecker::~ModelChecker() delete node_stack; delete scheduler; delete mo_graph; - - for (unsigned int i = 0; i < priv->bugs.size(); i++) - delete priv->bugs[i]; - priv->bugs.clear(); - snapshot_free(priv); + delete priv; } static action_list_t * get_safe_ptr_action(HashTable * hash, void * ptr) {