summaryrefslogtreecommitdiff
path: root/src/common/uint128.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/common/uint128.cpp')
-rw-r--r--src/common/uint128.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/common/uint128.cpp b/src/common/uint128.cpp
index 32bf56730..7e77588db 100644
--- a/src/common/uint128.cpp
+++ b/src/common/uint128.cpp
@@ -6,12 +6,34 @@
6#include <intrin.h> 6#include <intrin.h>
7 7
8#pragma intrinsic(_umul128) 8#pragma intrinsic(_umul128)
9#pragma intrinsic(_udiv128)
9#endif 10#endif
10#include <cstring> 11#include <cstring>
11#include "common/uint128.h" 12#include "common/uint128.h"
12 13
13namespace Common { 14namespace Common {
14 15
16#ifdef _MSC_VER
17
18u64 MultiplyAndDivide64(u64 a, u64 b, u64 d) {
19 u128 r{};
20 r[0] = _umul128(a, b, &r[1]);
21 u64 remainder;
22 return _udiv128(r[1], r[0], d, &remainder);
23}
24
25#else
26
27u64 MultiplyAndDivide64(u64 a, u64 b, u64 d) {
28 const u64 diva = a / d;
29 const u64 moda = a % d;
30 const u64 divb = b / d;
31 const u64 modb = b % d;
32 return diva * b + moda * divb + moda * modb / d;
33}
34
35#endif
36
15u128 Multiply64Into128(u64 a, u64 b) { 37u128 Multiply64Into128(u64 a, u64 b) {
16 u128 result; 38 u128 result;
17#ifdef _MSC_VER 39#ifdef _MSC_VER