https://bugs.winehq.org/show_bug.cgi?id=53321
Bug ID: 53321 Summary: Unhandled page fault on write access in A_SHAFinal Product: Wine Version: 7.12 Hardware: x86-64 OS: Linux Status: UNCONFIRMED Severity: normal Priority: P2 Component: ntdll Assignee: wine-bugs@winehq.org Reporter: f.alexander.wilms@gmail.com Distribution: ---
Created attachment 72703 --> https://bugs.winehq.org/attachment.cgi?id=72703 log of wine output
I was trying to a run a snake game for Windows that can fit into a QR code:
https://www.mattkc.com/etc/snakeqr/ https://web.archive.org/web/20220616183735/https://www.mattkc.com/etc/snakeq...
The binary was created using the compressing linker Crinkler (https://github.com/runestubbe/Crinkler)
Convert QR code to exe: zbarimg -S binary code.png > snake.exe
I encountered the following crash:
wine: Unhandled page fault on write access to 00000024 at address 7BC4AD36 (thread 016c), starting debugger... Unhandled exception: page fault on write access to 0x00000024 in 32-bit code (0x7bc4ad36). [...] =>0 0x7bc4ad36 A_SHAFinal+0xc6(Context=<internal error>, Result=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\ntdll\crypt.c:204] in ntdll (0x1f92ea38) 1 0x00420640 in snake (+0x20640) (0x1f92eae8)
Running snake.exe with WINEDEBUG=+relay took forever and didn't seem to contain any additional information.
https://bugs.winehq.org/show_bug.cgi?id=53321
--- Comment #1 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- Created attachment 72704 --> https://bugs.winehq.org/attachment.cgi?id=72704 snake.exe
https://bugs.winehq.org/show_bug.cgi?id=53321
f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- Keywords| |download
https://bugs.winehq.org/show_bug.cgi?id=53321
--- Comment #2 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- Comment on attachment 72703 --> https://bugs.winehq.org/attachment.cgi?id=72703 log of wine output
alexander@PC:~/Development/wine64> ./wine --version wine-7.12-81-g6c465ae8efe alexander@PC:~/Development/wine64> ./wine ../snake/snake.exe 00c0:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00c0:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00c4:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00c4:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00c8:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00c8:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00cc:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00cc:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00d0:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00d0:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00d4:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00d4:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00d8:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00d8:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00dc:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00dc:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00e0:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00e0:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00e4:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00e4:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00ec:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00ec:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00f0:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00f0:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 00fc:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 00fc:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0100:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0100:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0104:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0104:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0108:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0108:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 010c:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 010c:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0110:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0110:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0114:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0114:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0118:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0118:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 011c:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 011c:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0120:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0120:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) 0124:fixme:ntoskrnl:KeQueryPriorityThread (0000000000000000): stub. 0124:fixme:ntoskrnl:KeSetPriorityThread (0000000000000000 16) wine: Unhandled page fault on write access to 00000024 at address 7BC4AD36 (thread 0024), starting debugger... Unhandled exception: page fault on write access to 0x00000024 in 32-bit code (0x7bc4ad36). Register dump: CS:0023 SS:002b DS:002b ES:002b FS:0063 GS:006b EIP:7bc4ad36 ESP:1f92e9c0 EBP:1f92ea38 EFLAGS:00010246( R- -- I Z- -P- ) EAX:00000000 EBX:00020046 ECX:438dfd0f EDX:00000024 ESI:00000000 EDI:00000000 Stack dump: 0x1f92e9c0: 00000000 00000024 00000000 00000038 0x1f92e9d0: 494d5445 58414d4e 00000080 00000000 0x1f92e9e0: 00000000 00000000 00000000 00000000 0x1f92e9f0: 00000000 00000000 00000000 00000000 0x1f92ea00: 00000000 00000000 00000000 00000000 0x1f92ea10: 00000000 00000000 00000000 40300000 Backtrace: 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) =>0 0x7bc4ad36 A_SHAFinal+0xc6(Context=<internal error>, Result=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\ntdll\crypt.c:204] in ntdll (0x1f92ea38) 1 0x00420640 in snake (+0x20640) (0x1f92eae8) 2 0x7e92f0dc call_window_proc+0x2c(hwnd=<is not available>, msg=<is not available>, wp=<is not available>, lp=<is not available>, result=<is not available>, arg=<is not available>) [Z:\home\alexander\Development\wine-git\dlls\user32\winproc.c:145] in user32 (0x1f92eb38) 3 0x7e92f417 WINPROC_CallProcWtoA+0x187(callback=7E92F0B0, hwnd=00020046, msg=0x24, wParam=<is not available>, lParam=<is not available>, result=<is not available>, arg=<is not available>) [Z:\home\alexander\Development\wine-git\dlls\user32\winproc.c:572] in user32 (0x1f92eff8) 4 0x7e930e35 dispatch_win_proc_params+0x115(params=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\user32\winproc.c:762] in user32 (0x1f92f038) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 5 0x7e931097 User32CallWindowProc+0x177(params=<internal error>, size=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\user32\winproc.c:1277] in user32 (0x1f92f158) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 6 0xf7c87524 KeUserModeCallback+0xe4(id=<internal error>, args=<internal error>, len=<internal error>, ret_ptr=<internal error>, ret_len=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\ntdll\unix\signal_i386.c:1592] in ntdll.so (0x1f92f5f8) 7 0x7e48a3eb call_window_proc+0x26b(hwnd=<internal error>, msg=<internal error>, wparam=<internal error>, lparam=<is not available>, unicode=<is not available>, same_thread=<is not available>, mapping=<is not available>, needs_unpack=<is not available>, buffer=<is not available>, size=<is not available>) [Z:\home\alexander\Development\wine-git\dlls\win32u\m essage.c:255] in win32u.so (0x1f92f708) 8 0x7e48b5af process_message+0x17f(info=1F92F7C0, res_ptr=<internal error>, ansi=0) [Z:\home\alexander\Development\wine-git\dlls\win32u\message.c:2627] in win32u.so (0x1f92f7a8) 9 0x7e48b77e send_message+0x4e(hwnd=00020046, msg=0x24, wparam=0, lparam=0x1f92f878) [Z:\home\alexander\Development\wine-git\dlls\win32u\message.c:2755] in win32u.so (0x1f92f7f8) 10 0x7e4bc8db get_min_max_info+0x1fb(hwnd=<is not available>) [Z:\home\alexander\Development\wine-git\dlls\win32u\window.c:3865] in win32u.so (0x1f92f8b8) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 11 0x7e4c0d7f NtUserCreateWindowEx+0xd0f(ex_style=<internal error>, class_name=<internal error>, version=<internal error>, window_name=<internal error>, style=<internal error>, x=<internal error>, y=<internal error>, cx=<internal error>, cy=<internal error>, parent=<internal error>, menu=<internal error>, instance=<internal error>, params=<internal error>, flags=<internal error>, cbtc=<internal error>, unk=<internal error>, ansi=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\win32u\window.c:5238] in win32u.so (0x1f92fa68) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 12 0x7e55fbc7 NtUserCreateWindowEx+0xa7(ex_style=<internal error>, class_name=<internal error>, version=<internal error>, window_name=<internal error>, style=<internal error>, x=<internal error>, y=<internal error>, width=<internal error>, height=<internal error>, parent=<internal error>, menu=<internal error>, instance=<internal error>, params=<internal er ror>, flags=<internal error>, cbtc=<internal error>, unk=<internal error>, ansi=<internal error>) [Z:\home\alexander\Development\wine-git\dlls\win32u\wrappers.c:820] in win32u (0x1f92fb18) 13 0x7e92b61b WIN_CreateWindowEx+0xc7b(cs=<is not available>, className=<is not available>, module=<is not available>, unicode=<is not available>) [Z:\home\alexander\Development\wine-git\dlls\user32\win.c:622] in user32 (0x1f92fc48) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 0174:fixme:dbghelp_dwarf:compute_call_frame_cfa Too complex expression for frame_CFA resolution (RULE_VAL_EXPRESSION) 14 0x7e92c126 CreateWindowExA+0xf1(exStyle=<internal error>, className=<internal error>, windowName=<internal error>, style=<internal error>, x=<internal error>, y=<internal error>, width=<internal error>, height=<internal error>, parent=<internal error>, menu=<internal error>, instance=<internal error>, data=<internal error>) [Z:\home\alexander\Development \wine-git\dlls\user32\win.c:656] in user32 (0x1f92fea8) 15 0x0042018b in snake (+0x2018b) (0x10ca0000) 0x7bc4ad36 A_SHAFinal+0xc6 [Z:\home\alexander\Development\wine-git\dlls\ntdll\crypt.c:204] in ntdll: movl %ecx,0x0(%edx,%eax,4) 204 Result[Index] = DWORD2BE(Context->State[Index]); Modules: Module Address Debug info Name (58 modules) PE 00400000-1f82b6eb Export snake ELF 7b000000-7b2b7000 Deferred kernelbase<elf> -PE 7b030000-7b2b7000 \ kernelbase ELF 7b600000-7b68c000 Deferred kernel32<elf> -PE 7b620000-7b68c000 \ kernel32 ELF 7bc00000-7bccf000 Dwarf-4-5 ntdll<elf> -PE 7bc20000-7bccf000 \ ntdll ELF 7d000000-7d005000 Deferred <wine-loader> ELF 7dcd6000-7dd1a000 Deferred uxtheme<elf> -PE 7dce0000-7dd1a000 \ uxtheme ELF 7dd1a000-7dd23000 Deferred libxfixes.so.3 ELF 7dd23000-7dd30000 Deferred libxcursor.so.1 ELF 7dd30000-7dd44000 Deferred libxi.so.6 ELF 7dd44000-7dd54000 Deferred libxrandr.so.2 ELF 7dd54000-7dd61000 Deferred libxrender.so.1 ELF 7dd61000-7dd69000 Deferred libxxf86vm.so.1 ELF 7dd69000-7dd98000 Deferred libxcb.so.1 ELF 7dd98000-7deed000 Deferred libx11.so.6 ELF 7deed000-7df03000 Deferred libxext.so.6 ELF 7df20000-7df9a000 Deferred winex11.so ELF 7df9a000-7dfc3000 Deferred winex11<elf> -PE 7dfa0000-7dfc3000 \ winex11 ELF 7dfc3000-7dfeb000 Deferred imm32<elf> -PE 7dfd0000-7dfeb000 \ imm32 ELF 7e1ce000-7e1fd000 Deferred libexpat.so.1 ELF 7e1fd000-7e251000 Deferred libfontconfig.so.1 ELF 7e251000-7e274000 Deferred libbrotlicommon.so.1 ELF 7e274000-7e282000 Deferred libbrotlidec.so.1 ELF 7e282000-7e2a0000 Deferred libz.so.1 ELF 7e2a0000-7e2e4000 Deferred libpng16.so.16 ELF 7e2e4000-7e2fd000 Deferred libbz2.so.1 ELF 7e2fd000-7e3cb000 Deferred libfreetype.so.6 ELF 7e3cb000-7e3d0000 Deferred libxcomposite.so.1 ELF 7e3d0000-7e3d5000 Deferred libxinerama.so.1 ELF 7e3d5000-7e3da000 Deferred libxau.so.6 ELF 7e3e8000-7e535000 Dwarf-4-5 win32u.so ELF 7e535000-7e588000 Dwarf-4-5 win32u<elf> -PE 7e550000-7e588000 \ win32u ELF 7e588000-7e61f000 Deferred gdi32<elf> -PE 7e5a0000-7e61f000 \ gdi32 ELF 7e61f000-7e735000 Deferred ucrtbase<elf> -PE 7e650000-7e735000 \ ucrtbase ELF 7e735000-7e770000 Deferred sechost<elf> -PE 7e740000-7e770000 \ sechost ELF 7e770000-7e84b000 Deferred msvcrt<elf> -PE 7e7a0000-7e84b000 \ msvcrt ELF 7e84b000-7e8a6000 Deferred advapi32<elf> -PE 7e860000-7e8a6000 \ advapi32 ELF 7e8a6000-7ea86000 Dwarf-4-5 user32<elf> -PE 7e8d0000-7ea86000 \ user32 ELF 7ea86000-7eb8d000 Deferred libm.so.6 ELF 7eb93000-7ebaa000 Deferred version<elf> -PE 7eba0000-7ebaa000 \ version ELF 7ebaa000-7ed31000 Dwarf-4-5 libwine.so.1 ELF f7c4c000-f7cef000 Dwarf-4-5 ntdll.so ELF f7cef000-f7f23000 Deferred libc.so.6 ELF f7f42000-f7f7a000 Deferred ld-linux.so.2 ELF f7f7e000-f7f80000 Deferred [vdso].so Threads: process tid prio name (all IDs are in hex) 00000020 (D) Z:\home\alexander\Development\snake\snake.exe 00000024 0 <== 00000178 0 00000038 services.exe 0000003c 0 00000040 0 0000004c 0 00000050 0 0000006c 0 0000009c 0 000000b4 0 00000128 0 00000134 0 0000014c 0 00000044 winedevice.exe 00000048 0 00000054 0 00000058 0 0000005c 0 00000060 0 00000140 0 00000064 winedevice.exe 00000068 0 00000070 0 00000074 0 00000078 0 0000007c 0 00000088 0 0000008c 0 00000090 0 00000080 explorer.exe 00000084 0 000000e8 0 000000f4 0 00000094 plugplay.exe 00000098 0 000000a0 0 000000a4 0 000000a8 0 000000ac winedevice.exe 000000b0 0 000000b8 0 000000bc 0 000000c0 0 000000c4 0 000000c8 0 000000cc 0 000000d0 0 000000d4 0 000000d8 0 000000dc 0 000000e0 0 000000e4 0 000000ec 0 000000f0 0 000000fc 0 00000100 0 00000104 0 00000108 0 0000010c 0 00000110 0 00000114 0 00000118 0 0000011c 0 00000120 0 00000124 0 0000012c svchost.exe 00000130 0 00000138 0 0000013c 0 00000144 rpcss.exe 00000148 0 00000150 0 00000154 0 00000158 0 0000015c 0 00000160 0 00000164 0 00000168 conhost.exe 0000016c 0 System information: Wine build: wine-7.12-81-g6c465ae8efe Platform: i386 (WOW64) Version: Windows 10 Host system: Linux Host version: 5.18.6-1-default
https://bugs.winehq.org/show_bug.cgi?id=53321
Austin English austinenglish@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- CC| |austinenglish@gmail.com
https://bugs.winehq.org/show_bug.cgi?id=53321
Austin English austinenglish@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- Summary|Unhandled page fault on |snakeqr: Unhandled page |write access in A_SHAFinal |fault on write access in | |A_SHAFinal
https://bugs.winehq.org/show_bug.cgi?id=53321
Bernhard Übelacker bernhardu@mailbox.org changed:
What |Removed |Added ---------------------------------------------------------------------------- CC| |bernhardu@mailbox.org
--- Comment #3 from Bernhard Übelacker bernhardu@mailbox.org --- It looks like doing the link step with Crinkler adds a custom dll loader to the executable. That loader seems to try to lookup ntdll.NtdllDefWindowProc_A but cannot find it and erroneously takes the first export of ntdll, which is A_SHAFinal.
Therefore A_SHAFinal gets called later with wrong parameter and therefore crashes.
This can be seen by adding this stub entry to dlls/ntdll/ntdll.spec: +@ stub NtdllDefWindowProc_A
Then the output of snake.exe changes to: wine: Call from 7BC243E0 to unimplemented function ntdll.dll.NtdllDefWindowProc_A, aborting
Unfortunately I have currently no Idea how either forwarding this call from ntdll to user32 can/should work.
https://bugs.winehq.org/show_bug.cgi?id=53321
f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- CC| |f.alexander.wilms@gmail.com
--- Comment #4 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- Created attachment 72710 --> https://bugs.winehq.org/attachment.cgi?id=72710 Patch adding NtdllDefWindowProc_A
I tried to forward NtdllDefWindowProc_A to DefWindowProcA. I probably added it to the wrong source file, but the code compiles. However, it still results in an unhandled exception:
Unhandled exception: page fault on read access to 0x000ab0a0 in 32-bit code (0x000ab0a0). [...] =>0 0x000ab0a0 (0x1f92ea38) 1 0x00420640 in snake (+0x20640) (0x1f92eae8) 2 0x7e92f0dc call_window_proc+0x2c(hwnd=<is not available>, msg=<is not available>, wp=<is not available>, lp=<is not available>, result=<is not available>, arg=<is not availab le>) [Z:\home\alexander\Development\wine-git\dlls\user32\winproc.c:145] in user32 (0x1f92eb38) 3 0x7e92f417 WINPROC_CallProcWtoA+0x187(callback=7E92F0B0, hwnd=00020046, msg=0x24, wParam=<is not available>, lParam=<is not available>, result=<is not available>, arg=<is not available>) [Z:\home\alexander\Development\wine-git\dlls\user32\winproc.c:572] in user32 (0x1f92eff8)
https://bugs.winehq.org/show_bug.cgi?id=53321
Zeb Figura z.figura12@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- CC| |z.figura12@gmail.com Summary|snakeqr: Unhandled page |snakeqr: Unhandled page |fault on write access in |fault on write access in |A_SHAFinal |A_SHAFinal (needs | |NtdllDefWindowProc_A)
https://bugs.winehq.org/show_bug.cgi?id=53321
--- Comment #5 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- You're right, using the regular MSVC linker results in a binary which works just fine using wine-8.6 (Staging).
Meanwhile, the snakeqr code has been released under MIT license here: https://www.mattkc.com/etc/snakeqr/
Based on MattKC's video, I was able to build it myself.
Video timecode of build commands and MSVC version: https://youtu.be/ExwqNreocpg?t=748
Code with CI config to build exe: https://github.com/Alexander-Wilms/mattkc-snakeqr
build config: # Adapted from https://stackoverflow.com/a/64560687/2278742
name: Compile snake
on: - push
jobs: windows: name: run on windows runs-on: windows-2019 steps: - uses: actions/checkout@v2 - uses: ilammy/msvc-dev-cmd@v1.12.1 with: arch: x86 - name: compile run: | dir cl /c /01 /GS- snake.c dir # https://stackoverflow.com/a/53971921/2278742 link /nologo /ENTRY:main /NODEFAULTLIB /SUBSYSTEM:WINDOWS snake.obj kernel32.lib user32.lib gdi32.lib ucrt.lib dir - name: upload executable uses: actions/upload-artifact@v2 with: name: windows path: | snake.exe
https://bugs.winehq.org/show_bug.cgi?id=53321
--- Comment #6 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- I've been trying to link it with Crinkler 2.2 (cf. the Github repo), but so far without success.
The video shows output of Crinkler at https://www.youtube.com/watch?v=ExwqNreocpg&t=748s
One has to jump frame by frame to see it.
3 function calls are being forwarded:
: warning LNK: Entry point not at start of section, jump necessary Forced alignment of 1 code hunk to 1 (including entry point).
: warning LNK: Import 'HeapAlloc' from 'kernel32' uses forwarded RVA. Replaced by 'RtlAllocateHeap' from 'ntdll'
: warning LNK: Import 'DefWindowProcA' from 'user32' uses forwarded RVA. Replaced by 'NtdllDefWindowProc_A' from 'ntdll'
: warning LNK: Import 'rand' from 'api-ms-win-crt-utility-l1-1-0' uses forwarded RVA. Replaced by 'rand' from [?]
https://bugs.winehq.org/show_bug.cgi?id=53321
--- Comment #7 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- Created attachment 74419 --> https://bugs.winehq.org/attachment.cgi?id=74419 Output of MSVC's cl.exe and Crinkler.exe
https://bugs.winehq.org/show_bug.cgi?id=53321
Louis Lenders xerox.xerox2000x@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- CC| |xerox.xerox2000x@gmail.com
--- Comment #8 from Louis Lenders xerox.xerox2000x@gmail.com --- Created attachment 76033 --> https://bugs.winehq.org/attachment.cgi?id=76033 hack
This hack is utterly wrong but it allows the game to start and play and might be useful to test other apps that suffer from this bug. It's copy/paste code to try to load DefWindowProc from user32.dll
There's a test in user32/tests/class.c that shows that it should really be the other way around: DefWindowProc is forwarded to NtdllDefWindowProc from Vista+ on. That looks like quite a massive change but probably the way to go if one wants to resolve this bug :(
https://bugs.winehq.org/show_bug.cgi?id=53321
Alexandre Julliard julliard@winehq.org changed:
What |Removed |Added ---------------------------------------------------------------------------- Status|UNCONFIRMED |RESOLVED Fixed by SHA1| |9f9ce9fa46a6575d4c78f112707 | |ed879648db17a Resolution|--- |FIXED
--- Comment #9 from Alexandre Julliard julliard@winehq.org --- Fixed by 9f9ce9fa46a6575d4c78f112707ed879648db17a.
https://bugs.winehq.org/show_bug.cgi?id=53321
Alexandre Julliard julliard@winehq.org changed:
What |Removed |Added ---------------------------------------------------------------------------- Status|RESOLVED |CLOSED
--- Comment #10 from Alexandre Julliard julliard@winehq.org --- Closing bugs fixed in 9.22.
https://bugs.winehq.org/show_bug.cgi?id=53321
--- Comment #11 from f.alexander.wilms@gmail.com f.alexander.wilms@gmail.com --- I can confirm that the binary stored in the QR code works fine with wine-10.0-rc3.