當前位置: 首頁>>代碼示例>>Python>>正文


Python claripy.Solver方法代碼示例

本文整理匯總了Python中claripy.Solver方法的典型用法代碼示例。如果您正苦於以下問題:Python claripy.Solver方法的具體用法?Python claripy.Solver怎麽用?Python claripy.Solver使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在claripy的用法示例。


在下文中一共展示了claripy.Solver方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: run_manyfloatsum_symbolic

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def run_manyfloatsum_symbolic(arch):
    global type_cache
    if type_cache is None:
        type_cache = parse_defns(open(os.path.join(location, 'tests_src', 'manyfloatsum.c')).read())

    p = angr.Project(os.path.join(location, 'tests', arch, 'manyfloatsum'))
    function = 'sum_doubles'
    cc = p.factory.cc(func_ty=type_cache[function])
    args = [claripy.FPS('arg_%d' % i, claripy.FSORT_DOUBLE) for i in range(len(type_cache[function].args))]
    addr = p.loader.main_object.get_symbol(function).rebased_addr
    my_callable = p.factory.callable(addr, cc=cc)
    result = my_callable(*args)
    nose.tools.assert_true(result.symbolic)

    s = claripy.Solver(timeout=15*60*1000)
    for arg in args:
        s.add(arg > claripy.FPV(1.0, claripy.FSORT_DOUBLE))
    s.add(result == claripy.FPV(27.7, claripy.FSORT_DOUBLE))

    args_conc = s.batch_eval(args, 1)[0]
    nose.tools.assert_equal(s.eval(result, 1)[0], 27.7)
    # not almost equal!! totally equal!!! z3 is magic, if kinda slow!!!!!
    for arg_conc in args_conc:
        nose.tools.assert_greater(arg_conc, 1.0)
    nose.tools.assert_equal(sum(args_conc), 27.7) 
開發者ID:angr,項目名稱:angr,代碼行數:27,代碼來源:test_callable.py

示例2: combine

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def combine(self, others):
        other_claripy_solvers = [i.solver for i in others]
        combined = Solver(
            claripy_solver=self.solver.combine(other_claripy_solvers),
            hashes=self.hashes,
        )

        for other in others:
            for k, v in self.hashes.items():
                # Make sure the hash symbols are distinct
                if any(v is v2 for v2 in other.hashes.values()):
                    # Call regenerate_hash_symbols() on one of them first?
                    raise ValueError("Cannot combine with equivalent hashes.")

                # TODO: If some hash input are equal, we should merge the hash
                # symols here, it would be more efficient.
            combined.hashes.update(other.hashes)

        return combined 
開發者ID:palkeo,項目名稱:pakala,代碼行數:21,代碼來源:claripy_sha3.py

示例3: __init__

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def __init__(self, plock=None, q=None, kernel_path=None):
        """
        :param kernel_path: the vmlinux path to the kernel
        """
        if plock is not None:
            self.lock = plock  # this is the lock because all instances of osok share a qemu instance
        else:
            self.lock = None
        self.queue = q

        self.kernel_path = kernel_path
        if os.path.isfile('angr_project.cache'):
            with open('angr_project.cache', 'rb') as f:
                print('[+] load kernel vmlinux binary from pickle dump')
                self.b = pickle.load(f)
        else:
            self.b = angr.Project(kernel_path)
            with open('angr_project.cache', 'wb') as f:
                pickle.dump(self.b, f)
        self.r = None
        self.statebroker = statebroker.StateBroker()
        self.claripy = claripy
        self.sol = claripy.Solver()
        self.md = Cs(CS_ARCH_X86, CS_MODE_64)
        self.md.detail = True
        self.debug_bloom_verbose = False
        self.vm = None
        self.reproduce_mode = False  # reproduce exploit and generate payload
        self.custom_rop_gadget_number = 10  # length of the rop payload we want to use 
開發者ID:ww9210,項目名稱:kepler-cfhp,代碼行數:31,代碼來源:__init__.py

示例4: reachable

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def reachable(self):
        if self._satisfiable is not None:
            pass
        elif self.state is not None:
            self._satisfiable = self.state.solver.satisfiable()
        else:
            solver = claripy.Solver()
            solver.add(self._all_constraints)
            self._satisfiable = solver.satisfiable()

        return self._satisfiable

    #
    # Log handling
    # 
開發者ID:angr,項目名稱:angr,代碼行數:17,代碼來源:history.py

示例5: get_claripy_solver

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def get_claripy_solver():
    # TODO: What about SolverComposite? Tried, and seems slower.
    return claripy.Solver() 
開發者ID:palkeo,項目名稱:pakala,代碼行數:5,代碼來源:claripy_sha3.py

示例6: branch

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def branch(self):
        return Solver(claripy_solver=self.solver.branch(), hashes=self.hashes.copy()) 
開發者ID:palkeo,項目名稱:pakala,代碼行數:4,代碼來源:claripy_sha3.py

示例7: test_ite

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_ite():
    yield raw_ite, claripy.Solver
    yield raw_ite, claripy.SolverHybrid
    yield raw_ite, claripy.SolverComposite 
開發者ID:angr,項目名稱:claripy,代碼行數:6,代碼來源:test_expression.py

