summaryrefslogtreecommitdiff
path: root/src/common/alignment.h
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2020-07-11 14:54:34 -0400
committerGitHub <noreply@github.com>2020-07-11 14:54:34 -0400
commit7a051c497386e443d5d2a5f3e3493d734d963687 (patch)
treecbd176cf7b3dd85cde0b8fb65f8df38727d1c9a5 /src/common/alignment.h
parenta0ee597b19482ce4bfc6231ad54666e2a7f894b5 (diff)
parenta4306b9e5662fca74f65f0b657e7002fda7f1829 (diff)
Merge pull request #4300 from FearlessTobi/port-5441
Port citra-emu/citra#5441: "Common: remove a mod from AlignUp"
Diffstat (limited to 'src/common/alignment.h')
-rw-r--r--src/common/alignment.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/common/alignment.h b/src/common/alignment.h
index f8c49e079..516bb26c1 100644
--- a/src/common/alignment.h
+++ b/src/common/alignment.h
@@ -11,7 +11,9 @@ namespace Common {
template <typename T>
constexpr T AlignUp(T value, std::size_t size) {
static_assert(std::is_unsigned_v<T>, "T must be an unsigned value.");
- return static_cast<T>(value + (size - value % size) % size);
+ auto mod{value % size};
+ value -= mod;
+ return static_cast<T>(mod == T{0} ? value : value + size);
}
template <typename T>