package binsec
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Semantic analysis of binary executables
Install
dune-project
Dependency
Authors
-
AAdel Djoudi
-
BBenjamin Farinier
-
CChakib Foulani
-
DDorian Lesbre
-
FFrédéric Recoules
-
GGuillaume Girol
-
JJosselin Feist
-
LLesly-Ann Daniel
-
MMahmudul Faisal Al Ameen
-
MManh-Dung Nguyen
-
MMathéo Vergnolle
-
MMathilde Ollivier
-
MMatthieu Lemerre
-
NNicolas Bellec
-
OOlivier Nicole
-
RRichard Bonichon
-
RRobin David
-
SSébastien Bardin
-
SSoline Ducousso
-
TTa Thanh Dinh
-
YYaëlle Vinçont
-
YYanis Sellami
Maintainers
Sources
binsec-0.11.0.tbz
sha256=4cf70a0367fef6f33ee3165f05255914513ea0539b94ddfef0bd46fc9b42fa8a
sha512=cd67a5b7617f661a7786bef0c828ee55307cef5260dfecbb700a618be795d81b1ac49fc1a18c4904fd2eb8a182dc862b0159093028651e78e7dc743f5babf9e3
doc/src/binsec_cli_xtrasec/formula_decoder.ml.html
Source file formula_decoder.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236(**************************************************************************) (* This file is part of BINSEC. *) (* *) (* Copyright (C) 2016-2026 *) (* CEA (Commissariat à l'énergie atomique et aux énergies *) (* alternatives) *) (* *) (* you can redistribute it and/or modify it under the terms of the GNU *) (* Lesser General Public License as published by the Free Software *) (* Foundation, version 2.1. *) (* *) (* It is distributed in the hope that it will be useful, *) (* but WITHOUT ANY WARRANTY; without even the implied warranty of *) (* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *) (* GNU Lesser General Public License for more details. *) (* *) (* See the GNU Lesser General Public License version 2.1 *) (* for more details (enclosed in the file licenses/LGPLv2.1). *) (* *) (**************************************************************************) (** DBA -> Formula decoder interface. *) module Instr_to_Formula = struct module F = Binsec_smtlib.Formula module Types = struct type binary = F.bv_term type boolean = F.bl_term type memory = F.ax_term end include Types module VarMap = Map.Make (String) type state = { (* Associate to each register the representation of the bitvector that it contains; and a unique counter needed when we name the definitions. *) vars : (int * binary) VarMap.t; (* mem and memcount are like vars, but for the memory. *) mem : memory; memcount : int; (* The definitions that we have put so far. *) (* Note: currently we translate the assumes directly as assertions in the code, which works well only if we want a formula describing a single path. For path merging, we need a shared formula with a separate path-condition. *) formula : F.formula; } module State = struct type t = state let add_assertion cond state = { state with formula = Binsec_smtlib.Formula.push_front_assert cond state.formula; } let add_comment comment state = { state with formula = Binsec_smtlib.Formula.push_front_comment comment state.formula; } let clear state = (* Generate a new memory variable. *) let memcount = state.memcount + 1 in let memvar = F.ax_var ("memory" ^ string_of_int memcount) 32 8 in let formula = F.push_front_declare (F.decl @@ F.AxDecl (memvar, [])) state.formula in let mem = F.mk_ax_var memvar in (* Generate new variables. *) let vars, formula = VarMap.fold (fun var (i, b) (vars, formula) -> let i = i + 1 in let size = b.F.bv_term_size in let name = F.bv_var (var ^ string_of_int i) size in let formula = F.push_front_declare (F.decl @@ F.BvDecl (name, [])) formula in let term = F.mk_bv_var name in (VarMap.add var (i + 1, term) vars, formula)) state.vars (state.vars, formula) in { vars; formula; mem; memcount = memcount + 1 } end let initial_state = let formula = F.empty in let memvar = F.ax_var "memory0" 32 8 in let formula = F.push_front_declare (F.decl @@ F.AxDecl (memvar, [])) formula in let mem = F.mk_ax_var memvar in { vars = VarMap.empty; mem; memcount = 1; formula } let clear_memory = State.clear let get_formula x = x.formula let assume cond state = let state = State.add_assertion cond state in ((), state) let add_comment string state = State.add_comment string state let unknown ~name ~size state = let var = F.bv_var name size in let formula = F.push_front_declare (F.decl @@ F.BvDecl (var, [])) state.formula in (F.mk_bv_var var, { state with formula }) let unknown = let count = ref 0 in fun ~size state -> let name = "unknown" ^ string_of_int !count in incr count; unknown ~name ~size state let set_var ~size string bin state = let prev = try fst @@ VarMap.find string state.vars with Not_found -> 0 in let next = prev + 1 in (* Put a definition. *) let var = F.bv_var (string ^ string_of_int next) size in let formula = F.push_front_define (F.def @@ F.BvDef (var, [], bin)) state.formula in let vars = VarMap.add string (next, F.mk_bv_var var) state.vars in { state with vars; formula } let get_var ~size string state = try (snd @@ VarMap.find string state.vars, state) (* Ideally, we should initialize all registers with an unknown value. *) with Not_found -> let res, state = unknown ~size state in let vars = VarMap.add string (0, res) state.vars in (res, { state with vars }) let store ~size _endian addr value state = let memvar = F.ax_var ("memory" ^ string_of_int state.memcount) 32 8 in let mem = F.mk_store (size / 8) state.mem addr value in let formula = F.push_front_define (F.def @@ F.AxDef (memvar, [], mem)) state.formula in let mem = F.mk_ax_var memvar in { state with mem; formula; memcount = state.memcount + 1 } let load ~size _endian addr state = (F.mk_select (size / 8) state.mem addr, state) let ite cond then_ else_ state = (F.mk_bv_ite cond then_ else_, state) let bool_of_bin x state = (F.mk_bv_equal x F.mk_bv_one, state) let bin_of_bool x state = (F.mk_bv_ite x F.mk_bv_one F.mk_bv_zero, state) let undef = unknown module Boolean = struct include Types let false_ state = (F.mk_bl_false, state) let true_ state = (F.mk_bl_true, state) let ( || ) a b state = (F.mk_bl_or a b, state) let ( && ) a b state = (F.mk_bl_and a b, state) let not a state = (F.mk_bl_not a, state) end module Binary = struct include Types let biconst ~size i state = (F.mk_bv_cst (Bitvector.create i size), state) let bvar2 op = let f : size:int -> binary -> binary -> State.t -> binary * State.t = fun ~size a b state -> let _ = size in (op a b, state) in f let bimul = bvar2 F.mk_bv_mul let bisub = bvar2 F.mk_bv_sub let biadd = bvar2 F.mk_bv_add let blshr = bvar2 F.mk_bv_lshr let bashr = bvar2 F.mk_bv_ashr let bshl = bvar2 F.mk_bv_shl let biurem = bvar2 F.mk_bv_urem let biudiv = bvar2 F.mk_bv_udiv let bisrem = bvar2 F.mk_bv_srem let bisdiv = bvar2 F.mk_bv_sdiv let bxor = bvar2 F.mk_bv_xor let bor = bvar2 F.mk_bv_or let band = bvar2 F.mk_bv_and let bv_right_rotate ~size _a _b state = Xtrasec_options.Logger.warning "bv_right_rotate is imprecise"; unknown ~size state let bv_left_rotate ~size _a _b state = Xtrasec_options.Logger.warning "bv_left_rotate is imprecise"; unknown ~size state let buext ~size ~oldsize a state = (F.mk_bv_zero_extend (size - oldsize) a, state) let bsext ~size ~oldsize a state = (F.mk_bv_sign_extend (size - oldsize) a, state) let bextract ~lo ~hi ~oldsize a state = if lo == 0 && hi == oldsize - 1 then (a, state) else (F.mk_bv_extract Interval.{ lo; hi } a, state) let bconcat ~size1 ~size2 a b state = let _ = size1 and _ = size2 in (F.mk_bv_concat a b, state) let bpred op = let f : size:int -> binary -> binary -> State.t -> boolean * State.t = fun ~size a b state -> let _ = size in (op a b, state) in f let biult = bpred F.mk_bv_ult let biule = bpred F.mk_bv_ule let bislt = bpred F.mk_bv_slt let bisle = bpred F.mk_bv_sle let beq = bpred F.mk_bv_equal end end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>