301{
303 auto& resources = buffer_wrapper->get_buffer_resources();
304 auto dirty_ranges = buffer_wrapper->get_and_clear_dirty_ranges();
305 if (!dirty_ranges.empty()) {
306 for (auto [offset, size] : dirty_ranges) {
307 vk::MappedMemoryRange
range;
308 range.memory = resources.memory;
309 range.offset = offset;
311 if (
auto result =
m_context.
get_device().flushMappedMemoryRanges(1, &range); result != vk::Result::eSuccess) {
313 "Failed to flush mapped memory range: {}", vk::to_string(result));
314 }
315 }
317 "Flushed {} dirty ranges for buffer {:p}", dirty_ranges.size(),
318 (void*)buffer_wrapper->get_buffer());
319 }
320
321 auto invalid_ranges = buffer_wrapper->get_and_clear_invalid_ranges();
322 if (!invalid_ranges.empty()) {
323 for (auto [offset, size] : invalid_ranges) {
324 vk::MappedMemoryRange
range;
325 range.memory = buffer_wrapper->get_buffer_resources().memory;
326 range.offset = offset;
328 if (
auto result =
m_context.
get_device().invalidateMappedMemoryRanges(1, &range); result != vk::Result::eSuccess) {
330 "Failed to invalidate mapped memory range: {}", vk::to_string(result));
331 }
332 }
334 "Invalidated {} ranges for buffer {:p}", invalid_ranges.size(),
335 (void*)buffer_wrapper->get_buffer());
336 }
337 }
338}
#define MF_ERROR(comp, ctx,...)
#define MF_DEBUG(comp, ctx,...)
std::vector< std::shared_ptr< Buffers::VKBuffer > > m_managed_buffers
vk::Device get_device() const
Get logical device.
@ GraphicsBackend
Graphics/visual rendering backend (Vulkan, OpenGL)
@ Core
Core engine, backend, subsystems.
std::vector< double > range(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size)
Value range (max - min) per window.