diff options
author | ReinUsesLisp <reinuseslisp@airmail.cc> | 2018-10-02 19:47:26 +0200 |
---|---|---|
committer | ReinUsesLisp <reinuseslisp@airmail.cc> | 2018-10-04 05:03:44 +0200 |
commit | 3e2380327a99196ac2bb18668f6f53c4248bcca1 (patch) | |
tree | f0e330bb43f9611c5319d7d51c27c5d2fb2ebc5b /src/video_core/renderer_opengl/gl_buffer_cache.h | |
parent | Merge pull request #1422 from ReinUsesLisp/fixup-points (diff) | |
download | yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.tar yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.tar.gz yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.tar.bz2 yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.tar.lz yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.tar.xz yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.tar.zst yuzu-3e2380327a99196ac2bb18668f6f53c4248bcca1.zip |
Diffstat (limited to 'src/video_core/renderer_opengl/gl_buffer_cache.h')
-rw-r--r-- | src/video_core/renderer_opengl/gl_buffer_cache.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/gl_buffer_cache.h b/src/video_core/renderer_opengl/gl_buffer_cache.h index 6c18461f4..965976334 100644 --- a/src/video_core/renderer_opengl/gl_buffer_cache.h +++ b/src/video_core/renderer_opengl/gl_buffer_cache.h @@ -6,6 +6,7 @@ #include <cstddef> #include <memory> +#include <tuple> #include "common/common_types.h" #include "video_core/rasterizer_cache.h" @@ -33,11 +34,17 @@ class OGLBufferCache final : public RasterizerCache<std::shared_ptr<CachedBuffer public: explicit OGLBufferCache(std::size_t size); + /// Uploads data from a guest GPU address. Returns host's buffer offset where it's been + /// allocated. GLintptr UploadMemory(Tegra::GPUVAddr gpu_addr, std::size_t size, std::size_t alignment = 4, bool cache = true); + /// Uploads from a host memory. Returns host's buffer offset where it's been allocated. GLintptr UploadHostMemory(const void* raw_pointer, std::size_t size, std::size_t alignment = 4); + /// Reserves memory to be used by host's CPU. Returns mapped address and offset. + std::tuple<u8*, GLintptr> ReserveMemory(std::size_t size, std::size_t alignment = 4); + void Map(std::size_t max_size); void Unmap(); |