mirror of
https://github.com/hrydgard/ppsspp.git
synced 2025-04-02 11:01:50 -04:00
Typo, validation fix More fixes Fix mipgen logging Disable the logging profiler by default again Important to use the macro
47 lines
1.2 KiB
C++
47 lines
1.2 KiB
C++
#pragma once
|
|
|
|
#include <vector>
|
|
#include <string>
|
|
|
|
#include "Common/Log.h"
|
|
#include "VulkanLoader.h"
|
|
|
|
// Simple scoped based profiler, initially meant for instant one-time tasks like texture uploads
|
|
// etc. Supports recursive scopes. Scopes are not yet tracked separately for each command buffer.
|
|
// For the pass profiler in VulkanQueueRunner, a purpose-built separate profiler that can take only
|
|
// one measurement between each pass makes more sense.
|
|
//
|
|
// Put the whole thing in a FrameData to allow for overlap.
|
|
|
|
struct ProfilerScope {
|
|
std::string name;
|
|
size_t startQueryId;
|
|
size_t endQueryId;
|
|
int level;
|
|
};
|
|
|
|
class VulkanContext;
|
|
|
|
|
|
class VulkanProfiler {
|
|
public:
|
|
void Init(VulkanContext *vulkan);
|
|
void Shutdown();
|
|
|
|
void BeginFrame(VulkanContext *vulkan, VkCommandBuffer firstCommandBuffer);
|
|
|
|
void Begin(VkCommandBuffer cmdBuf, VkPipelineStageFlagBits stage, std::string scopeName);
|
|
void End(VkCommandBuffer cmdBuf, VkPipelineStageFlagBits stage);
|
|
|
|
private:
|
|
VulkanContext *vulkan_;
|
|
|
|
VkQueryPool queryPool_ = VK_NULL_HANDLE;
|
|
std::vector<ProfilerScope> scopes_;
|
|
int numQueries_ = 0;
|
|
bool firstFrame_ = true;
|
|
|
|
std::vector<size_t> scopeStack_;
|
|
|
|
const int MAX_QUERY_COUNT = 1024;
|
|
};
|