Added a maximize objective API to DeepState.

This commit is contained in:
Peter Goodman 2017-12-10 13:37:47 -05:00
parent 188d4517d8
commit fcd000dc14
6 changed files with 68 additions and 15 deletions

View File

@ -93,6 +93,9 @@ class DeepState(object):
def concretize_min(self, val, constrain=False): def concretize_min(self, val, constrain=False):
raise NotImplementedError("Must be implemented by engine.") raise NotImplementedError("Must be implemented by engine.")
def concretize_max(self, val, constrain=False):
raise NotImplementedError("Must be implemented by engine.")
def concretize_many(self, val, max_num): def concretize_many(self, val, max_num):
raise NotImplementedError("Must be implemented by engine.") raise NotImplementedError("Must be implemented by engine.")
@ -383,10 +386,10 @@ class DeepState(object):
minimum satisfiable value for `arg`.""" minimum satisfiable value for `arg`."""
return self.concretize_min(arg, constrain=False) return self.concretize_min(arg, constrain=False)
def api_min_int(self, arg): def api_max_uint(self, arg):
"""Implements the `DeepState_MinInt` API function, which returns the """Implements the `DeepState_MaxUInt` API function, which returns the
minimum satisfiable value for `arg`.""" minimum satisfiable value for `arg`."""
return self.concretize_min(arg + 2**31, constrain=False) return self.concretize_max(arg, constrain=False)
def api_is_symbolic_uint(self, arg): def api_is_symbolic_uint(self, arg):
"""Implements the `DeepState_IsSymbolicUInt` API, which returns whether or """Implements the `DeepState_IsSymbolicUInt` API, which returns whether or

View File

@ -107,6 +107,14 @@ class DeepAngr(DeepState):
self.add_constraint(val == concrete_val) self.add_constraint(val == concrete_val)
return concrete_val return concrete_val
def concretize_max(self, val, constrain=False):
if isinstance(val, (int, long)):
return val
concrete_val = self.state.solver.max(val)
if constrain:
self.add_constraint(val == concrete_val)
return concrete_val
def concretize_many(self, val, max_num): def concretize_many(self, val, max_num):
assert 0 < max_num assert 0 < max_num
if isinstance(val, (int, long)): if isinstance(val, (int, long)):
@ -197,11 +205,11 @@ class MinUInt(angr.SimProcedure):
return DeepAngr(procedure=self).api_min_uint(val) return DeepAngr(procedure=self).api_min_uint(val)
class MinInt(angr.SimProcedure): class MaxUInt(angr.SimProcedure):
"""Implements the `Deeptate_MinUInt` API function, which lets the """Implements the `Deeptate_MaxUInt` API function, which lets the
programmer ask for the minimum satisfiable value of a signed integer.""" programmer ask for the minimum satisfiable value of a signed integer."""
def run(self, val): def run(self, val):
return DeepAngr(procedure=self).api_min_int(val) return DeepAngr(procedure=self).api_max_uint(val)
class StreamInt(angr.SimProcedure): class StreamInt(angr.SimProcedure):
@ -340,7 +348,7 @@ def main():
hook_function(project, apis['ConcretizeData'], ConcretizeData) hook_function(project, apis['ConcretizeData'], ConcretizeData)
hook_function(project, apis['ConcretizeCStr'], ConcretizeCStr) hook_function(project, apis['ConcretizeCStr'], ConcretizeCStr)
hook_function(project, apis['MinUInt'], MinUInt) hook_function(project, apis['MinUInt'], MinUInt)
hook_function(project, apis['MinInt'], MinInt) hook_function(project, apis['MaxUInt'], MaxUInt)
hook_function(project, apis['Assume'], Assume) hook_function(project, apis['Assume'], Assume)
hook_function(project, apis['Pass'], Pass) hook_function(project, apis['Pass'], Pass)
hook_function(project, apis['Fail'], Fail) hook_function(project, apis['Fail'], Fail)

View File

@ -106,6 +106,14 @@ class DeepManticore(DeepState):
self.add_constraint(val == concrete_val) self.add_constraint(val == concrete_val)
return concrete_val return concrete_val
def concretize_max(self, val, constrain=False):
if isinstance(val, (int, long)):
return val
concrete_val = max(self.state.concretize(val, policy='MINMAX'))
if constrain:
self.add_constraint(val == concrete_val)
return concrete_val
def concretize_many(self, val, max_num): def concretize_many(self, val, max_num):
assert 0 < max_num assert 0 < max_num
if isinstance(val, (int, long)): if isinstance(val, (int, long)):
@ -212,10 +220,10 @@ def hook_MinUInt(self, val):
return DeepAngr(procedure=self).api_min_uint(val) return DeepAngr(procedure=self).api_min_uint(val)
def hook_MinInt(self, val): def hook_MaxUInt(self, val):
"""Implements the `Deeptate_MinUInt` API function, which lets the """Implements the `Deeptate_MaxUInt` API function, which lets the
programmer ask for the minimum satisfiable value of a signed integer.""" programmer ask for the minimum satisfiable value of a signed integer."""
return DeepAngr(procedure=self).api_min_int(val) return DeepAngr(procedure=self).api_max_uint(val)
def hook_Log(state, level, ea): def hook_Log(state, level, ea):
@ -253,7 +261,7 @@ def do_run_test(state, apis, test):
m.add_hook(apis['ConcretizeData'], hook(hook_ConcretizeData)) m.add_hook(apis['ConcretizeData'], hook(hook_ConcretizeData))
m.add_hook(apis['ConcretizeCStr'], hook(hook_ConcretizeCStr)) m.add_hook(apis['ConcretizeCStr'], hook(hook_ConcretizeCStr))
m.add_hook(apis['MinUInt'], hook(hook_MinUInt)) m.add_hook(apis['MinUInt'], hook(hook_MinUInt))
m.add_hook(apis['MinInt'], hook(hook_MinInt)) m.add_hook(apis['MaxUInt'], hook(hook_MaxUInt))
m.add_hook(apis['Assume'], hook(hook_Assume)) m.add_hook(apis['Assume'], hook(hook_Assume))
m.add_hook(apis['Pass'], hook(hook_Pass)) m.add_hook(apis['Pass'], hook(hook_Pass))
m.add_hook(apis['Fail'], hook(hook_Fail)) m.add_hook(apis['Fail'], hook(hook_Fail))

