Changeset bb76950 in opengl-game for vulkan-game.cpp


Ignore:
Timestamp:
Jun 9, 2021, 6:41:48 PM (4 years ago)
Author:
Dmitry Portnoy <dportnoy@…>
Branches:
feature/imgui-sdl
Children:
b7fc3c2
Parents:
6bac215
git-author:
Dmitry Portnoy <dportnoy@…> (06/09/21 18:41:20)
git-committer:
Dmitry Portnoy <dportnoy@…> (06/09/21 18:41:48)
Message:

Change VulkanGame::resizeBufferSet() to take a buffer size instead of an entire
VulkanBuffer object, and to not update descriptor sets, which obviates the need
to pass in a GraphicsPipeline_Vulkan object. Descriptor set updates must
now be handled separetly.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • vulkan-game.cpp

    r6bac215 rbb76950  
    10891089   }
    10901090
     1091   // TODO: Replace updateBufferSet to one call to copyDataToMemory, using VulkanBuffer to provide the data source
     1092   // TODO: Figure out a way to make updateDescriptorInfo easier to use, maybe store the binding index in the buffer set
    10911093   // TODO: Probably move the resizing to the VulkanBuffer class
     1094
    10921095   if (objects_modelPipeline.resized) {
    1093       resizeBufferSet(storageBuffers_modelPipeline, objects_modelPipeline, modelPipeline, resourceCommandPool,
    1094                       graphicsQueue);
     1096      resizeBufferSet(storageBuffers_modelPipeline, objects_modelPipeline.capacity * sizeof(SSBO_ModelObject),
     1097                      resourceCommandPool, graphicsQueue, true);
    10951098
    10961099      objects_modelPipeline.resize();
     1100
     1101      modelPipeline.updateDescriptorInfo(1, &storageBuffers_modelPipeline.infoSet, swapChainImages.size());
    10971102   }
    10981103
     
    11061111   // TODO: Probably move the resizing to the VulkanBuffer class
    11071112   if (objects_shipPipeline.resized) {
    1108       resizeBufferSet(storageBuffers_shipPipeline, objects_shipPipeline, shipPipeline, resourceCommandPool,
    1109                       graphicsQueue);
     1113      resizeBufferSet(storageBuffers_shipPipeline, objects_shipPipeline.capacity * sizeof(SSBO_ModelObject),
     1114                      resourceCommandPool, graphicsQueue, true);
    11101115
    11111116      objects_shipPipeline.resize();
     1117
     1118      shipPipeline.updateDescriptorInfo(1, &storageBuffers_shipPipeline.infoSet, swapChainImages.size());
    11121119   }
    11131120
     
    11211128   // TODO: Probably move the resizing to the VulkanBuffer class
    11221129   if (objects_asteroidPipeline.resized) {
    1123       resizeBufferSet(storageBuffers_asteroidPipeline, objects_asteroidPipeline, asteroidPipeline,
    1124                       resourceCommandPool, graphicsQueue);
     1130      resizeBufferSet(storageBuffers_asteroidPipeline, objects_asteroidPipeline.capacity * sizeof(SSBO_Asteroid),
     1131                      resourceCommandPool, graphicsQueue, true);
    11251132
    11261133      objects_asteroidPipeline.resize();
     1134
     1135      asteroidPipeline.updateDescriptorInfo(1, &storageBuffers_asteroidPipeline.infoSet, swapChainImages.size());
    11271136   }
    11281137
     
    11361145   // TODO: Probably move the resizing to the VulkanBuffer class
    11371146   if (objects_laserPipeline.resized) {
    1138       resizeBufferSet(storageBuffers_laserPipeline, objects_laserPipeline, laserPipeline, resourceCommandPool,
    1139                       graphicsQueue);
     1147      resizeBufferSet(storageBuffers_laserPipeline, objects_laserPipeline.capacity * sizeof(SSBO_Laser),
     1148                      resourceCommandPool, graphicsQueue, true);
    11401149
    11411150      objects_laserPipeline.resize();
     1151
     1152      laserPipeline.updateDescriptorInfo(1, &storageBuffers_laserPipeline.infoSet, swapChainImages.size());
    11421153   }
    11431154
     
    11511162   // TODO: Probably move the resizing to the VulkanBuffer class
    11521163   if (objects_explosionPipeline.resized) {
    1153       resizeBufferSet(storageBuffers_explosionPipeline, objects_explosionPipeline, explosionPipeline,
    1154                      resourceCommandPool, graphicsQueue);
     1164      resizeBufferSet(storageBuffers_explosionPipeline, objects_explosionPipeline.capacity * sizeof(SSBO_Explosion),
     1165                      resourceCommandPool, graphicsQueue, true);
    11551166
    11561167      objects_explosionPipeline.resize();
     1168
     1169      explosionPipeline.updateDescriptorInfo(1, &storageBuffers_explosionPipeline.infoSet, swapChainImages.size());
    11571170   }
    11581171
     
    19621975      set.infoSet[i].offset = 0; // This is the offset from the start of the buffer, so always 0 for now
    19631976      set.infoSet[i].range = bufferSize; // Size of the update starting from offset, or VK_WHOLE_SIZE
     1977   }
     1978}
     1979
     1980void VulkanGame::resizeBufferSet(BufferSet& set, VkDeviceSize newSize, VkCommandPool commandPool,
     1981                                 VkQueue graphicsQueue, bool copyData) {
     1982   for (size_t i = 0; i < set.buffers.size(); i++) {
     1983      VkBuffer newBuffer;
     1984      VkDeviceMemory newMemory;
     1985
     1986      VulkanUtils::createBuffer(device, physicalDevice, newSize, set.usages, set.properties, newBuffer, newMemory);
     1987
     1988      if (copyData) {
     1989         VulkanUtils::copyBuffer(device, commandPool, set.buffers[i], newBuffer, 0, 0, set.infoSet[i].range,
     1990                                 graphicsQueue);
     1991      }
     1992
     1993      vkDestroyBuffer(device, set.buffers[i], nullptr);
     1994      vkFreeMemory(device, set.memory[i], nullptr);
     1995
     1996      set.buffers[i] = newBuffer;
     1997      set.memory[i] = newMemory;
     1998
     1999      set.infoSet[i].buffer = set.buffers[i];
     2000      set.infoSet[i].offset = 0; // This is the offset from the start of the buffer, so always 0 for now
     2001      set.infoSet[i].range = newSize; // Size of the update starting from offset, or VK_WHOLE_SIZE
    19642002   }
    19652003}
Note: See TracChangeset for help on using the changeset viewer.