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

feat: add logic to sort swapchain formats #103

Merged
merged 2 commits into from
Oct 25, 2024

Conversation

pollend
Copy link
Contributor

@pollend pollend commented Oct 25, 2024

this logic attempts to sort swapchains and pick the best swapchain given criteria for SwapChainFormat. I place the colorspace at the highest bit so its sorted by colorspace then by formats. formats have to be unorm where the bitwidth matches the criteria. code feels a bit overbuilt though.

does it matter if its bgra vs rgba depending on the driver? should it be more consistent in the selection I don't think it should matter?

#102

@dzhdanNV
Copy link
Collaborator

Thanks for improving this. I have a few questions:

  1. Sometimes you use:
((!formatProps.isSrgb) << 4) | ((surface.colorSpace == X) << 4);

Sometimes:

((!formatProps.isSrgb) << 4) | ((surface.colorSpace == X) << 5);

Why?

  1. case nri::SwapChainFormat::BT709_G10_16BIT: uses priority_BT709_G22_16BIT. Why?

  2. Should formatProps.isSrgb be used for 10 bits? 10 bit RGB doesn't have sRGB evil-twin format (but swap chain has supports gamma 2.2 transfer function).

P.S. Probably I understand why, but would like to hear your explanation.

@pollend
Copy link
Contributor Author

pollend commented Oct 25, 2024

Thanks for improving this. I have a few questions:

1. Sometimes you use:
((!formatProps.isSrgb) << 4) | ((surface.colorSpace == X) << 4);

Sometimes:

((!formatProps.isSrgb) << 4) | ((surface.colorSpace == X) << 5);

Why?

2. `case nri::SwapChainFormat::BT709_G10_16BIT:` uses `priority_BT709_G22_16BIT`. Why?

3. Should `formatProps.isSrgb` be used for `10 bits`? 10 bit RGB doesn't have `sRGB` evil-twin format (but swap chain has supports gamma 2.2 transfer function).

P.S. Probably I understand why, but would like to hear your explanation.

probably oversight on my end. I would drop the srgb check from 10bits and for the other formats that don't even have it? looks like only 8 bit formats have srgb. Im not familiar with what formats are available or what to expect from the surface? you can have a set of bits and a number so it would sort by flags then order by number? you can pack it all into one uint32.

would this have to be done for DirectX as well?

@dzhdanNV
Copy link
Collaborator

Sure. This logic seems GAPI irrelevant, so better share it between D3D11/D3D12/VK.

Could you please formulate your problem? I understand that my simple checks "are not enough", but I didn't get which set of surface formats you have and which surface format from this list is not selected being desired?

@dzhdanNV
Copy link
Collaborator

This logic seems GAPI irrelevant, so better share it between D3D11/D3D12/VK.

Ooops. My bad. Not needed for D3D, because there is always full support for those.

@dzhdanNV
Copy link
Collaborator

Summary:

  • please, explain your problem
    • list of surface formats you have
    • desired but unselected surface format
  • this code is not needed for D3D
  • polish the PR and I will merge it

@pollend
Copy link
Contributor Author

pollend commented Oct 25, 2024

Sure. This logic seems GAPI irrelevant, so better share it between D3D11/D3D12/VK.

Could you please formulate your problem? I understand that my simple checks "are not enough", but I didn't get which set of surface formats you have and which surface format from this list is not selected being desired?

// Color space:
//  - BT.709 - LDR https://en.wikipedia.org/wiki/Rec._709
//  - BT.2020 - HDR https://en.wikipedia.org/wiki/Rec._2020
// Transfer function:
//  - G10 - linear (gamma 1.0)
//  - G22 - sRGB (gamma ~2.2)
//  - G2084 - SMPTE ST.2084 (Perceptual Quantization)
// Bits per channel:
//  - 8, 10, 16 (float)

This is the criteria I'm thinking of given the enum. My thought would be colorspace followed by format. For the format I guess you would order by closest matching. would the order of the channels matter I wouldn't assume so since that is regardless of the shading code right? outputting to bgra is the same as rgba.

  • BT709_G10_16BIT
    • R16G16B16A16
    • VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT
  • BT709_G22_8BIT
    • R8G8B8A8
    • non srgb
    • VK_COLOR_SPACE_SRGB_NONLINEAR_KHR
  • BT709_G22_10BIT
    • R10G10B10A2
    • VK_COLOR_SPACE_SRGB_NONLINEAR_KHR
  • BT2020_G2084_10BIT
    • R10G10B10A2
    • VK_COLOR_SPACE_HDR10_ST2084_EXT

I haven't worked with these other colorspace formats so i'm not familiar with the expectation. you can always add more bits if you want to prioritize one colorspace then the other if one is closer then the other color space. reserve a part of the value for the colorspace so maybe like 4 bits so you write 1 for this colorspace then 2 for this colorspace so colorspace 1 would be first followed by colorspace 2.

still working on this project so my machine is the only sample at the moment. so the code here expected BGRA8 but mesa/AMD reports RGBA8. sorry, if i can't give you a really straight answer.

@dzhdanNV
Copy link
Collaborator

outputting to bgra is the same as rgba

Right. Unless you want to access the texture in a shader code. Not a big problem, since NRI returns swap chain format (in one way or another), so the app is aware.

Agree with the rest.

Do you plan to add more changes?

@pollend
Copy link
Contributor Author

pollend commented Oct 25, 2024

outputting to bgra is the same as rgba

Right. Unless you want to access the texture in a shader code. Not a big problem, since NRI returns swap chain format (in one way or another), so the app is aware.

Agree with the rest.

Do you plan to add more changes?

I'll quickly make the changes unless its easier on your end to just rework what i have.

@pollend
Copy link
Contributor Author

pollend commented Oct 25, 2024

outputting to bgra is the same as rgba

Right. Unless you want to access the texture in a shader code. Not a big problem, since NRI returns swap chain format (in one way or another), so the app is aware.

Agree with the rest.

Do you plan to add more changes?

the original code was a bit overbuilt I think these criteria should be a good start if it needs to be adjusted that can always happen later. for srgb scenario you don't need to handle it because if it reports SRGB then there must be an associated UNORM.

you might get an idea looking at this: https://vulkan.gpuinfo.org/listsurfaceformats.php

There are a lot of scenarios to consider ... I think its should be safe to start with these until something comes up.

Signed-off-by: Michael Pollind <[email protected]>
@pollend pollend force-pushed the feature/prio-swapchain-format branch from 15d94bf to bcaa730 Compare October 25, 2024 04:30
@dzhdanNV dzhdanNV merged commit 11a4d0d into NVIDIAGameWorks:main Oct 25, 2024
2 checks passed
@pollend pollend deleted the feature/prio-swapchain-format branch October 25, 2024 04:40
@dzhdanNV
Copy link
Collaborator

Thanks Michael. This is a solid starting point.

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

Successfully merging this pull request may close these issues.

2 participants