mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-19 04:58:27 +00:00
d9873e30bc
* shader_recompiler: Add LDEXP * shader_recompiler: Add most image integer atomic ops * shader_recompiler: Implement shared memory load/store * shader_recompiler: More image atomics * externals: Update sirit * clang format * cmake: Add missing files * shader_recompiler: Fix some atomic bugs * shader_recompiler: Vs outputs * shader_recompiler: Shared mem has side-effects, fix format component order * shader_recompiler: Inline constant buffer impl * video_core: Fix regressions * Work * Fixup a few things
26 lines
822 B
C++
Executable file
26 lines
822 B
C++
Executable file
// SPDX-FileCopyrightText: Copyright 2020 yuzu Emulator Project
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#pragma once
|
|
|
|
#include <cstddef>
|
|
#include <type_traits>
|
|
|
|
namespace Common {
|
|
|
|
/// Ceiled integer division.
|
|
template <typename N, typename D>
|
|
requires std::is_integral_v<N> && std::is_unsigned_v<D>
|
|
[[nodiscard]] constexpr N DivCeil(N number, D divisor) {
|
|
return static_cast<N>((static_cast<D>(number) + divisor - 1) / divisor);
|
|
}
|
|
|
|
/// Ceiled integer division with logarithmic divisor in base 2
|
|
template <typename N, typename D>
|
|
requires std::is_integral_v<N> && std::is_unsigned_v<D>
|
|
[[nodiscard]] constexpr N DivCeilLog2(N value, D alignment_log2) {
|
|
return static_cast<N>((static_cast<D>(value) + (D(1) << alignment_log2) - 1) >> alignment_log2);
|
|
}
|
|
|
|
} // namespace Common
|