jit/backend/aarch64/test/test_runner.py::TestARM64::()::test_call_release_gil_save_errno
self = <rpython.jit.backend.aarch64.test.test_runner.TestARM64 object at 0x00000001315f0800>
def test_call_release_gil_save_errno(self):
from rpython.translator.tool.cbuild import ExternalCompilationInfo
from rpython.rlib.libffi import types
from rpython.jit.backend.llsupport import llerrno
#
if not isinstance(self.cpu, AbstractLLCPU):
py.test.skip("not on LLGraph")
eci = ExternalCompilationInfo(
separate_module_sources=['''
#include <errno.h>
static Signed f1(Signed a, Signed b, Signed c, Signed d,
Signed e, Signed f, Signed g) {
errno = 42;
return (a + 10*b + 100*c + 1000*d +
10000*e + 100000*f + 1000000*g);
}
RPY_EXPORTED
Signed test_call_release_gil_save_errno(void) {
return (Signed)&f1;
}
'''])
fn_name = 'test_call_release_gil_save_errno'
getter_ptr = rffi.llexternal(fn_name, [], lltype.Signed,
compilation_info=eci, _nowrapper=True)
func1_adr = getter_ptr()
calldescr = self.cpu._calldescr_dynamic_for_tests([types.signed]*7,
types.signed)
#
for saveerr in [rffi.RFFI_ERR_NONE,
rffi.RFFI_SAVE_ERRNO,
rffi.RFFI_ERR_NONE | rffi.RFFI_ALT_ERRNO,
rffi.RFFI_SAVE_ERRNO | rffi.RFFI_ALT_ERRNO,
]:
faildescr = BasicFailDescr(1)
inputargs = [InputArgInt() for i in range(7)]
op0 = ResOperation(rop.CALL_RELEASE_GIL_I,
[ConstInt(saveerr), ConstInt(func1_adr)]
+ inputargs,
descr=calldescr)
ops = [
op0,
ResOperation(rop.GUARD_NOT_FORCED, [], descr=faildescr),
ResOperation(rop.FINISH, [op0], descr=BasicFinalDescr(0))
]
ops[-2].setfailargs([])
looptoken = JitCellToken()
self.cpu.compile_loop(inputargs, ops, looptoken)
#
llerrno.set_debug_saved_errno(self.cpu, 24)
llerrno.set_debug_saved_alterrno(self.cpu, 25)
deadframe = self.cpu.execute_token(looptoken, 9, 8, 7, 6, 5, 4, 3)
original_result = self.cpu.get_int_value(deadframe, 0)
result = llerrno.get_debug_saved_errno(self.cpu)
altresult = llerrno.get_debug_saved_alterrno(self.cpu)
print('saveerr =', saveerr, ': got result =', result,
'altresult =', altresult)
#
expected = {
rffi.RFFI_ERR_NONE: (24, 25),
rffi.RFFI_SAVE_ERRNO: (42, 25),
rffi.RFFI_ERR_NONE | rffi.RFFI_ALT_ERRNO: (24, 25),
rffi.RFFI_SAVE_ERRNO | rffi.RFFI_ALT_ERRNO: (24, 42),
}
# expected (24, 25) as originally set, with possibly one
# of the two changed to 42 by the assembler code
> assert (result, altresult) == expected[saveerr]
E assert (7906702464546504746, 25) == (42, 25)
E At index 0 diff: 7906702464546504746 != 42
E Use -v to get the full diff
jit/backend/test/runner_test.py:3193: AssertionError
---------- Captured stderr setup ----------
[c5817e5d62f5200] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700000 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9E0031DAAF35344A9FE77C5A8C0035FD6
[c5817e5d63e7880] jit-backend-dump}
[c5817e5d66a9400] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700060 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9059595D2C507A0F20500CCF2A40040F9060080D2A60000F9059495D2C507A0F20500CCF2A60000F9A41700F9E0031DAAF35344A9FE77C5A8C0035FD6
[c5817e5d6817980] jit-backend-dump}
[c5817e5d6f9b080] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @70037000f0 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FDE00740A9FE0300F9A00F00F9E0031DAA109595D2D007A0F21000CCF2100240F9B01700F9109495D2D007A0F21000CCF2130240F9109595D2D007A0F21000CCF2110080D2110200F9109495D2D007A0F21000CCF2110200F9106499D29045A0F23000C0F21000E0F200023FD6FD0300AA109595D2D007A0F21000CCF2B11740F9110200F9110080D2B11700F9109495D2D007A0F21000CCF2130200F9100080D2B00F00F9A02340F9A12740F9A22B40F9A32F40F9A43340F9A53740F9A63B40F9A73F40F9A84340F9A94740F9AA4B40F9AB4F40F9AC5340F9AD5740F9B35B40F9B45F40F9A06340FDA16740FDA26B40FDA36F40FDA47340FDA57740FDA67B40FDA77F40FDFE0340F9FF430091C0035FD6
[c5817e5d7391b00] jit-backend-dump}
[c5817e5d75e5e80] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700270 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FDE0031DAAF35344A9FE77C5A8C0035FD6
[c5817e5d7724a00] jit-backend-dump}
[c5817e5d7a47980] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @70037002f0 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FD059595D2C507A0F20500CCF2A40040F9060080D2A60000F9059495D2C507A0F20500CCF2A60000F9A41700F9E0031DAAF35344A9FE77C5A8C0035FD6
[c5817e5d7c03100] jit-backend-dump}
[c5817e5d7d92580] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @70037003a0 +0 109595D2D007A0F21000CCF2000240F9110080D2110200F9109495D2D007A0F21000CCF2110200F9A01700F9000080D2A00700F9E0031DAAF35344A9FE77C5A8C0035FD6
[c5817e5d7e5b080] jit-backend-dump}
[c5817e5d821ec80] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @70037003f0 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FDFF4300D1F00700F9FE0300F920023FD6F10300AAA02340F9A12740F9A22B40F9A32F40F9A43340F9A53740F9A63B40F9A73F40F9A84340F9A94740F9AA4B40F9AB4F40F9AC5340F9AD5740F9B35B40F9B45F40F9F00340F9FF43009100025FD6
[c5817e5d8437480] jit-backend-dump}
[c5817e5d87b8480] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @70037004c0 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FDFF4300D1F00700F9FE0300F920023FD6F10300AAA02340F9A12740F9A22B40F9A32F40F9A43340F9A53740F9A63B40F9A73F40F9A84340F9A94740F9AA4B40F9AB4F40F9AC5340F9AD5740F9F00340F9FF43009100025FD6
[c5817e5d899ff00] jit-backend-dump}
[c5817e5d8e00880] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700580 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9B35B00F9B45F00F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FDFF4300D1F00700F9FE0300F920023FD6F10300AAA02340F9A12740F9A22B40F9A32F40F9A43340F9A53740F9A63B40F9A73F40F9A84340F9A94740F9AA4B40F9AB4F40F9AC5340F9AD5740F9B35B40F9B45F40F9A06340FDA16740FDA26B40FDA36F40FDA47340FDA57740FDA67B40FDA77F40FDF00340F9FF43009100025FD6
[c5817e5d9071c80] jit-backend-dump}
[c5817e5d9483480] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700670 +0 A02300F9A12700F9A22B00F9A32F00F9A43300F9A53700F9A63B00F9A73F00F9A84300F9A94700F9AA4B00F9AB4F00F9AC5300F9AD5700F9A06300FDA16700FDA26B00FDA36F00FDA47300FDA57700FDA67B00FDA77F00FDFF4300D1F00700F9FE0300F920023FD6F10300AAA02340F9A12740F9A22B40F9A32F40F9A43340F9A53740F9A63B40F9A73F40F9A84340F9A94740F9AA4B40F9AB4F40F9AC5340F9AD5740F9A06340FDA16740FDA26B40FDA36F40FDA47340FDA57740FDA67B40FDA77F40FDF00340F9FF43009100025FD6
[c5817e5d96c8500] jit-backend-dump}
---------- Captured stdout call ----------
saveerr = 0 : got result = 24 altresult = 25
saveerr = 1 : got result = 7906702464546504746 altresult = 25
---------- Captured stderr call ----------
[c5817e5e2fcb380] {jit-mem-looptoken-alloc
allocating Loop # -1
[c5817e5e2fd7300] jit-mem-looptoken-alloc}
[c5817e5e373b480] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700780 +0 00000000000000000000000000000000FE77BBA9F35304A9E10F00F9FD0300AA004890D2E002A0F20000CCF2010040F921040091010000F950FEFF58B00B00F9A08340F9A18740F9A28B40F9A38F40F9A49340F9A59740F9A69B40F910EB80D2106EA0F2100EC0F2B00F00F9113990D2D147A0F23100C0F2330240F93FFE9FC8BD07009110D287D2504EA0F23000C0F21000E0F200023FD60F3990D2CF47A0F22F00C0F2E17D5FC8610000B5F3FD03C8A3FFFF35BF3B03D5010100B4F30300AA101298D29045A0F23000C0F21000E0F200023FD6E00313AABD0700D1100080D2B00F00F9B00740F91F0200F1000020D4A02300F9B0F8FF58B00700F9BF0F00F9E0031DAAF35344A9FE77C5A8C0035FD6000020D470F7FF58B00700F910ED80D2106EA0F2100EC0F2B00F00F9100C80D2106EA0F2100EC0F21000E0F200023FD6
[c5817e5e3ab1a80] jit-backend-dump}
[c5817e5e3b44580] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @700370086c +0 41010054
[c5817e5e3b64180] jit-backend-dump}
[c5817e5e3ee8a00] {jit-backend-addr
Loop -1 () has address 0x70037007a0 to 0x7003700894 (bootstrap 0x7003700790)
gc table: 0x7003700780
function: 0x7003700790
resops: 0x70037007a0
failures: 0x7003700894
end: 0x70037008c0
[c5817e5e3ef7800] jit-backend-addr}
[c5817e5e4135400] {jit-mem-looptoken-alloc
allocating Loop # -1
[c5817e5e413bf80] jit-mem-looptoken-alloc}
[c5817e5edc08200] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @7003700900 +0 00000000000000000000000000000000FE77BBA9F35304A9E10F00F9FD0300AA009090D2E002A0F20000CCF2010040F921040091010000F950FEFF58B00B00F9A08340F9A18740F9A28B40F9A38F40F9A49340F9A59740F9A69B40F9101B81D2106EA0F2100EC0F2B00F00F9113990D2D147A0F23100C0F2330240F93FFE9FC8BD07009110D287D2504EA0F23000C0F21000E0F200023FD6E30F40F9700840F9100240F9700C00F90F3990D2CF47A0F22F00C0F2E17D5FC8610000B5F3FD03C8A3FFFF35BF3B03D5010100B4F30300AA101298D29045A0F23000C0F21000E0F200023FD6E00313AABD0700D1100080D2B00F00F9B00740F91F0200F1000020D4A02300F930F8FF58B00700F9BF0F00F9E0031DAAF35344A9FE77C5A8C0035FD6000020D4F0F6FF58B00700F9101D81D2106EA0F2100EC0F2B00F00F9100C80D2106EA0F2100EC0F21000E0F200023FD6
[c5817e5edfa2b80] jit-backend-dump}
[c5817e5ee032880] {jit-backend-dump
BACKEND arm
SYS_EXECUTABLE ??
CODE_DUMP @70037009fc +0 41010054
[c5817e5ee052480] jit-backend-dump}
[c5817e5ee40c600] {jit-backend-addr
Loop -1 () has address 0x7003700920 to 0x7003700a24 (bootstrap 0x7003700910)
gc table: 0x7003700900
function: 0x7003700910
resops: 0x7003700920
failures: 0x7003700a24
end: 0x7003700a50
[c5817e5ee41c000] jit-backend-addr}
builder: rpython-macos-arm64 build #259
test: jit/backend/aarch64/test/test_runner/py/TestARM64/()/test_call_release_gil_save_errno