From 7bc6dafdcd7ab881e3fa0c62c433c0230308dffb Mon Sep 17 00:00:00 2001 From: Marion Guthmuller Date: Sat, 2 Jun 2012 16:49:42 +0200 Subject: [PATCH] model-checker : add pair's number in struct mc_pair_reached and prepare canonicalisation in comparison of regions --- src/mc/mc_liveness.c | 29 +++++++++++++++++++++++------ src/mc/mc_private.h | 1 + 2 files changed, 24 insertions(+), 6 deletions(-) diff --git a/src/mc/mc_liveness.c b/src/mc/mc_liveness.c index 9ea615fa67..241baab292 100644 --- a/src/mc/mc_liveness.c +++ b/src/mc/mc_liveness.c @@ -46,6 +46,7 @@ const char* get_memory_map_addr(void *addr){ perror("fopen failed"); if(addr == NULL){ + free(line); fclose(fp); return "nil"; } @@ -90,18 +91,25 @@ int data_program_region_compare(void *d1, void *d2, size_t size){ int distance = 0; int pointer_align; int i; + char *pointed_address1, *pointed_address2; for(i=0; inb); if(automaton_state_compare(pair_test->automaton_state, st) == 0){ if(propositional_symbols_compare_value(pair_test->prop_ato, prop_ato) == 0){ //XBT_INFO("Rdv points size %d - %d", xbt_dict_length(pair_test->rdv_points), xbt_dict_length(current_rdv_points)); //if(xbt_dict_length(pair_test->rdv_points) == xbt_dict_length(current_rdv_points)){ //if(rdv_points_compare(pair_test->rdv_points, current_rdv_points) == 0){ if(snapshot_compare(pair_test->system_state, sn, std_heap, raw_heap) == 0){ + MC_free_snapshot(sn); xbt_dynar_reset(prop_ato); xbt_free(prop_ato); @@ -429,6 +445,7 @@ void set_pair_reached(xbt_state_t st){ mc_pair_reached_t pair = NULL; pair = xbt_new0(s_mc_pair_reached_t, 1); + pair->nb = xbt_dynar_length(reached_pairs) + 1; pair->automaton_state = st; pair->prop_ato = xbt_dynar_new(sizeof(int), NULL); pair->system_state = xbt_new0(s_mc_snapshot_t, 1); @@ -992,7 +1009,7 @@ void MC_ddfs(int search_cycle){ mc_pair_stateless_t next_pair = NULL; mc_pair_stateless_t pair_succ; - + if(xbt_fifo_size(mc_stack_liveness) < MAX_DEPTH_LIVENESS){ //set_pair_visited(current_pair->automaton_state, search_cycle); @@ -1012,7 +1029,7 @@ void MC_ddfs(int search_cycle){ xbt_free(req_str); MC_state_set_executed_request(current_pair->graph_state, req, value); - + /* Answer the request */ SIMIX_simcall_pre(req, value); @@ -1226,7 +1243,7 @@ void MC_ddfs(int search_cycle){ //if(reached_hash(pair_succ->automaton_state)){ XBT_INFO("Next pair (depth = %d) already reached !", xbt_fifo_size(mc_stack_liveness) + 1); - + XBT_INFO("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*"); XBT_INFO("| ACCEPTANCE CYCLE |"); XBT_INFO("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*"); diff --git a/src/mc/mc_private.h b/src/mc/mc_private.h index a34855fae3..1d24b20701 100644 --- a/src/mc/mc_private.h +++ b/src/mc/mc_private.h @@ -217,6 +217,7 @@ typedef struct s_mc_pair{ }s_mc_pair_t, *mc_pair_t; typedef struct s_mc_pair_reached{ + int nb; xbt_state_t automaton_state; xbt_dynar_t prop_ato; mc_snapshot_t system_state; -- 2.20.1