diff options
| author | 2020-11-19 07:54:00 -0500 | |
|---|---|---|
| committer | 2020-11-19 07:54:03 -0500 | |
| commit | 412044960a39180bc9990f6b35e1872c6a69591b (patch) | |
| tree | 2423f639b1713380aab4196d0abb682789416c49 /src | |
| parent | Merge pull request #4936 from lioncash/page (diff) | |
| download | yuzu-412044960a39180bc9990f6b35e1872c6a69591b.tar.gz yuzu-412044960a39180bc9990f6b35e1872c6a69591b.tar.xz yuzu-412044960a39180bc9990f6b35e1872c6a69591b.zip | |
virtual_buffer: Do nothing on resize() calls with same sizes
Prevents us from churning memory by freeing and reallocating a memory
block that would have already been adequate as is.
Diffstat (limited to 'src')
| -rw-r--r-- | src/common/virtual_buffer.h | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/common/virtual_buffer.h b/src/common/virtual_buffer.h index 078e61c77..91d430036 100644 --- a/src/common/virtual_buffer.h +++ b/src/common/virtual_buffer.h | |||
| @@ -43,9 +43,14 @@ public: | |||
| 43 | } | 43 | } |
| 44 | 44 | ||
| 45 | void resize(std::size_t count) { | 45 | void resize(std::size_t count) { |
| 46 | const auto new_size = count * sizeof(T); | ||
| 47 | if (new_size == alloc_size) { | ||
| 48 | return; | ||
| 49 | } | ||
| 50 | |||
| 46 | FreeMemoryPages(base_ptr, alloc_size); | 51 | FreeMemoryPages(base_ptr, alloc_size); |
| 47 | 52 | ||
| 48 | alloc_size = count * sizeof(T); | 53 | alloc_size = new_size; |
| 49 | base_ptr = reinterpret_cast<T*>(AllocateMemoryPages(alloc_size)); | 54 | base_ptr = reinterpret_cast<T*>(AllocateMemoryPages(alloc_size)); |
| 50 | } | 55 | } |
| 51 | 56 | ||