diff options
| author | 2019-05-07 10:55:44 -0400 | |
|---|---|---|
| committer | 2019-06-20 21:36:12 -0300 | |
| commit | 3b26206dbdd36e53152f97726da372da2e1a9a84 (patch) | |
| tree | ca7f3fbaf3fc3077835d493ea0ac34a67899032b /src | |
| parent | Deglobalize Memory Manager on texture cahe and Implement Invalidation and Flu... (diff) | |
| download | yuzu-3b26206dbdd36e53152f97726da372da2e1a9a84.tar.gz yuzu-3b26206dbdd36e53152f97726da372da2e1a9a84.tar.xz yuzu-3b26206dbdd36e53152f97726da372da2e1a9a84.zip | |
Add OGLTextureView
Diffstat (limited to 'src')
| -rw-r--r-- | src/video_core/renderer_opengl/gl_resource_manager.cpp | 18 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_resource_manager.h | 25 |
2 files changed, 43 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/gl_resource_manager.cpp b/src/video_core/renderer_opengl/gl_resource_manager.cpp index bfe666a73..9f81c15cb 100644 --- a/src/video_core/renderer_opengl/gl_resource_manager.cpp +++ b/src/video_core/renderer_opengl/gl_resource_manager.cpp | |||
| @@ -33,6 +33,24 @@ void OGLTexture::Release() { | |||
| 33 | handle = 0; | 33 | handle = 0; |
| 34 | } | 34 | } |
| 35 | 35 | ||
| 36 | void OGLTextureView::Create() { | ||
| 37 | if (handle != 0) | ||
| 38 | return; | ||
| 39 | |||
| 40 | MICROPROFILE_SCOPE(OpenGL_ResourceCreation); | ||
| 41 | glGenTextures(1, &handle); | ||
| 42 | } | ||
| 43 | |||
| 44 | void OGLTextureView::Release() { | ||
| 45 | if (handle == 0) | ||
| 46 | return; | ||
| 47 | |||
| 48 | MICROPROFILE_SCOPE(OpenGL_ResourceDeletion); | ||
| 49 | glDeleteTextures(1, &handle); | ||
| 50 | OpenGLState::GetCurState().UnbindTexture(handle).Apply(); | ||
| 51 | handle = 0; | ||
| 52 | } | ||
| 53 | |||
| 36 | void OGLSampler::Create() { | 54 | void OGLSampler::Create() { |
| 37 | if (handle != 0) | 55 | if (handle != 0) |
| 38 | return; | 56 | return; |
diff --git a/src/video_core/renderer_opengl/gl_resource_manager.h b/src/video_core/renderer_opengl/gl_resource_manager.h index fbb93ee49..310ee2bf3 100644 --- a/src/video_core/renderer_opengl/gl_resource_manager.h +++ b/src/video_core/renderer_opengl/gl_resource_manager.h | |||
| @@ -36,6 +36,31 @@ public: | |||
| 36 | GLuint handle = 0; | 36 | GLuint handle = 0; |
| 37 | }; | 37 | }; |
| 38 | 38 | ||
| 39 | class OGLTextureView : private NonCopyable { | ||
| 40 | public: | ||
| 41 | OGLTextureView() = default; | ||
| 42 | |||
| 43 | OGLTextureView(OGLTextureView&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||
| 44 | |||
| 45 | ~OGLTextureView() { | ||
| 46 | Release(); | ||
| 47 | } | ||
| 48 | |||
| 49 | OGLTextureView& operator=(OGLTextureView&& o) noexcept { | ||
| 50 | Release(); | ||
| 51 | handle = std::exchange(o.handle, 0); | ||
| 52 | return *this; | ||
| 53 | } | ||
| 54 | |||
| 55 | /// Creates a new internal OpenGL resource and stores the handle | ||
| 56 | void Create(); | ||
| 57 | |||
| 58 | /// Deletes the internal OpenGL resource | ||
| 59 | void Release(); | ||
| 60 | |||
| 61 | GLuint handle = 0; | ||
| 62 | }; | ||
| 63 | |||
| 39 | class OGLSampler : private NonCopyable { | 64 | class OGLSampler : private NonCopyable { |
| 40 | public: | 65 | public: |
| 41 | OGLSampler() = default; | 66 | OGLSampler() = default; |