vkAcquireNextImageKHR семантика?Что означает тайм-аут? - PullRequest
0 голосов
/ 05 октября 2018

Я запутался в семантике vkAcquireNextImageKHR.В частности, при каких обстоятельствах функция может возвращать VK_TIMEOUT?то есть, что может помешать ему не получить изображение сразу?Что может ждать, пока это произойдет?

Кажется, что изображение можно получить, даже если механизм представления еще не завершил чтение с изображения, и необходимо использовать семафор или забор для синхронизации использованиявсе равно приобрел образ.Чего мне не хватает?

Ответы [ 2 ]

0 голосов
/ 06 октября 2018

Ответ Никола Боласа верный, но поскольку в ответах на него запрашивались подробности о том, где это используется в реальных реализациях, я добавлю еще один ответ здесь.

На Android vkQueuePresentKHR отправляет изображение вКомпозитор (SurfaceFlinger), который его отображает.Композитор повторно отображает это изображение при каждом обновлении дисплея, пока не получит новое изображение для отображения для этого окна.Пока он не получит следующее изображение, он не будет знать, сколько раз ему понадобится снова прочитать буфер в будущем, и не сможет создать семафор, который будет сигнализировать о завершении последнего чтения.(Гипотетически, вы могли бы создать систему, которая могла бы сделать это, но это не то, как механизмы синхронизации ядра Linux Android использует для этой работы.) Поэтому, пока вы не представите образ N + 1, композитор не сможет выпуститьimage N обратно в ваше приложение для его приобретения, поскольку оно не может дать вам семафор, чтобы пойти вместе с ним.

Это немного сложнее, так как, даже если вы представите кадр N + 1,Композитор не знает, сколько времени пройдет до того, как семафор рендеринга подаст сигнал, поэтому он все еще не знает сразу, сколько еще времени потребуется, чтобы иметь возможность прочитать изображение для кадра N.

Это расширяетк цепочкам обмена с более чем двумя буферами.

Я не так знаком с другими системами, но я полагаю, что у других есть подобные ограничения, которые не позволяют им получать изображения произвольно далеко перед их представлением.Определенно возможно создать механизм представления, который позволил бы это, но Vulkan нужно было работать с существующими системами и существующими механизмами представления, поэтому пришлось мириться с ограничениями, которые накладывают эти существующие системы.Участники Khronos не могут менять композитор Windows, а другие, такие как X11, Wayland и Android, трудно / медленно менять, поскольку это может повлиять на все существующие приложения, платформы и т. Д.

0 голосов
/ 05 октября 2018

Все это определяется реализацией.

Тем не менее, стандарт дает один ясный случай:

Изображение в конечном итоге будет получено, если количество изображений, которое есть в приложенииполученный в настоящее время (но еще не представленный) размер, меньший или равный разнице между количеством изображений в цепочке обмена и значением VkSurfaceCapabilitiesKHR::minImageCount.Если количество полученных в данный момент изображений больше этого, vkAcquireNextImageKHR не вызывается;если это так, timeout не должно быть UINT64_MAX.

Таким образом, если вы приобрели все доступные изображения в цепочке обмена и не представили их, вы можете получить тайм-ауты.

Могут быть и другие обстоятельства, но, опять же, они определяются реализацией.Совершенно правильная реализация vkAcquireNextImageKHR может сигнализировать о семафоре / ограждении, которое вы предоставляете, до того, как он вернет успешное получение, таким образом вызывая любую задержку в самом вызове vkAcquireNextImageKHR.Вы не можете это контролировать.

...