Branch data Line data Source code
1 : : // Copyright (c) 2009-2010 Satoshi Nakamoto
2 : : // Copyright (c) 2009-present The Bitcoin Core developers
3 : : // Distributed under the MIT software license, see the accompanying
4 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 : :
6 : : #include <arith_uint256.h>
7 : :
8 : : #include <crypto/common.h>
9 : : #include <uint256.h>
10 : : #include <util/overflow.h>
11 : :
12 : : #include <cassert>
13 : :
14 : : template <unsigned int BITS>
15 : 3589456 : base_uint<BITS>& base_uint<BITS>::operator<<=(unsigned int shift)
16 : : {
17 : 3589456 : base_uint<BITS> a(*this);
18 [ + + ]: 32305104 : for (int i = 0; i < WIDTH; i++)
19 : 28715648 : pn[i] = 0;
20 : 3589456 : int k = shift / 32;
21 : 3589456 : shift = shift % 32;
22 [ + + ]: 32305104 : for (int i = 0; i < WIDTH; i++) {
23 [ + + + + ]: 28715648 : if (i + k + 1 < WIDTH && shift != 0)
24 : 6290815 : pn[i + k + 1] |= (a.pn[i] >> (32 - shift));
25 [ + + ]: 28715648 : if (i + k < WIDTH)
26 : 10044212 : pn[i + k] |= (a.pn[i] << shift);
27 : : }
28 : 3589456 : return *this;
29 : : }
30 : :
31 : : template <unsigned int BITS>
32 : 1913015 : base_uint<BITS>& base_uint<BITS>::operator>>=(unsigned int shift)
33 : : {
34 : 1913015 : base_uint<BITS> a(*this);
35 [ + + ]: 17217135 : for (int i = 0; i < WIDTH; i++)
36 : 15304120 : pn[i] = 0;
37 : 1913015 : int k = shift / 32;
38 : 1913015 : shift = shift % 32;
39 [ + + ]: 17217135 : for (int i = 0; i < WIDTH; i++) {
40 [ + + + + ]: 15304120 : if (i - k - 1 >= 0 && shift != 0)
41 : 11299823 : pn[i - k - 1] |= (a.pn[i] << (32 - shift));
42 [ + + ]: 15304120 : if (i - k >= 0)
43 : 13213599 : pn[i - k] |= (a.pn[i] >> shift);
44 : : }
45 : 1913015 : return *this;
46 : : }
47 : :
48 : : template <unsigned int BITS>
49 : 14051 : base_uint<BITS>& base_uint<BITS>::operator*=(uint32_t b32)
50 : : {
51 : 14051 : uint64_t carry = 0;
52 [ + + ]: 126459 : for (int i = 0; i < WIDTH; i++) {
53 : 112408 : uint64_t n = carry + (uint64_t)b32 * pn[i];
54 : 112408 : pn[i] = n & 0xffffffff;
55 : 112408 : carry = n >> 32;
56 : : }
57 : 14051 : return *this;
58 : : }
59 : :
60 : : template <unsigned int BITS>
61 : 66396 : base_uint<BITS>& base_uint<BITS>::operator*=(const base_uint& b)
62 : : {
63 : 66396 : base_uint<BITS> a;
64 [ + + ]: 597564 : for (int j = 0; j < WIDTH; j++) {
65 : : uint64_t carry = 0;
66 [ + + ]: 2921424 : for (int i = 0; i + j < WIDTH; i++) {
67 : 2390256 : uint64_t n = carry + a.pn[i + j] + (uint64_t)pn[j] * b.pn[i];
68 : 2390256 : a.pn[i + j] = n & 0xffffffff;
69 : 2390256 : carry = n >> 32;
70 : : }
71 : : }
72 : 66396 : *this = a;
73 : 66396 : return *this;
74 : : }
75 : :
76 : : template <unsigned int BITS>
77 : 754509 : base_uint<BITS>& base_uint<BITS>::operator/=(const base_uint& b)
78 : : {
79 : 754509 : base_uint<BITS> div = b; // make a copy, so we can shift.
80 : 754509 : base_uint<BITS> num = *this; // make a copy, so we can subtract.
81 : 754509 : *this = 0; // the quotient.
82 : 754509 : int num_bits = num.bits();
83 : 754509 : int div_bits = div.bits();
84 [ + + ]: 754509 : if (div_bits == 0)
85 [ + - ]: 4 : throw uint_error("Division by zero");
86 [ + + ]: 754507 : if (div_bits > num_bits) // the result is certainly 0.
87 : : return *this;
88 : 754505 : int shift = num_bits - div_bits;
89 : 754505 : div <<= shift; // shift so that div and num align.
90 [ + + ]: 2364715 : while (shift >= 0) {
91 [ + + ]: 1610210 : if (num >= div) {
92 : 769321 : num -= div;
93 : 769321 : pn[shift / 32] |= (1U << (shift & 31)); // set a bit of the result.
94 : : }
95 : 1610210 : div >>= 1; // shift back.
96 : 1610210 : shift--;
97 : : }
98 : : // num now contains the remainder of the division.
99 : : return *this;
100 : : }
101 : :
102 : : template <unsigned int BITS>
103 : 1891321093 : int base_uint<BITS>::CompareTo(const base_uint<BITS>& b) const
104 : : {
105 [ + + ]: 14997771223 : for (int i = WIDTH - 1; i >= 0; i--) {
106 [ + + ]: 14984042354 : if (pn[i] < b.pn[i])
107 : : return -1;
108 [ + + ]: 13673980584 : if (pn[i] > b.pn[i])
109 : : return 1;
110 : : }
111 : : return 0;
112 : : }
113 : :
114 : : template <unsigned int BITS>
115 : 2777721 : bool base_uint<BITS>::EqualTo(uint64_t b) const
116 : : {
117 [ + + ]: 2785530 : for (int i = WIDTH - 1; i >= 2; i--) {
118 [ + + ]: 2785424 : if (pn[i])
119 : : return false;
120 : : }
121 [ + + ]: 106 : if (pn[1] != (b >> 32))
122 : : return false;
123 [ + + ]: 74 : if (pn[0] != (b & 0xfffffffful))
124 : 32 : return false;
125 : : return true;
126 : : }
127 : :
128 : : template <unsigned int BITS>
129 : 157289 : double base_uint<BITS>::getdouble() const
130 : : {
131 : 157289 : double ret = 0.0;
132 : 157289 : double fact = 1.0;
133 [ + + ]: 1415601 : for (int i = 0; i < WIDTH; i++) {
134 : 1258312 : ret += fact * pn[i];
135 : 1258312 : fact *= 4294967296.0;
136 : : }
137 : 157289 : return ret;
138 : : }
139 : :
140 : : template <unsigned int BITS>
141 : 24943 : std::string base_uint<BITS>::GetHex() const
142 : : {
143 : 24943 : base_blob<BITS> b;
144 [ + + ]: 224487 : for (int x = 0; x < this->WIDTH; ++x) {
145 : 199544 : WriteLE32(b.begin() + x*4, this->pn[x]);
146 : : }
147 : 24943 : return b.GetHex();
148 : : }
149 : :
150 : : template <unsigned int BITS>
151 : 33 : std::string base_uint<BITS>::ToString() const
152 : : {
153 : 33 : return GetHex();
154 : : }
155 : :
156 : : template <unsigned int BITS>
157 : 1805681 : unsigned int base_uint<BITS>::bits() const
158 : : {
159 [ + + ]: 1839598 : for (int pos = WIDTH - 1; pos >= 0; pos--) {
160 [ + + ]: 1839582 : if (pn[pos]) {
161 [ + + ]: 2922589 : for (int nbits = 31; nbits > 0; nbits--) {
162 [ + + ]: 2922586 : if (pn[pos] & 1U << nbits)
163 : 1805662 : return 32 * pos + nbits + 1;
164 : : }
165 : 3 : return 32 * pos + 1;
166 : : }
167 : : }
168 : : return 0;
169 : : }
170 : :
171 : : // Explicit instantiations for base_uint<256>
172 : : template class base_uint<256>;
173 : :
174 : : // This implementation directly uses shifts instead of going
175 : : // through an intermediate MPI representation.
176 : 2779591 : arith_uint256& arith_uint256::SetCompact(uint32_t nCompact, bool* pfNegative, bool* pfOverflow)
177 : : {
178 : 2779591 : int nSize = nCompact >> 24;
179 : 2779591 : uint32_t nWord = nCompact & 0x007fffff;
180 [ + + ]: 2779591 : if (nSize <= 3) {
181 : 46 : nWord >>= 8 * (3 - nSize);
182 : 92 : *this = nWord;
183 : : } else {
184 : 2779545 : *this = nWord;
185 : 2779545 : *this <<= 8 * (nSize - 3);
186 : : }
187 [ + + ]: 2779591 : if (pfNegative)
188 [ + + + + ]: 5554953 : *pfNegative = nWord != 0 && (nCompact & 0x00800000) != 0;
189 [ + + ]: 2779591 : if (pfOverflow)
190 [ + + + + ]: 5554954 : *pfOverflow = nWord != 0 && ((nSize > 34) ||
191 [ + - ]: 2777432 : (nWord > 0xff && nSize > 33) ||
192 [ + - ]: 2777432 : (nWord > 0xffff && nSize > 32));
193 : 2779591 : return *this;
194 : : }
195 : :
196 : 295287 : uint32_t arith_uint256::GetCompact(bool fNegative) const
197 : : {
198 [ + + ]: 295287 : int nSize = CeilDiv(bits(), 8u);
199 : 295287 : uint32_t nCompact = 0;
200 [ + + ]: 295287 : if (nSize <= 3) {
201 : 17 : nCompact = GetLow64() << 8 * (3 - nSize);
202 : : } else {
203 : 295270 : arith_uint256 bn = *this >> 8 * (nSize - 3);
204 : 295270 : nCompact = bn.GetLow64();
205 : : }
206 : : // The 0x00800000 bit denotes the sign.
207 : : // Thus, if it is already set, divide the mantissa by 256 and increase the exponent.
208 [ + + ]: 295287 : if (nCompact & 0x00800000) {
209 : 2422 : nCompact >>= 8;
210 : 2422 : nSize++;
211 : : }
212 [ - + ]: 295287 : assert((nCompact & ~0x007fffffU) == 0);
213 [ - + ]: 295287 : assert(nSize < 256);
214 : 295287 : nCompact |= nSize << 24;
215 [ + + - + ]: 295287 : nCompact |= (fNegative && (nCompact & 0x007fffff) ? 0x00800000 : 0);
216 : 295287 : return nCompact;
217 : : }
218 : :
219 : 307370 : uint256 ArithToUint256(const arith_uint256 &a)
220 : : {
221 : 307370 : uint256 b;
222 [ + + ]: 2766330 : for(int x=0; x<a.WIDTH; ++x)
223 : 2458960 : WriteLE32(b.begin() + x*4, a.pn[x]);
224 : 307370 : return b;
225 : : }
226 : 20784776 : arith_uint256 UintToArith256(const uint256 &a)
227 : : {
228 : 20784776 : arith_uint256 b;
229 [ + + ]: 187062984 : for(int x=0; x<b.WIDTH; ++x)
230 : 166278208 : b.pn[x] = ReadLE32(a.begin() + x*4);
231 : 20784776 : return b;
232 : : }
233 : :
234 : : // Explicit instantiations for base_uint<6144> (used in test/fuzz/muhash.cpp).
235 : : template base_uint<6144>& base_uint<6144>::operator*=(const base_uint<6144>& b);
236 : : template base_uint<6144>& base_uint<6144>::operator/=(const base_uint<6144>& b);
|