View File

@ -64,20 +64,39 @@ extern int8_t DeepState_Char(void);
extern uint32_t DeepState_MinUInt(uint32_t); extern uint32_t DeepState_MinUInt(uint32_t);
extern int32_t DeepState_MinInt(int32_t); extern int32_t DeepState_MinInt(int32_t);
extern uint32_t DeepState_MaxUInt(uint32_t);
extern int32_t DeepState_MaxInt(int32_t);
DEEPSTATE_INLINE static uint16_t DeepState_MinUShort(uint16_t v) { DEEPSTATE_INLINE static uint16_t DeepState_MinUShort(uint16_t v) {
return DeepState_MinUInt(v); return DeepState_MinUInt(v);
} }
DEEPSTATE_INLINE static uint8_t DeepState_MinUChar(uint8_t v) { DEEPSTATE_INLINE static uint8_t DeepState_MinUChar(uint8_t v) {
return DeepState_MinUInt(v); return (uint8_t) DeepState_MinUInt(v);
} }
DEEPSTATE_INLINE static int16_t DeepState_MinShort(int16_t v) { DEEPSTATE_INLINE static int16_t DeepState_MinShort(int16_t v) {
return DeepState_MinInt(v); return (int16_t) DeepState_MinInt(v);
} }
DEEPSTATE_INLINE static int8_t DeepState_MinChar(int8_t v) { DEEPSTATE_INLINE static int8_t DeepState_MinChar(int8_t v) {
return DeepState_MinInt(v); return (int8_t) DeepState_MinInt(v);
}
DEEPSTATE_INLINE static uint16_t DeepState_MaxUShort(uint16_t v) {
return (uint16_t) DeepState_MaxUInt(v);
}
DEEPSTATE_INLINE static uint8_t DeepState_MaxUChar(uint8_t v) {
return (uint8_t) DeepState_MaxUInt(v);
}
DEEPSTATE_INLINE static int16_t DeepState_MaxShort(int16_t v) {
return (int16_t) DeepState_MaxInt(v);
}
DEEPSTATE_INLINE static int8_t DeepState_MaxChar(int8_t v) {
return (int8_t) DeepState_MaxInt(v);
} }
/* Returns `1` if `expr` is true, and `0` otherwise. This is kind of an indirect /* Returns `1` if `expr` is true, and `0` otherwise. This is kind of an indirect

View File

@ -258,6 +258,9 @@ using symbolic_uint64_t = Symbolic<uint64_t>;
#define MAKE_MINIMIZER(Type, type) \ #define MAKE_MINIMIZER(Type, type) \
DEEPSTATE_INLINE static type Minimize(type val) { \ DEEPSTATE_INLINE static type Minimize(type val) { \
return DeepState_Min ## Type(val); \ return DeepState_Min ## Type(val); \
} \
DEEPSTATE_INLINE static type Maximize(type val) { \
return DeepState_Max ## Type(val); \
} }
MAKE_MINIMIZER(UInt, uint32_t) MAKE_MINIMIZER(UInt, uint32_t)

View File

@ -204,9 +204,21 @@ uint32_t DeepState_MinUInt(uint32_t v) {
} }
int32_t DeepState_MinInt(int32_t v) { int32_t DeepState_MinInt(int32_t v) {
return (int32_t) (DeepState_MinUInt(((uint32_t) v) + 0x80000000U) -
0x80000000U);
}
/* Returns the maximum satisfiable value for a given symbolic value, given
* the constraints present on that value. */
uint32_t DeepState_MaxUInt(uint32_t v) {
return v; return v;
} }
int32_t DeepState_MaxInt(int32_t v) {
return (int32_t) (DeepState_MaxUInt(((uint32_t) v) + 0x80000000U) -
0x80000000U);
}
void _DeepState_Assume(int expr, const char *expr_str, const char *file, void _DeepState_Assume(int expr, const char *expr_str, const char *file,
unsigned line) { unsigned line) {
if (!expr) { if (!expr) {
@ -263,7 +275,7 @@ const struct DeepState_IndexEntry DeepState_API[] = {
{"ConcretizeData", (void *) DeepState_ConcretizeData}, {"ConcretizeData", (void *) DeepState_ConcretizeData},
{"ConcretizeCStr", (void *) DeepState_ConcretizeCStr}, {"ConcretizeCStr", (void *) DeepState_ConcretizeCStr},
{"MinUInt", (void *) DeepState_MinUInt}, {"MinUInt", (void *) DeepState_MinUInt},
{"MinInt", (void *) DeepState_MinInt}, {"MaxUInt", (void *) DeepState_MaxUInt},
/* Logging API. */ /* Logging API. */
{"Log", (void *) DeepState_Log}, {"Log", (void *) DeepState_Log},