Подумайте, что вы делаете на секунду. Как вы думаете, почему необходима синхронизация между двумя наборами команд? Потому что второй набор команд должен сочетаться с данными в первом наборе, верно? И, следовательно, он должен выполнить чтение / изменение / запись (RMW), которые должны быть в состоянии прочитать данные, записанные предыдущим набором команд. Считываемые данные должны быть записаны, и для этого обычно требуется синхронизация.
Но подумайте немного больше о том, что это значит. Смешивание должно читать из кадрового буфера, чтобы сделать свою работу. Но ... так же тест глубины, верно? Он должен прочитать значение глубины существующего образца, сравнить его с входящим фрагментом, а затем отбросить фрагмент или нет на основе теста глубины. Таким образом, в основном каждый вызов отрисовки , который использует тест глубины, содержит чтение / изменение / запись кадрового буфера.
И все же ... ваши тесты глубины работают. Они не только работают между вызовами отрисовки без явной синхронизации, они также работают в вызове отрисовки. Если два треугольника в вызове отрисовки перекрываются, у вас нет проблем с просмотром нижнего через верхний, верно? Вам не нужно выполнять межтреугольную синхронизацию, чтобы убедиться, что записи предыдущих треугольников завершены до чтения.
Так или иначе, RMW теста глубины работает без какой-либо явной синхронизации. Итак ... почему вы думаете, что это не соответствует RMW этапа смешивания?
Спецификация Vulkan гласит, что команды и этапы внутри команд будут выполняться в основном неупорядоченным образом, с несколькими исключениями. Наиболее очевидным является наличие явных барьеров / зависимостей выполнения. Но это также говорит о том, что этапы тестирования и смешивания с фиксированной функцией для каждого образца всегда будут выполняться (как если бы) в порядке представления (в подпроходе). Мало того, это требует, чтобы треугольники, сгенерированные внутри команды, также выполняли эти этапы (как будто) в определенном, четко определенном порядке.
Вот почему ваш тест глубины ненужна синхронизация;Вулкан требует, чтобы это было обработано. Вот почему вашему смешиванию не потребуется синхронизация (в подпроходе).
Таким образом, у вас есть много вариантов (от самого быстрого до самого медленного):
- Визуализируйте ваш пользовательский интерфейс в том же подпроходе, что и не-пользовательский интерфейс. Просто измените конвейеры соответствующим образом.
- Визуализируйте ваш пользовательский интерфейс в подпроцессе с явной зависимостью от образов кадрового буфера не-пользовательского интерфейса. Хотя это технически медленнее, но, вероятно, не будет намного медленнее, если вообще будет. Кроме того, это полезно для отложенного рендеринга, поскольку ваш пользовательский интерфейс должен произойти после вашего прохода освещения, который, несомненно, будет его собственным подпроходом.
- Визуализация вашего пользовательского интерфейса выполняется на другом проходе рендеринга. Это действительно понадобится только в тех случаях, когда вам нужно выполнить какую-то полноэкранную работу (SSAO), которая заставит ваш проход рендеринга без интерфейса пользователя в любом случае прерваться.