Memory Management Principles¶
The principle in Kompute on memory management is summarised as follows:
Memory management by Kompute is optional and only in place if resource is created by Kompute
Memory management ownership architecture are acyclic and with a single top manager
Operations do not manage any GPU memory or resources
Top level manager is main owner of GPU resources and removes all resources when destroyed
Manager holds weak pointers to ensure that if object created outside is destroyed it’s released
Once a resource is destroyed it cannot be recreated
Resources can only be rebuilt if they haven’t been destroyed
Kompute is responsible for managing both the CPU and GPU memory allocations and resources that it creates, and is important that they are able to explicitly define when these objects are released or destroyed. Similarly, it’s important that the memory resources created by the application are released safely.
Kompute is built with the BYOV principle in mind (Bring your own VulkanSDK). This means that even though the top level resources are managing the memory to its owned resources, they themselves may not have full ownership of the GPU / Vulkan SDK components - this is in the case that you may want to use Kompute with an existing Vulkan SDK enabled application, and may want to initialise Kompute components with existing Vulkan SDK resources.
The memory ownership is hierarchically outlined in the component architecture - in this diagram, the arrows provide an intuition on the memory management ownership relationships. It’s worth mentioning that the memory relationship may be different to the way components interact with each other - for this, you can see the high level component overview. More specifically: * The purple arrows denote GPU memory management
Optional Memory Management¶
As outlined above, resource memory is only managed by Kompute if the resources are created by Kompute. Each of the Kompute components can also be initialised with externally managed resources. The kp::Manager
for example can be initialized with an external vk::Device. The first principle ensures that all memory ownership is explicitly defined when managing and creating Kompute resources.