[pypy-commit] pypy default: Check that computing hashes with siphash24 can raise MemoryError but nothing more
arigo
pypy.commits at gmail.com
Wed Feb 1 03:48:11 EST 2017
Author: Armin Rigo <arigo at tunes.org>
Branch:
Changeset: r89869:70e009029493
Date: 2017-02-01 09:45 +0100
http://bitbucket.org/pypy/pypy/changeset/70e009029493/
Log: Check that computing hashes with siphash24 can raise MemoryError but
nothing more
diff --git a/rpython/jit/codewriter/test/test_call.py b/rpython/jit/codewriter/test/test_call.py
--- a/rpython/jit/codewriter/test/test_call.py
+++ b/rpython/jit/codewriter/test/test_call.py
@@ -281,6 +281,8 @@
def test_elidable_kinds():
from rpython.jit.backend.llgraph.runner import LLGraphCPU
+ from rpython.rlib.objectmodel import compute_hash
+ from rpython.rlib.rsiphash import enable_siphash24
@jit.elidable
def f1(n, m):
@@ -293,12 +295,17 @@
if n > m:
raise ValueError
return n + m
+ @jit.elidable
+ def f4(n, m):
+ return compute_hash(str(n) + str(m))
def f(n, m):
a = f1(n, m)
b = f2(n, m)
c = f3(n, m)
- return a + len(b) + c
+ d = f4(n, m)
+ enable_siphash24()
+ return a + len(b) + c + d
rtyper = support.annotate(f, [7, 9])
jitdriver_sd = FakeJitDriverSD(rtyper.annotator.translator.graphs[0])
@@ -309,7 +316,8 @@
for index, expected in [
(0, EffectInfo.EF_ELIDABLE_CANNOT_RAISE),
(1, EffectInfo.EF_ELIDABLE_OR_MEMORYERROR),
- (2, EffectInfo.EF_ELIDABLE_CAN_RAISE)]:
+ (2, EffectInfo.EF_ELIDABLE_CAN_RAISE),
+ (3, EffectInfo.EF_ELIDABLE_OR_MEMORYERROR)]:
call_op = f_graph.startblock.operations[index]
assert call_op.opname == 'direct_call'
call_descr = cc.getcalldescr(call_op)
More information about the pypy-commit
mailing list