#ifndef GPU_COMMAND_BUFFER_CLIENT_IMPLEMENTATION_BASE_H_
#define GPU_COMMAND_BUFFER_CLIENT_IMPLEMENTATION_BASE_H_
#include <stddef.h>
#include <stdint.h>
#include <memory>
#include <string>
#include <utility>
#include <vector>
#include "base/functional/callback_forward.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "base/trace_event/memory_dump_provider.h"
#include "gpu/command_buffer/client/client_transfer_cache.h"
#include "gpu/command_buffer/client/context_support.h"
#include "gpu/command_buffer/client/gles2_impl_export.h"
#include "gpu/command_buffer/client/gpu_control_client.h"
#include "gpu/command_buffer/client/query_tracker.h"
#include "gpu/command_buffer/client/transfer_buffer.h"
#include "gpu/command_buffer/common/capabilities.h"
#include "gpu/command_buffer/common/context_result.h"
namespace gpu {
namespace gles2 {
class QueryTracker;
}
class CommandBufferHelper;
class GpuControl;
class MappedMemoryManager;
struct SharedMemoryLimits;
class GLES2_IMPL_EXPORT ImplementationBase
: public base::trace_event::MemoryDumpProvider,
public ContextSupport,
public GpuControlClient {
public:
static const uint32_t kMaxSizeOfSimpleResult =
16 * sizeof(uint32_t);
static const uint32_t kStartingOffset = kMaxSizeOfSimpleResult;
static const unsigned int kAlignment = 16;
static const uint32_t kResultBucketId = 1;
ImplementationBase(CommandBufferHelper* helper,
TransferBufferInterface* transfer_buffer,
GpuControl* gpu_control);
ImplementationBase(const ImplementationBase&) = delete;
ImplementationBase& operator=(const ImplementationBase&) = delete;
~ImplementationBase() override;
void FreeUnusedSharedMemory();
void FreeEverything();
void SetLostContextCallback(base::OnceClosure callback);
const Capabilities& capabilities() const { return capabilities_; }
void FlushPendingWork() override;
void SignalSyncToken(const gpu::SyncToken& sync_token,
base::OnceClosure callback) override;
bool IsSyncTokenSignaled(const gpu::SyncToken& sync_token) override;
void SignalQuery(uint32_t query, base::OnceClosure callback) override;
void GetGpuFence(uint32_t gpu_fence_id,
base::OnceCallback<void(std::unique_ptr<gfx::GpuFence>)>
callback) override;
bool OnMemoryDump(const base::trace_event::MemoryDumpArgs& args,
base::trace_event::ProcessMemoryDump* pmd) override;
void GenSyncToken(GLbyte* sync_token);
void GenUnverifiedSyncToken(GLbyte* sync_token);
void VerifySyncTokens(GLbyte** sync_tokens, GLsizei count);
void WaitSyncToken(const GLbyte* sync_token);
protected:
gpu::ContextResult Initialize(const SharedMemoryLimits& limits);
bool WaitForCmd();
template <typename T>
ScopedResultPtr<T> GetResultAs() {
return ScopedResultPtr<T>(transfer_buffer_);
}
int32_t GetResultShmId();
bool GetBucketContents(uint32_t bucket_id, std::vector<int8_t>* data);
void SetBucketContents(uint32_t bucket_id, const void* data, uint32_t size);
void SetBucketAsCString(uint32_t bucket_id, const char* str);
bool GetBucketAsString(uint32_t bucket_id, std::string* str);
void SetBucketAsString(uint32_t bucket_id, const std::string& str);
bool GetVerifiedSyncTokenForIPC(const SyncToken& sync_token,
SyncToken* verified_sync_token);
void RunIfContextNotLost(base::OnceClosure callback);
raw_ptr<TransferBufferInterface> transfer_buffer_;
std::unique_ptr<MappedMemoryManager> mapped_memory_;
std::unique_ptr<gles2::QueryTracker> query_tracker_;
base::OnceClosure lost_context_callback_;
bool lost_context_callback_run_ = false;
const raw_ptr<GpuControl> gpu_control_;
Capabilities capabilities_;
private:
virtual void IssueShallowFlush() = 0;
virtual void SetGLError(GLenum error,
const char* function_name,
const char* msg) = 0;
raw_ptr<CommandBufferHelper> helper_;
base::WeakPtrFactory<ImplementationBase> weak_ptr_factory_{this};
};
}
#endif