-
Notifications
You must be signed in to change notification settings - Fork 569
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
String endianness is incorrect: big-endian strings cannot be read on little-endian machines #5595
Comments
Does #5302 fix this for you? On 2024.4 rc1 "vanilla" using an x86_64 computer I see:
If I then apply #5302 I see:
It seems to also help my Power9 (which is a big endian PPC64) handle little-endian examples from the SPIRV-LLVM-Translator test suite. |
Cool, the fix works fine. |
FYI: This kind of issue was originally discussed in 2016: https://www.khronos.org/members/login/bugzilla-public/show_bug.cgi?id=1474 |
According to the specification:
This means that bytes must be swapped before reading a big-endian spv file on a little-endian machine, and vice versa. For example,
glslang
outputs big-endian encoded spv binary files on big-endian machines. But when disassembling this file viaspirv-dis
on little-endian machines, only words and operands are handled properly via spvFixWord, strings are handled in host endianness, which is not correct.More specifically:
"GLSL.std.450" in big-endian encoding (or on big-endian machines), the first octet 'G' should be in the lowest-order byte, which is the fourth byte in a word. Then in the file (or memory), from the first byte to the last byte, from left to right is, 'L''S''L''G' 'd''t''s''.' '0''5''4''.' '\0''\0''\0''\0', 16 bytes and 4 words in total.
When reading this big-endian encoded file:
On big-endian machines, reinterpret the each consecutive 4 bytes as unit32_t, and use bit shift to obtain the first octet, like
(word >> 0) & 0xFF
. We will get the fourth byte, which is 'G', and this is correct.On little-endian machines, the result of the bit operation is the first byte, which is 'L'. This is not correct, because there is no call to
spvFixWord
.I'm making a compiler in Java myself and can selectively output spv binary files in little-endian or big-endian (the default is host endianness). I encountered this issue when running
spirv-dis
:A related issue is #149 and PR #4622, but it does not fix this issue.
My spirv-dis version:
SPIRV-Tools v2023.6 v2023.6.rc1-50-gdc667644
Here is my spv binary file for testing purposes, git describes this file as
Khronos SPIR-V binary, big-endian, version 0x010500, generator 00000000
, my CPU is little-endiantest_shader.zip
The text was updated successfully, but these errors were encountered: