bugzilla-daemon at freedesktop.org
2019-Jan-16 00:36 UTC
[Nouveau] [Bug 109371] New: Textures seem to be byteswapped on big endian architectures
https://bugs.freedesktop.org/show_bug.cgi?id=109371 Bug ID: 109371 Summary: Textures seem to be byteswapped on big endian architectures Product: Mesa Version: 18.3 Hardware: PowerPC OS: Linux (All) Status: NEW Severity: normal Priority: medium Component: Drivers/DRI/nouveau Assignee: nouveau at lists.freedesktop.org Reporter: kungfujesus06 at gmail.com QA Contact: nouveau at lists.freedesktop.org When using an NV43 based GPU on a PPC64 kernel with a 64 bit userspace, it seems applications will have byte swapped textures when specified with GL_RGBA and GL_UNSIGNED_BYTE. Matplotlib will do this when blit=True for the plot routines, and several games will have this issue. In particular, for Legacy Doom, I've found that if I swap the textures so that they are A,B,G,R just before the textures are mapped, everything is correct. I also found that doing glPixelStorei(GL_UNPACK_BYTES, GL_TRUE) and choosing GL_UNSIGNED_INT_8_8_8_8 as the representation seemed to also remedy this. I found that the _REV variant didn't byte swap the textures back to the incorrect ordering (this is probably a different bug). Easiest way to demonstrate the bug: svn co https://svn.code.sf.net/p/doomlegacy/svn/legacy_one/trunk doomlegacy cd doomlegacy make OS=LINUX make cd bin Grab this archive: https://sourceforge.net/projects/doomlegacy/files/1.47.2/doomlegacy_1.47.2_common.zip/download, unzip it, extract legacy.wad into the bin directory Grab this archive: https://github.com/freedoom/freedoom/releases/download/v0.11.3/freedoom-0.11.3.zip, extract, move freedoom1.wad into the bin directory. Then do: ./doomlegacy -iwad freedoom1.wad -opengl -- You are receiving this mail because: You are the QA Contact for the bug. You are the assignee for the bug. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.freedesktop.org/archives/nouveau/attachments/20190116/fa4fb110/attachment.html>
bugzilla-daemon at freedesktop.org
2019-Jan-16 00:40 UTC
[Nouveau] [Bug 109371] Textures seem to be byteswapped on big endian architectures
https://bugs.freedesktop.org/show_bug.cgi?id=109371 --- Comment #1 from Ilia Mirkin <imirkin at alum.mit.edu> --- You'd save me a bunch of effort by performing these steps yourself, and tracing using apitrace (https://github.com/apitrace/apitrace). Ideally record an as-short-as-possible trace, and check that it still looks bad on replay, and then xz -9 it and attach here. -- You are receiving this mail because: You are the QA Contact for the bug. You are the assignee for the bug. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.freedesktop.org/archives/nouveau/attachments/20190116/27d06986/attachment-0001.html>
bugzilla-daemon at freedesktop.org
2019-Jan-16 05:41 UTC
[Nouveau] [Bug 109371] Textures seem to be byteswapped on big endian architectures
https://bugs.freedesktop.org/show_bug.cgi?id=109371 --- Comment #2 from Adam Stylinski <kungfujesus06 at gmail.com> --- Created attachment 143138 --> https://bugs.freedesktop.org/attachment.cgi?id=143138&action=edit Trace demoing the issue Heh, the issue is there by the time I hit the title screen. -- You are receiving this mail because: You are the QA Contact for the bug. You are the assignee for the bug. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.freedesktop.org/archives/nouveau/attachments/20190116/00fe3ad6/attachment.html>
bugzilla-daemon at freedesktop.org
2019-Jan-19 20:31 UTC
[Nouveau] [Bug 109371] Textures seem to be byteswapped on big endian architectures
https://bugs.freedesktop.org/show_bug.cgi?id=109371 --- Comment #3 from Ilia Mirkin <imirkin at alum.mit.edu> --- Unfortunately it appears that my G5 is dead. It half-booted once (died right around nfsroot load time). Then for a bit it would turn on, with fans going but no light and no chime. Now the fans don't even turn on. So I think that's the end. The things I would have done: 1. Check whether the textures look OK in qapitrace's inspector 2. Look at the transfer methods being used (in nv30_transfer.c). Try commenting some out, although that can also lead to failures. 3. Try to create a simple program based on the apitrace which reproduces the issue, and debug it step by step, to figure out where the byteswap might be happening. A few bits of info: The GPUs are LE deep down inside. However they have BE modes which byteswap "some stuff". So like MMIO accesses, FIFO commands, etc. So they can still be packed like integers as usual, without an extra byteswap, and the GPU will "take care of it". I don't have a clean idea of whether and how byteswapping happens between GART and VRAM, as well as in various "blit"/copy methods, where the byteswap would be different depending on whether it's u8, u16, or u32 datatype. This is most relevant to index buffers though, not textures. [Like let's say you're feeding the data via FIFO commands, there's an implicit byteswap there, etc.] Have a look at nv30_format.c for the supported texture formats/etc. As always, feel free to ask stuff in #nouveau. It should be noted that with a patch to apitrace (https://github.com/apitrace/apitrace/issues/601#issuecomment-455019551), the attached trace replays fine on both nv42 and nv34 on x86. -- You are receiving this mail because: You are the QA Contact for the bug. You are the assignee for the bug. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.freedesktop.org/archives/nouveau/attachments/20190119/04f2a0f8/attachment.html>
bugzilla-daemon at freedesktop.org
2019-Sep-18 20:47 UTC
[Nouveau] [Bug 109371] Textures seem to be byteswapped on big endian architectures
https://bugs.freedesktop.org/show_bug.cgi?id=109371 GitLab Migration User <gitlab-migration at fdo.invalid> changed: What |Removed |Added ---------------------------------------------------------------------------- Resolution|--- |MOVED Status|NEW |RESOLVED --- Comment #4 from GitLab Migration User <gitlab-migration at fdo.invalid> --- -- GitLab Migration Automatic Message -- This bug has been migrated to freedesktop.org's GitLab instance and has been closed from further activity. You can subscribe and participate further through the new bug through this link to our GitLab instance: https://gitlab.freedesktop.org/mesa/mesa/issues/1167. -- You are receiving this mail because: You are the QA Contact for the bug. You are the assignee for the bug. -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.freedesktop.org/archives/nouveau/attachments/20190918/4f4f9b69/attachment.html>
Apparently Analagous Threads
- [Bug 49295] New: artifacts in prboom on NV86
- [Bug 97508] New: Rogue Legacy 4th area with corrupted textures
- [Bug 92306] New: GL Excess demo renders incorrectly on nv43
- [Bug 89019] New: Black texture using Qt5
- [Bug 99400] New: garbled rending with glamor on G71