Вообще речь про что, я наблюдал у них там в примерах ряд нелогичности. Например, они делают проверку на D3D_ROOT_SIGNATURE_VERSION_1_1. И если поддержки нет, то выставляется D3D_ROOT_SIGNATURE_VERSION_1_0. Но, затем, какой бы не был результат, всё равно по коду используется D3D12_DESCRIPTOR_RANGE1, D3D12_ROOT_PARAMETER1 и D3D12_ROOT_SIGNATURE_DESC1. Я не знаю, может их можно и при D3D_ROOT_SIGNATURE_VERSION_1_0 использовать, но всё равно насторожился. Поэтому ко всем их примерам...
Про UPLOAD и DEFAULT понятно. UPLOAD же не обязательно должна быть память на CPU, она же может быть и на GPU, только с доступом для CPU. А вот DEFAULT будет уже или внутренней памятью для GPU, куда у CPU нет доступа, или же системной памятью с полным доступом для CPU. Всё зависит от дискретной или интегрированной карточки.
Вопрос в том, какой лучше поступать с константным буфером, данные которого нужно обновлять часто (матрица ModelViewProj). Достаточно просто создать его в UPLOAD или же, если если дискретная карточка, то создать ещё и в DEFAULT и копировать каждый кадр. Ну и термин per instance я не понял что означает, в плане с константным буфером.
s3dworld
> UPLOAD же не обязательно должна быть память на CPU, она же может быть и на GPU,
> только с доступом для CPU.
Нет, видеопамять с доступом для ЦП - это GPU_UPLOAD, а не UPLOAD. UPLOAD всегда находится в оперативной памяти.
prowkan
> Нет, видеопамять с доступом для ЦП - это GPU_UPLOAD, а не UPLOAD. UPLOAD всегда находится в оперативной памяти.
Интересно вот что. У меня в d3d12.h для перечисления D3D12_HEAP_TYPE есть только следующие значения:
- D3D12_HEAP_TYPE_DEFAULT
- D3D12_HEAP_TYPE_UPLOAD
- D3D12_HEAP_TYPE_READBACK
- D3D12_HEAP_TYPE_CUSTOM
Значения D3D12_HEAP_TYPE_GPU_UPLOAD у меня нет. Видимо это нужно что-то другое качать (у меня заголовочные файлы от Windows SDK с Visual Studio 2019). Это что же получается, в те времена нельзя было из GPU забрать результат работы? Честно говоря очень странно.
s3dworld
> Это что же получается, в те времена нельзя было из GPU забрать результат
> работы?
Почему? D3D12_HEAP_TYPE_READBACK же есть, он предназначен для этого.
А GPU_UPLOAD есть в новых Agility SDK.
prowkan
> Почему? D3D12_HEAP_TYPE_READBACK же есть, он предназначен для этого.
> А GPU_UPLOAD есть в новых Agility SDK.
А зачем тогда новое перечисление GPU_UPLOAD если это всё можно было сделать через READBACK?
s3dworld
Затем, что READBACK - это область оперативной памяти, оптимизированная для чтения со стороны ЦП, и поэтому используемая для получения данных с ГП.
GPU_UPLOAD - это область видеопамяти, в которую может писать ЦП, и обычно она используется для передачи данных в ГП.
prowkan
Вот я и про то, что сразу так не сделали. В Vulkan же сразу всё это было распланировано. Там, правда это на флагах.
s3dworld
> GPU_UPLOAD
Если видеокарты дескретной нет, эта GPU_UPLOAD будет аналогична READBACK или вообще работать не будет?
s3dworld
Да ёп, каким боком тут вообще READBACK? Куча GPU_UPLOAD оптизирована для передачи данных от центрального процессора к графическому! (Вы не заметили схожести названия кучи GPU_UPLOAD с кучей UPLOAD?) Единственное отличие GPU_UPLOAD от UPLOAD в том, что UPLOAD - это оперативная память, GPU_UPLOAD - память видеокарты. Насчёт
> вообще работать не будет
не знаю, скорее, вероятно, эта куча просто не будет поддерживаться (примерно как на видеокартах без Resizable BAR).
prowkan
Да по названиям понятно кто что делает. Вопрос в том, как что куда попадёт при указании DEFAULT и GPU_UPLOAD, если нет встроенной видеокарты.
s3dworld
DEFAULT на интегрированных видеокартах попадает в оперативную память, на дискретных - в локальную память видеокарты.
На счёт GPU_UPLOAD повторюсь, что точно не знаю.
Как определить какой из адаптеров интегрированный, а какой дискретный? В Vullan есть функция VkPhysicalDeviceProperties, где по полю deviceType можно определить VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU, VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU и другое. В Direct3D 12 я вижу DXGI_ADAPTER_DESC, DXGI_ADAPTER_DESC1, DXGI_ADAPTER_DESC2 и DXGI_ADAPTER_DESC3. Но там я ничего подобного не нашёл. Что, только через EnumAdapterByGpuPreference?
s3dworld
Самое близкое это D3D12_FEATURE_DATA_ARCHITECTURE::UMA
А что происходит у Nvidia с поддержкой фич D3D12?
Обнаружил, что на RTX4060Ti с последним драйвером среди фич Render passes - No, Enhanced barriers - No. Притом что обе фичи появились в DirectX уже несколько лет как.
Планировалось их использовать для упрощения общего слоя между Vulkan и DX - а их то и нет.
Да и максимальная Shader model - 6.6, притом что 6.7 вышла в 2022
CatsCanFly
А кто придумывает фичи дх12?