NRI is a low-level abstract render interface, which has been designed to support all low level features of D3D12 and Vulkan GAPIs, but at the same time to simplify usage and reduce the amount of code needed (especially compared with VK).
Goals:
- generalization of D3D12 (spec) and VK (spec) GAPIs
- explicitness (providing access to low-level features of modern GAPIs)
- "quality of life" features (providing high-level improving utilities, organized as extensions)
- low overhead
- cross platform and platform independence (AMD/INTEL friendly)
- D3D11 (spec) support (as much as possible)
Non-goals (exceptions apply to helper interfaces, where high-level abstraction and hidden management are desired):
- high level (D3D11-like) abstraction
- exposing entities not existing in GAPIs
- hidden management of any kind
Currently supported GAPIs:
- VK (Vulkan 1.2+ with extensions, preferring core 1.3)
- D3D12
- D3D11
- Metal (through MoltenVK)
- None / dummy (everything is supported, but does nothing)
Key features:
- C++ and C compatible interfaces
- generalized common denominator for D3D12, VK and D3D11 GAPIs
- low overhead
- no memory allocations at runtime
- descriptor indexing support
- ray tracing support
- mesh shaders support
- D3D12 Ultimate features support, including enhanced barriers
- VK printf support
- validation layers (GAPI- and NRI- provided)
- default D3D11 behavior is changed to match D3D12/VK using NVAPI or AMD AGS libraries, where applicable
- supporting as much as possible VK-enabled platforms: Windows, Linux, MacOS, Android
- can be used as a shared or static library
Available interfaces:
NRI.h
- core functionalityNRIDeviceCreation.h
- device creation and related functionalityNRIHelper.h
- a collection of various helpers to ease use of the core interfaceNRILowLatency.h
- low latency support (aka NVIDIA REFLEX)NRIMeshShader.h
- mesh shadersNRIRayTracing.h
- ray tracingNRIResourceAllocator.h
- convenient creation of resources using AMD Virtual Memory Allocator, which get returned already bound to memoryNRIStreamer.h
- a convenient way to stream data into resourcesNRISwapChain.h
- swap chain and related functionality
Hooked up Vulkan extensions:
Required:
- VK_KHR_synchronization2 (for Vulkan 1.2)
- VK_KHR_dynamic_rendering (for Vulkan 1.2)
- VK_KHR_maintenance4 (for Vulkan 1.2)
- VK_KHR_portability_subset (for APPLE)
Optional:
- VK_KHR_swapchain
- VK_KHR_present_id
- VK_KHR_present_wait
- VK_KHR_swapchain_mutable_format
- VK_KHR_maintenance5
- VK_KHR_fragment_shading_rate
- VK_KHR_push_descriptor
- VK_KHR_pipeline_library
- VK_KHR_ray_tracing_pipeline
- VK_KHR_acceleration_structure (depends on VK_KHR_deferred_host_operations)
- VK_KHR_ray_query
- VK_KHR_ray_tracing_maintenance1
- VK_KHR_line_rasterization
- VK_KHR_fragment_shader_barycentric
- VK_EXT_opacity_micromap
- VK_EXT_sample_locations
- VK_EXT_conservative_rasterization
- VK_EXT_mesh_shader
- VK_EXT_shader_atomic_float
- VK_EXT_shader_atomic_float2
- VK_EXT_memory_budget
- VK_EXT_memory_priority
- VK_EXT_image_sliced_view_of_3d
- VK_EXT_custom_border_color
- VK_EXT_robustness2
- VK_EXT_pipeline_robustness
- VK_EXT_fragment_shader_interlock
Vendor specific:
- VK_NV_low_latency2
NRI sample code:
C++ | C |
---|---|
nri::Interface |
NriInterface |
nri::Enum::MEMBER |
NriEnum_MEMBER |
nri::CONST |
NRI_CONST |
nri::nriFunction |
nriFunction |
nri::Function |
nriFunction |
Reference & |
Pointer * |
NRI | D3D11 | D3D12 | VK |
---|---|---|---|
Device |
ID3D11Device |
ID3D12Device |
VkDevice |
CommandBuffer |
ID3D11DeviceContext (deferred) |
ID3D12CommandList |
VkCommandBuffer |
CommandQueue |
ID3D11DeviceContext (immediate) |
ID3D12CommandQueue |
VkQueue |
Fence |
ID3D11Fence |
ID3D12Fence |
VkSemaphore (timeline) |
CommandAllocator |
N/A | ID3D12CommandAllocator |
VkCommandPool |
Buffer |
ID3D11Buffer |
ID3D12Resource |
VkBuffer |
Texture |
ID3D11Texture |
ID3D12Resource |
VkImage |
Memory |
N/A | ID3D12Heap |
VkDeviceMemory |
Descriptor |
ID3D11*View |
D3D12_CPU_DESCRIPTOR_HANDLE |
Vk*View or VkSampler |
DescriptorSet |
N/A | N/A | VkDescriptorSet |
DescriptorPool |
N/A | ID3D12DescriptorHeap |
VkDescriptorPool |
PipelineLayout |
N/A | ID3D12RootSignature |
VkPipelineLayout |
Pipeline |
ID3D11*Shader and ID3D11*State |
ID3D12StateObject |
VkPipeline |
AccelerationStructure |
N/A | ID3D12Resource |
VkAccelerationStructure |
- Install Cmake 3.15+
- Install on
- Windows: latest WindowsSDK and VulkanSDK
- Linux (x86-64): latest VulkanSDK and optional libx11-dev and libwayland-dev
- Linux (aarch64): optional libx11-dev and libwayland-dev
- Build (variant 1) - using Git and CMake explicitly
- Clone project and init submodules
- Generate and build the project using CMake
- Build (variant 2) - by running scripts:
- Run
1-Deploy
- Run
2-Build
- Run
Notes:
- Xlib and Wayland can be both enabled
- Minimal supported client is Windows 8.1+. Windows 7 support requires minimal effort and can be added by request
NRI_STATIC_LIBRARY
- build NRI as a static library (off
by default)NRI_ENABLE_NVTX_SUPPORT
- annotations for NVIDIA Nsight Systems (off
by default)NRI_ENABLE_NONE_SUPPORT
- enable NONE backend (on
by default)NRI_ENABLE_VK_SUPPORT
- enable VULKAN backend (on
by default)NRI_ENABLE_D3D11_SUPPORT
- enable D3D11 backend (on
by default on Windows)NRI_ENABLE_D3D12_SUPPORT
- enable D3D12 backend (on
by default on Windows)
VK only:
NRI_ENABLE_XLIB_SUPPORT
- enable Xlib support (on
by default)NRI_ENABLE_WAYLAND_SUPPORT
- enable Wayland support (on
by default)
D3D12 only:
NRI_ENABLE_AGILITY_SDK_SUPPORT
- enable Agility SDK (off
by default)NRI_AGILITY_SDK_PATH
- path to a directory containing Agility SDK: contents of.nupkg/build/native/
(C:/AgilitySDK
by default)NRI_AGILITY_SDK_VERSION
- Agility SDK version (614
or newer)NRI_AGILITY_SDK_DIR
- directory where Agility SDK binaries will be copied to relative toCMAKE_RUNTIME_OUTPUT_DIRECTORY
(AgilitySDK
by default)
Overview and Download sections can be found here.
D3D12 backend uses Agility SDK to get access to most recent D3D12 features. As soon as these features become available in the OS, installation of Agility SDK will be deprecated.
Installation steps:
- download Agility SDK package
preview
versions require enabling Developer Mode in Windows
- rename
.nupkg
into.zip
- extract contents of
.nupkg/build/native
intoNRI_AGILITY_SDK_PATH
folder- can be located anywhere
- set
NRI_AGILITY_SDK_DIR
to a path, wherebin
folder needs to be copied- most likely closer to the executable
- set
NRI_AGILITY_SDK_VERSION
to the version of the package - enable
NRI_ENABLE_AGILITY_SDK_SUPPORT
- re-deploy project
- include auto-generated
NRIAgilitySDK.h
header in the code of your executable, using NRI
NRI samples can be found here.
Samples:
- DeviceInfo - queries and prints out information about device groups in the system
- Clear - minimal example of rendering using framebuffer clears only
- CTest - very simple example of C interface usage
- Triangle - simple textured triangle rendering (also multiview demonstration in FLEXIBLE mode)
- SceneViewer - loading & rendering of meshes with materials (also tests programmable sample locations, shading rate and pipeline statistics)
- BindlessSceneViewer - bindless GPU-driven rendering test
- Readback - getting data from the GPU back to the CPU
- AsyncCompute - demonstrates parallel execution of graphic and compute workloads
- MultiThreading - shows advantages of multi-threaded command buffer recording
- Multiview - multiview demonstration in LAYER_BASED mode (VK and D3D12 compatible)
- MultiGPU - multi GPU example
- RayTracingTriangle - simple triangle rendering through ray tracing
- RayTracingBoxes - a more advanced ray tracing example with many BLASes in TLAS
- Wrapper - shows how to wrap native D3D11/D3D12/VK objects into NRI entities
- Resize - demonstrates window resize
NRI is licensed under the MIT License. This project includes NVAPI software. All uses of NVAPI software are governed by the license terms specified here.