Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[GPU LOCKUP] Deus Ex: Human Revolution DX11 tessellation #338

Open
chadmed opened this issue Oct 21, 2024 · 12 comments
Open

[GPU LOCKUP] Deus Ex: Human Revolution DX11 tessellation #338

chadmed opened this issue Oct 21, 2024 · 12 comments

Comments

@chadmed
Copy link

chadmed commented Oct 21, 2024

Deus Ex: Human Revolution (Proton Experimental, DX11) causes kernel driver crashes when tessellation is enabled. Visually, the game world loads but over the course of a few seconds rendering begins to degrade. Initially, this is seen as magenta tiles, then incorrectly rendered geometry, then a blank screen and unresponsive system. The game runs basically perfectly with tessellation disabled, modulo Wine-related issues this title has had for over a decade.

asahi-diagnose-20241021-204402.txt

@jannau
Copy link
Member

jannau commented Oct 22, 2024

https://gitlab.freedesktop.org/asahi/mesa/-/merge_requests/295 has fixes for indirect tess, worth trying to test.

Would make sense to reference #72

@alyssarosenzweig
Copy link
Member

HeapAllocator[File 2974 VM 1 GPU FW Private]::new: Failed to insert node of size 0x400000000 / align 0x8000: ENOSPC

@asahilina is this a kernel bug or a plain OOM?

@asahilina
Copy link
Member

asahilina commented Oct 24, 2024 via email

@chadmed
Copy link
Author

chadmed commented Nov 17, 2024

Still borked with mesa tag 20241111 (host and FEX rootfs) but... slightly less so? The GPU can recover from the fault now and the game instantly crashes. No more HeapAllocator errors, just a bunch of what look like unmapped mem/OOM issues.

[ 6804.318998] asahi 406400000.gpu:  (\________/) 
[ 6804.319008] asahi 406400000.gpu:   |        |  
[ 6804.319010] asahi 406400000.gpu: '.| \  , / |.'
[ 6804.319012] asahi 406400000.gpu: --| / (( \ |--
[ 6804.319014] asahi 406400000.gpu: .'|  _-_-  |'.
[ 6804.319015] asahi 406400000.gpu:   |________|  
[ 6804.319017] asahi 406400000.gpu: ** GPU timeout nya~!!!!! **
[ 6804.319018] asahi 406400000.gpu:   Event slot: 25
[ 6804.319022] asahi 406400000.gpu:   Timeout count: 0
[ 6804.319023] asahi 406400000.gpu:   Unk: 0
[ 6804.319026] asahi 406400000.gpu:   Fault info: FaultInfo {
                   address: 0x0,
                   sideband: 0x38,
                   vm_slot: 0x36,
                   unit_code: 0xa,
                   unit: IPF(
                       0x0,
                   ),
                   level: 0x2,
                   unk_5: 0x0,
                   read: true,
                   reason: Unmapped,
               }
[ 6804.319038] asahi 406400000.gpu:   Pending events:
[ 6804.319039] asahi 406400000.gpu:     [0:21] flags=13 value=0x1557b200
[ 6804.319042] asahi 406400000.gpu:     [1:25] flags=7 value=0x1955a800
[ 6804.319045] asahi 406400000.gpu:   Halt count: 1
[ 6804.319047] asahi 406400000.gpu:   Halted: 1
[ 6804.319049] asahi 406400000.gpu:   Attempting recovery...

@asahilina
Copy link
Member

@alyssarosenzweig Don't know if that's the problem at this point, but do we want to investigate if we can have a special path for vertex-only passes without a giant tile buffer? If Mesa can know this is vertex-only it's possible we can do something like just give the GPU unmapped memory for the TVB head pointers and TPC (the TPC size can be set to zero, it's only used by the firmware to know how much to clear) and then pass dummy parameters to the fragment stage so it doesn't try to read them. I can investigate if Metal can do this or try to experimentally figure it out myself, if it's important.

@alyssarosenzweig
Copy link
Member

@alyssarosenzweig Don't know if that's the problem at this point, but do we want to investigate if we can have a special path for vertex-only passes without a giant tile buffer? If Mesa can know this is vertex-only it's possible we can do something like just give the GPU unmapped memory for the TVB head pointers and TPC (the TPC size can be set to zero, it's only used by the firmware to know how much to clear) and then pass dummy parameters to the fragment stage so it doesn't try to read them. I can investigate if Metal can do this or try to experimentally figure it out myself, if it's important.

I mean, maybe? Do we have a reason to think this is vertex only? The spicy case with Dx12 (and only DX12, dxvk doesn't do this AFAIK) is with no attachments, but you still have to run the fragment shaders and rasterize and everything since the FS will have global memory writes

@asahilina
Copy link
Member

Sorry, I was confused ^^

@chadmed
Copy link
Author

chadmed commented Nov 30, 2024

I've just been hit with the original systemwide lockup in the Steam version of Black Mesa. Mesa 20241111 in both the fex and normal filesystems, kernel asahi-6.12.1-4.

@asahilina
Copy link
Member

As mentioned on Matrix: If you're running Mesa built against LLVM19 on Gentoo, that's known broken with tess...

@chadmed
Copy link
Author

chadmed commented Dec 12, 2024

Rebuilding mesa against LLVM 18 did not solve this :(

@chadmed
Copy link
Author

chadmed commented Dec 29, 2024

Explicitly thunking Vulkan with an AppConfig for dxhr.exe resolves this and allows tessellation to be used.

@asahilina
Copy link
Member

@alyssarosenzweig ^^ That sounds like another arch-layout-dep in the x86 build? I think you fixed one of those recently?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants