-
Notifications
You must be signed in to change notification settings - Fork 713
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
[SPIR-V][Feature Request] Implement Buffer Pointers in HLSL With vk::BufferPointer #6489
Comments
Here's the deal, given that Proposal 0011 is merged, I could implement proposal 0010 as a pure header-only library.
|
I'm actually quite close to getting it working, blocked by #6541 though |
I've looked at this more closely. We might be able to implement something similar to the proposal using inline spir-v, but it cannot implement is properly. The main reason is the I don't think we should wait until them. The reason this is such a big deal is that if you cannot return a reference, then the number of operations you will need to define in inline spir-v grows to a huge number. You will have to define specific load and store instruction. You'll have to redefine all of the atomic operations. Just in general the syntax will not be as clean. We still need to do a builtin definition of the class to be able to get the reference semantics right. |
Hmm, the only thing I'm wondering here though is that if that proposal relies on references, do we need an implementation of references proper to actually make that work anyway? Or do you think it's possible to implement that proposal without doing so? |
Good question. I do not think that is a problem because we have precedent for having builtin functions that return a reference. It might not be described that way, but that is what it is. For example RWStructuredBuffer::operator[] really returns a reference. The same for any |
@s-perron its worse thank you think, you can't define a reference with current inline SPIR-V hence my request for #6578 (which follows/supersedes my #5675 request) |
Anybody know what the status of this is? It's one of the big points of incompatibility preventing people from fully migrating off of GLSL. |
AFAIK, not in development for DXC, probably in dev for Clang-HLSL. Already implemented in Slang. I've been able to make my own BDA with I mean, heck, I even have atomics on my BDAs! Again I'm not a dev so they can probably tell you more about the roadmap |
AMD is working on an implementation. @danbrown-amd Can you provide an update? |
I've circulated in-house an implementation of everything but the templated casts. (I've asked @greg-lunarg for clarification about how the alignment template parameter should show up in the output.) I'm hoping to get a PR out in 2024. |
@danbrown-amd Any updates? Do you have an updated eta on the PR? |
I already have this (as in equivalent capability) working using inline SPIR-V and used in production for months now, including except that it only works on scalar and vector types as I'm blocked #6541 on access chains and DXC loosing its marbles about the offset decorations on a struct whenever I want to put it inside |
@s-perron Unfortunately, while my implementation is complete, I can't provide an ETA for the PR. I've been awaiting internal review for a while and don't know when that will happen. |
The proposal for BufferPointer is now in the accepted state.
So we should now be able to start implementation on this.
https://github.com/microsoft/hlsl-specs/blob/main/proposals/0010-vk-buffer-ref.md
Adding this issue to track the SPIR-V side of the work.
The text was updated successfully, but these errors were encountered: