Skip to content

Commit cac7293

Browse files
committed
Add and check type of pointees in memory analyzer
GDB does not know (the CBMC) types but the resulting symbol table requires them. Also prevents catch-by-value error when compiled with gcc-8.
1 parent cd35287 commit cac7293

File tree

1 file changed

+7
-3
lines changed

1 file changed

+7
-3
lines changed

src/memory-analyzer/analyze_symbol.cpp

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -68,7 +68,7 @@ void gdb_value_extractort::analyze_symbol(const irep_idt &symbol_name)
6868

6969
add_assignment(symbol_expr, target_expr);
7070
}
71-
catch(gdb_interaction_exceptiont e)
71+
catch(gdb_interaction_exceptiont &e)
7272
{
7373
throw analysis_exceptiont(e.what());
7474
}
@@ -294,7 +294,9 @@ exprt gdb_value_extractort::get_non_char_pointer_value(
294294
}
295295
else
296296
{
297-
return it->second;
297+
const symbol_exprt typed_symbol_value = symbol_exprt{
298+
to_symbol_expr(it->second).get_identifier(), expr.type().subtype()};
299+
return typed_symbol_value;
298300
}
299301
}
300302

@@ -350,7 +352,9 @@ exprt gdb_value_extractort::get_pointer_value(
350352
}
351353
else
352354
{
353-
return address_of_exprt(target_expr);
355+
const auto result_expr = address_of_exprt(target_expr);
356+
CHECK_RETURN(result_expr.type() == zero_expr.type());
357+
return result_expr;
354358
}
355359
}
356360
}

0 commit comments

Comments
 (0)