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

[SPIR-V][Feature Request] Implement Buffer Pointers in HLSL With vk::BufferPointer #6489

Open
Keenuts opened this issue Apr 3, 2024 · 13 comments
Assignees
Labels
enhancement Feature suggestion spirv Work related to SPIR-V
Milestone

Comments

@Keenuts
Copy link
Collaborator

Keenuts commented Apr 3, 2024

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.

@Keenuts Keenuts added enhancement Feature suggestion spirv Work related to SPIR-V labels Apr 3, 2024
@Keenuts Keenuts changed the title [Feature Request] Implement Buffer Pointers in HLSL With vk::BufferPointer [SPIR-V][Feature Request] Implement Buffer Pointers in HLSL With vk::BufferPointer Apr 3, 2024
@devshgraphicsprogramming
Copy link

devshgraphicsprogramming commented Apr 16, 2024

Here's the deal, given that Proposal 0011 is merged, I could implement proposal 0010 as a pure header-only library.

Provided this issue is fixed
#5784

@devshgraphicsprogramming

I'm actually quite close to getting it working, blocked by #6541 though

@s-perron
Copy link
Collaborator

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 get() is suppose to return a reference, but that cannot be expressed in HLSL at this time. When references are added to HLSL properly, then we could implement it in inline spir-v.

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.

@Tobski
Copy link

Tobski commented Jun 21, 2024

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?

@s-perron
Copy link
Collaborator

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 operator[]. We will essentially implement the same concept.

@devshgraphicsprogramming

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.

@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)

@buzmeg
Copy link

buzmeg commented Nov 12, 2024

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.

@devshgraphicsprogramming
Copy link

devshgraphicsprogramming commented Nov 12, 2024

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 vk::SpirvType and Inline Spir-V intrinsics, HOWEVER they only work for is_fundamental_v<T> (scalar and vector) and I've been banging the drum over and over again that if only this little issue (DXC not being able to figure out/annotate the offsets/layouts for a struct type T #6541) got fixed I'd be able to make BDA for all types.

I mean, heck, I even have atomics on my BDAs!
See our counting sort https://github.com/Devsh-Graphics-Programming/Nabla/blob/d37770f6dfab7f19de6c798ddd2c5a93256ee7ae/include/nbl/builtin/hlsl/bda/bda_accessor.hlsl#L39

Again I'm not a dev so they can probably tell you more about the roadmap

@s-perron
Copy link
Collaborator

AMD is working on an implementation. @danbrown-amd Can you provide an update?

@danbrown-amd
Copy link
Contributor

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.

@s-perron
Copy link
Collaborator

@danbrown-amd Any updates? Do you have an updated eta on the PR?

@devshgraphicsprogramming
Copy link

devshgraphicsprogramming commented Jan 10, 2025

I already have this (as in equivalent capability) working using inline SPIR-V and used in production for months now, including uint32_t, uint64_t and float32_t atomics.

Image

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 SpirvTypeOpaque denoting a PhysicalStorageBuffer address space pointer

@danbrown-amd
Copy link
Contributor

@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.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement Feature suggestion spirv Work related to SPIR-V
Projects
Status: New
Development

No branches or pull requests

7 participants