示例8: test_extract_concat_simplify

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_extract_concat_simplify():
    a = claripy.BVS("a", 32)
    assert a[31:0] is a
    assert a[31:8].concat(a[7:0]) is a  # pylint:disable=no-member
    assert a[31:16].concat(a[15:8], a[7:0]) is a  # pylint:disable=no-member
    assert a[31:24].concat(a[23:16], a[15:8], a[7:0]) is a  # pylint:disable=no-member

    a = claripy.BVS("a", 32)
    b = a + 100
    b_concat = b[31:8].concat(b[7:0])
    a100 = a + 100
    assert claripy.is_false(b_concat == a100) is False
    assert list(claripy.Solver().eval(b_concat == a100, 2)) == [ True ]
    assert b_concat is a100
    assert claripy.is_true(b_concat == a100) 
開發者ID:angr,項目名稱:claripy,代碼行數:17,代碼來源:test_expression.py

示例9: test_signed_symbolic

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_signed_symbolic():
    solver = claripy.Solver()
    a = claripy.BVS("a", 32)
    b = claripy.BVS("b", 32)
    c = claripy.BVS("c", 32)
    d = claripy.BVS("d", 32)
    solver.add(a == 5)
    solver.add(b == -5)
    solver.add(c == 3)
    solver.add(d == -3)

    # test unsigned
    assert list(solver.eval(a / c, 2)) == [1]
    assert list(solver.eval(a / d, 2)) == [0]
    assert list(solver.eval(b / c, 2)) == [0x55555553]
    assert list(solver.eval(b / d, 2)) == [0]
    assert list(solver.eval(a % c, 2)) == [2]
    assert list(solver.eval(a % d, 2)) == [5]
    assert list(solver.eval(b % c, 2)) == [2]
    assert list(solver.eval(b % d, 2)) == [2**32-5]

    # test unsigned
    assert list(solver.eval(a.SDiv(c), 2)) == [1]
    assert list(solver.eval(a.SDiv(d), 2)) == [2**32-1]
    assert list(solver.eval(b.SDiv(c), 2)) == [2**32-1]
    assert list(solver.eval(b.SDiv(d), 2)) == [1]
    assert list(solver.eval(a.SMod(c), 2)) == [2]
    assert list(solver.eval(a.SMod(d), 2)) == [2]
    assert list(solver.eval(b.SMod(c), 2)) == [2**32-2]
    assert list(solver.eval(b.SMod(d), 2)) == [2**32-2] 
開發者ID:angr,項目名稱:claripy,代碼行數:32,代碼來源:test_expression.py

示例10: test_arith_shift

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_arith_shift():
    bc = claripy.backends.concrete
    a = claripy.BVV(-4, 32)
    assert bc.convert(a >> 1) == -2

    solver = claripy.Solver()
    a = claripy.BVS("a", 32)
    solver.add(a == -4)
    assert list(solver.eval(a >> 1, 2)) == [2**32-2] 
開發者ID:angr,項目名稱:claripy,代碼行數:11,代碼來源:test_expression.py

示例11: raw_minmax

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def raw_minmax(reuse_z3_solver):
    claripy._backend_z3.reuse_z3_solver = reuse_z3_solver

    s = claripy.Solver()
    x = claripy.BVS("x", 32)

    nose.tools.assert_equal(s.max(x), 2**32-1)
    nose.tools.assert_equal(s.min(x), 0)
    nose.tools.assert_true(s.satisfiable()) 
開發者ID:angr,項目名稱:claripy,代碼行數:11,代碼來源:test_solver.py

示例12: test_model

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_model():
    x = claripy.BVS("x", 32)
    y = claripy.BVS("y", 32)
    s = claripy.Solver()

    s.add(x < 10)
    assert sorted(s.eval(x, 20)) == list(range(10))
    s.add(y == 1337)
    assert sorted(s.eval(x, 20)) == list(range(10)) 
開發者ID:angr,項目名稱:claripy,代碼行數:11,代碼來源:test_solver.py

示例13: test_unsatness

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_unsatness():
    x = claripy.BVS("x", 32)

    s = claripy.Solver()
    s.add(x == 10)
    assert s.satisfiable()
    s.add(claripy.false)
    assert not s.satisfiable() 
開發者ID:angr,項目名稱:claripy,代碼行數:10,代碼來源:test_solver.py

示例14: test_simplification_annotations

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_simplification_annotations():
    s = claripy.Solver()
    x = claripy.BVS("x", 32)

    s.add(x > 10)
    s.add(x > 11)
    s.add((x > 12).annotate(claripy.SimplificationAvoidanceAnnotation()))

    assert len(s.constraints) == 3
    s.simplify()
    assert len(s.constraints) == 2 
開發者ID:angr,項目名稱:claripy,代碼行數:13,代碼來源:test_solver.py

示例15: test_unsat_core

# 需要導入模塊: import claripy [as 別名]
# 或者: from claripy import Solver [as 別名]
def test_unsat_core():
    for s in (claripy.Solver, claripy.SolverComposite, claripy.SolverCacheless, claripy.SolverHybrid):
        yield raw_unsat_core, s, True
        yield raw_unsat_core, s, False 
開發者ID:angr,項目名稱:claripy,代碼行數:6,代碼來源:test_solver.py


注:本文中的claripy.Solver方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。