// // Copyright 2016 The ANGLE Project Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // // QueryVk.h: // Defines the class interface for QueryVk, implementing QueryImpl. // #ifndef LIBANGLE_RENDERER_VULKAN_QUERYVK_H_ #define LIBANGLE_RENDERER_VULKAN_QUERYVK_H_ #include "libANGLE/renderer/QueryImpl.h" #include "libANGLE/renderer/vulkan/vk_helpers.h" namespace rx { class TransformFeedbackVk; class QueryVk : public QueryImpl { public: QueryVk(gl::QueryType type); ~QueryVk() override; void onDestroy(const gl::Context *context) override; angle::Result begin(const gl::Context *context) override; angle::Result end(const gl::Context *context) override; angle::Result queryCounter(const gl::Context *context) override; angle::Result getResult(const gl::Context *context, GLint *params) override; angle::Result getResult(const gl::Context *context, GLuint *params) override; angle::Result getResult(const gl::Context *context, GLint64 *params) override; angle::Result getResult(const gl::Context *context, GLuint64 *params) override; angle::Result isResultAvailable(const gl::Context *context, bool *available) override; void onTransformFeedbackEnd(GLsizeiptr primitivesDrawn); bool hasQueryBegun() const { return mQueryHelper.isReferenced(); } vk::QueryHelper *getQueryHelper() { ASSERT(mQueryHelper.isReferenced()); return &mQueryHelper.get(); } // Called by ContextVk on render pass start / end for render pass queries. These will // stash and create new queries as needed. angle::Result onRenderPassStart(ContextVk *contextVk); void onRenderPassEnd(ContextVk *contextVk); private: angle::Result getResult(const gl::Context *context, bool wait); bool isCurrentlyInUse(vk::Renderer *renderer) const; angle::Result finishRunningCommands(ContextVk *contextVk); void stashQueryHelper(); uint32_t getQueryResultCount(ContextVk *contextVk) const; angle::Result accumulateStashedQueryResult(ContextVk *contextVk, vk::QueryResult *result); // Manage query allocations angle::Result allocateQuery(ContextVk *contextVk); void assignSharedQuery(QueryVk *shareQuery); void releaseQueries(ContextVk *contextVk); void releaseStashedQueries(ContextVk *contextVk); // Prepare for begin by handling peculiarities such as the two transform feedback queries // sharing QueryHelpers. angle::Result setupBegin(ContextVk *contextVk); // Used for all queries, except TimeElapsed (begin) or those that are emulated. For transform // feedback queries, these can be shared if the two queries are simultaneously active. vk::Shared mQueryHelper; // Used for queries that may end up with multiple outstanding query helper objects as they end // and begin again with render passes. std::vector> mStashedQueryHelpers; // An additional query used for TimeElapsed (begin), as it is implemented using Timestamp. vk::QueryHelper mQueryHelperTimeElapsedBegin; // Used with TransformFeedbackPrimitivesWritten when transform feedback is emulated. size_t mTransformFeedbackPrimitivesDrawn; uint64_t mCachedResult; bool mCachedResultValid; }; } // namespace rx #endif // LIBANGLE_RENDERER_VULKAN_QUERYVK_H_