CBMC
cover_instrument_branch.cpp
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module: Coverage Instrumentation
4 
5 Author: Daniel Kroening
6 
7 \*******************************************************************/
8 
11 
12 #include "cover_basic_blocks.h"
13 #include "cover_filter.h"
14 #include "cover_instrument.h"
15 
17  const irep_idt &function_id,
18  goto_programt &goto_program,
20  const cover_blocks_baset &basic_blocks,
21  const assertion_factoryt &make_assertion) const
22 {
23  if(is_non_cover_assertion(i_it))
24  i_it->turn_into_skip();
25 
26  const bool is_function_entry_point =
27  i_it == goto_program.instructions.begin();
28  const bool is_conditional_goto =
29  i_it->is_goto() && !i_it->condition().is_true();
30  if(!is_function_entry_point && !is_conditional_goto)
31  return;
32 
33  if(!goal_filters(i_it->source_location()))
34  return;
35 
36  if(is_function_entry_point)
37  {
38  // we want branch coverage to imply 'entry point of function'
39  // coverage
40  std::string comment = "entry point";
41 
42  source_locationt source_location = i_it->source_location();
43 
44  goto_programt::targett t = goto_program.insert_before(
45  i_it, make_assertion(false_exprt(), source_location));
46  initialize_source_location(t, comment, function_id);
47  }
48 
49  if(is_conditional_goto)
50  {
51  std::string b =
52  std::to_string(basic_blocks.block_of(i_it) + 1); // start with 1
53  std::string true_comment = "block " + b + " branch true";
54  std::string false_comment = "block " + b + " branch false";
55 
56  exprt guard = i_it->condition();
57  source_locationt source_location = i_it->source_location();
58 
59  goto_program.insert_before_swap(i_it);
60  *i_it = make_assertion(not_exprt(guard), source_location);
61  initialize_source_location(i_it, true_comment, function_id);
62 
63  goto_program.insert_before_swap(i_it);
64  *i_it = make_assertion(guard, source_location);
65  initialize_source_location(i_it, false_comment, function_id);
66 
67  std::advance(i_it, 2);
68  }
69 }
dstringt
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
Definition: dstring.h:36
cover_instrumenter_baset::is_non_cover_assertion
bool is_non_cover_assertion(goto_programt::const_targett t) const
Definition: cover_instrument.h:95
cover_instrumenter_baset::initialize_source_location
void initialize_source_location(goto_programt::targett t, const std::string &comment, const irep_idt &function_id) const
Definition: cover_instrument.h:83
exprt
Base class for all expressions.
Definition: expr.h:55
to_string
std::string to_string(const string_not_contains_constraintt &expr)
Used for debug printing.
Definition: string_constraint.cpp:58
cover_instrumenter_baset::goal_filters
const goal_filterst & goal_filters
Definition: cover_instrument.h:73
goto_programt::insert_before
targett insert_before(const_targett target)
Insertion before the instruction pointed-to by the given instruction iterator target.
Definition: goto_program.h:662
cover_instrument.h
cover_blocks_baset
Definition: cover_basic_blocks.h:25
cover_branch_instrumentert::instrument
void instrument(const irep_idt &function_id, goto_programt &, goto_programt::targett &, const cover_blocks_baset &, const assertion_factoryt &) const override
Override this method to implement an instrumenter.
Definition: cover_instrument_branch.cpp:16
false_exprt
The Boolean constant false.
Definition: std_expr.h:3016
cover_instrumenter_baset::assertion_factoryt
std::function< goto_programt::instructiont(const exprt &, const source_locationt &)> assertion_factoryt
The type of function used to make goto_program assertions.
Definition: cover_instrument.h:42
source_locationt
Definition: source_location.h:18
goto_programt::instructions
instructionst instructions
The list of instructions in the goto program.
Definition: goto_program.h:592
cover_basic_blocks.h
goto_programt
A generic container class for the GOTO intermediate representation of one function.
Definition: goto_program.h:72
goto_programt::insert_before_swap
void insert_before_swap(targett target)
Insertion that preserves jumps to "target".
Definition: goto_program.h:613
comment
static std::string comment(const rw_set_baset::entryt &entry, bool write)
Definition: race_check.cpp:109
cover_blocks_baset::block_of
virtual std::size_t block_of(goto_programt::const_targett t) const =0
cover_filter.h
goto_programt::targett
instructionst::iterator targett
Definition: goto_program.h:586
not_exprt
Boolean negation.
Definition: std_expr.h:2277