Home - Summaries: (main) : (py3.11) : Everything - Nightly builds - Benchmarks - RPython - Builders - About

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