[Inferbo] Bugfix: incorrect pruning for unary negation

Reviewed By: jvillard

Differential Revision: D5716888

fbshipit-source-id: abc1e54
master
Sungkeun Cho 7 years ago committed by Facebook Github Bot
parent fd105802db
commit e5ee27af20

@ -325,7 +325,7 @@ module Make (CFG : ProcCfg.S) = struct
match Mem.find_alias x mem with
| Some lv
-> let v = Mem.find_heap lv mem in
let itv_v = Itv.prune_ne (Val.get_itv v) Itv.false_sem in
let itv_v = Itv.prune_eq (Val.get_itv v) Itv.false_sem in
let v' = Val.modify_itv itv_v v in
Mem.update_mem (PowLoc.singleton lv) v' mem
| None

@ -47,6 +47,9 @@ codetoanalyze/c/bufferoverrun/prune_alias.c, prune_alias_not_Ok, 11, CONDITION_A
codetoanalyze/c/bufferoverrun/prune_alias.c, prune_alias_or_Ok, 3, CONDITION_ALWAYS_FALSE, []
codetoanalyze/c/bufferoverrun/prune_alias.c, prune_alias_or_Ok, 3, CONDITION_ALWAYS_FALSE, []
codetoanalyze/c/bufferoverrun/prune_constant.c, prune_constant_false_Ok, 3, CONDITION_ALWAYS_FALSE, []
codetoanalyze/c/bufferoverrun/prune_constant.c, prune_constant_not_Bad, 3, CONDITION_ALWAYS_FALSE, []
codetoanalyze/c/bufferoverrun/prune_constant.c, prune_constant_not_Bad, 3, CONDITION_ALWAYS_TRUE, []
codetoanalyze/c/bufferoverrun/prune_constant.c, prune_constant_not_Bad, 4, BUFFER_OVERRUN, [ArrayDeclaration,Assignment,ArrayAccess: Offset: [1, 1] Size: [1, 1]]
codetoanalyze/c/bufferoverrun/prune_constant.c, prune_constant_true_Ok, 3, CONDITION_ALWAYS_TRUE, []
codetoanalyze/c/bufferoverrun/prune_constant.c, prune_constant_value_Ok, 3, CONDITION_ALWAYS_FALSE, []
codetoanalyze/c/bufferoverrun/sizeof.c, eval_sizeof_bad, 1, CONDITION_ALWAYS_TRUE, []

@ -36,3 +36,11 @@ void prune_constant_value_Ok(int x) {
}
}
}
void prune_constant_not_Bad() {
int x = 0;
int a[1];
if (!x) {
a[x + 1] = 0;
}
}

Loading…
Cancel
Save