Branch data Line data Source code
1 : : // Copyright (c) 2019-2022 The Bitcoin Core developers 2 : : // Distributed under the MIT software license, see the accompanying 3 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php. 4 : : 5 : : #include <arith_uint256.h> 6 : : #include <common/args.h> 7 : : #include <common/system.h> 8 : : #include <compressor.h> 9 : : #include <consensus/amount.h> 10 : : #include <consensus/merkle.h> 11 : : #include <core_io.h> 12 : : #include <crypto/common.h> 13 : : #include <crypto/siphash.h> 14 : : #include <key_io.h> 15 : : #include <memusage.h> 16 : : #include <netbase.h> 17 : : #include <policy/policy.h> 18 : : #include <policy/settings.h> 19 : : #include <pow.h> 20 : : #include <protocol.h> 21 : : #include <pubkey.h> 22 : : #include <script/script.h> 23 : : #include <serialize.h> 24 : : #include <streams.h> 25 : : #include <test/fuzz/FuzzedDataProvider.h> 26 : : #include <test/fuzz/fuzz.h> 27 : : #include <test/fuzz/util.h> 28 : : #include <uint256.h> 29 : : #include <univalue.h> 30 : : #include <util/chaintype.h> 31 : : #include <util/check.h> 32 : : #include <util/moneystr.h> 33 : : #include <util/overflow.h> 34 : : #include <util/strencodings.h> 35 : : #include <util/string.h> 36 : : #include <version.h> 37 : : 38 : : #include <cassert> 39 : : #include <chrono> 40 : : #include <limits> 41 : : #include <set> 42 : : #include <vector> 43 : : 44 : 0 : void initialize_integer() 45 : : { 46 : 0 : SelectParams(ChainType::REGTEST); 47 : 0 : } 48 : : 49 [ + - ]: 4 : FUZZ_TARGET(integer, .init = initialize_integer) 50 : : { 51 [ # # ]: 0 : if (buffer.size() < sizeof(uint256) + sizeof(uint160)) { 52 : 0 : return; 53 : : } 54 : 0 : FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size()); 55 [ # # ][ # # ]: 0 : const uint256 u256(fuzzed_data_provider.ConsumeBytes<unsigned char>(sizeof(uint256))); 56 [ # # ][ # # ]: 0 : const uint160 u160(fuzzed_data_provider.ConsumeBytes<unsigned char>(sizeof(uint160))); 57 : 0 : const uint64_t u64 = fuzzed_data_provider.ConsumeIntegral<uint64_t>(); 58 : 0 : const int64_t i64 = fuzzed_data_provider.ConsumeIntegral<int64_t>(); 59 : 0 : const uint32_t u32 = fuzzed_data_provider.ConsumeIntegral<uint32_t>(); 60 : 0 : const int32_t i32 = fuzzed_data_provider.ConsumeIntegral<int32_t>(); 61 : 0 : const uint16_t u16 = fuzzed_data_provider.ConsumeIntegral<uint16_t>(); 62 : 0 : const int16_t i16 = fuzzed_data_provider.ConsumeIntegral<int16_t>(); 63 : 0 : const uint8_t u8 = fuzzed_data_provider.ConsumeIntegral<uint8_t>(); 64 : 0 : const int8_t i8 = fuzzed_data_provider.ConsumeIntegral<int8_t>(); 65 : : // We cannot assume a specific value of std::is_signed<char>::value: 66 : : // ConsumeIntegral<char>() instead of casting from {u,}int8_t. 67 : 0 : const char ch = fuzzed_data_provider.ConsumeIntegral<char>(); 68 : 0 : const bool b = fuzzed_data_provider.ConsumeBool(); 69 : : 70 : 0 : const Consensus::Params& consensus_params = Params().GetConsensus(); 71 : 0 : (void)CheckProofOfWork(u256, u32, consensus_params); 72 [ # # ]: 0 : if (u64 <= MAX_MONEY) { 73 : 0 : const uint64_t compressed_money_amount = CompressAmount(u64); 74 [ # # ]: 0 : assert(u64 == DecompressAmount(compressed_money_amount)); 75 [ # # ][ # # ]: 0 : static const uint64_t compressed_money_amount_max = CompressAmount(MAX_MONEY - 1); [ # # ] 76 [ # # ]: 0 : assert(compressed_money_amount <= compressed_money_amount_max); 77 : 0 : } else { 78 : 0 : (void)CompressAmount(u64); 79 : : } 80 [ # # ][ # # ]: 0 : static const uint256 u256_min(uint256S("0000000000000000000000000000000000000000000000000000000000000000")); [ # # ] 81 [ # # ][ # # ]: 0 : static const uint256 u256_max(uint256S("ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff")); [ # # ] 82 [ # # ]: 0 : const std::vector<uint256> v256{u256, u256_min, u256_max}; 83 [ # # ][ # # ]: 0 : (void)ComputeMerkleRoot(v256); 84 [ # # ]: 0 : (void)CountBits(u64); 85 [ # # ]: 0 : (void)DecompressAmount(u64); 86 : : { 87 [ # # ][ # # ]: 0 : if (std::optional<CAmount> parsed = ParseMoney(FormatMoney(i64))) { [ # # ] 88 [ # # ][ # # ]: 0 : assert(parsed.value() == i64); 89 : 0 : } 90 : : } 91 [ # # ]: 0 : (void)GetSizeOfCompactSize(u64); 92 [ # # ]: 0 : (void)GetSpecialScriptSize(u32); 93 [ # # ][ # # ]: 0 : if (!MultiplicationOverflow(i64, static_cast<int64_t>(u32)) && !AdditionOverflow(i64, static_cast<int64_t>(4)) && !AdditionOverflow(i64 * u32, static_cast<int64_t>(4))) { [ # # ] 94 [ # # ]: 0 : (void)GetVirtualTransactionSize(i64, i64, u32); 95 : 0 : } 96 [ # # ]: 0 : (void)HexDigit(ch); 97 [ # # ]: 0 : (void)MoneyRange(i64); 98 [ # # ]: 0 : (void)ToString(i64); 99 [ # # ]: 0 : (void)IsDigit(ch); 100 : 0 : (void)IsSpace(ch); 101 [ # # ]: 0 : (void)IsSwitchChar(ch); 102 [ # # ]: 0 : (void)memusage::DynamicUsage(ch); 103 [ # # ]: 0 : (void)memusage::DynamicUsage(i16); 104 [ # # ]: 0 : (void)memusage::DynamicUsage(i32); 105 [ # # ]: 0 : (void)memusage::DynamicUsage(i64); 106 [ # # ]: 0 : (void)memusage::DynamicUsage(i8); 107 [ # # ]: 0 : (void)memusage::DynamicUsage(u16); 108 [ # # ]: 0 : (void)memusage::DynamicUsage(u32); 109 [ # # ]: 0 : (void)memusage::DynamicUsage(u64); 110 [ # # ]: 0 : (void)memusage::DynamicUsage(u8); 111 : 0 : const unsigned char uch = static_cast<unsigned char>(u8); 112 [ # # ]: 0 : (void)memusage::DynamicUsage(uch); 113 : : { 114 [ # # ]: 0 : const std::set<int64_t> i64s{i64, static_cast<int64_t>(u64)}; 115 [ # # ]: 0 : const size_t dynamic_usage = memusage::DynamicUsage(i64s); 116 [ # # ]: 0 : const size_t incremental_dynamic_usage = memusage::IncrementalDynamicUsage(i64s); 117 [ # # ]: 0 : assert(dynamic_usage == incremental_dynamic_usage * i64s.size()); 118 : 0 : } 119 [ # # ]: 0 : (void)MillisToTimeval(i64); 120 [ # # ]: 0 : (void)SighashToStr(uch); 121 [ # # ]: 0 : (void)SipHashUint256(u64, u64, u256); 122 [ # # ]: 0 : (void)SipHashUint256Extra(u64, u64, u256, u32); 123 [ # # ]: 0 : (void)ToLower(ch); 124 [ # # ]: 0 : (void)ToUpper(ch); 125 : : { 126 [ # # ][ # # ]: 0 : if (std::optional<CAmount> parsed = ParseMoney(ValueFromAmount(i64).getValStr())) { [ # # ][ # # ] 127 [ # # ][ # # ]: 0 : assert(parsed.value() == i64); 128 : 0 : } 129 : : } 130 [ # # ][ # # ]: 0 : if (i32 >= 0 && i32 <= 16) { 131 [ # # ][ # # ]: 0 : assert(i32 == CScript::DecodeOP_N(CScript::EncodeOP_N(i32))); [ # # ] 132 : 0 : } 133 : : 134 [ # # ]: 0 : const std::chrono::seconds seconds{i64}; 135 [ # # ][ # # ]: 0 : assert(count_seconds(seconds) == i64); 136 : : 137 [ # # ]: 0 : const CScriptNum script_num{i64}; 138 [ # # ]: 0 : (void)script_num.getint(); 139 [ # # ]: 0 : (void)script_num.getvch(); 140 : : 141 [ # # ]: 0 : const arith_uint256 au256 = UintToArith256(u256); 142 [ # # ][ # # ]: 0 : assert(ArithToUint256(au256) == u256); [ # # ] 143 [ # # ][ # # ]: 0 : assert(uint256S(au256.GetHex()) == u256); [ # # ][ # # ] 144 [ # # ]: 0 : (void)au256.bits(); 145 [ # # ]: 0 : (void)au256.GetCompact(/* fNegative= */ false); 146 [ # # ]: 0 : (void)au256.GetCompact(/* fNegative= */ true); 147 [ # # ]: 0 : (void)au256.getdouble(); 148 [ # # ]: 0 : (void)au256.GetHex(); 149 [ # # ]: 0 : (void)au256.GetLow64(); 150 [ # # ]: 0 : (void)au256.size(); 151 [ # # ]: 0 : (void)au256.ToString(); 152 : : 153 [ # # ]: 0 : const CKeyID key_id{u160}; 154 [ # # ]: 0 : const CScriptID script_id{u160}; 155 : : 156 : : { 157 [ # # ]: 0 : DataStream stream{}; 158 : : 159 [ # # ]: 0 : uint256 deserialized_u256; 160 [ # # ]: 0 : stream << u256; 161 [ # # ]: 0 : stream >> deserialized_u256; 162 [ # # ][ # # ]: 0 : assert(u256 == deserialized_u256 && stream.empty()); [ # # ][ # # ] 163 : : 164 [ # # ]: 0 : uint160 deserialized_u160; 165 [ # # ]: 0 : stream << u160; 166 [ # # ]: 0 : stream >> deserialized_u160; 167 [ # # ][ # # ]: 0 : assert(u160 == deserialized_u160 && stream.empty()); [ # # ][ # # ] 168 : : 169 : : uint64_t deserialized_u64; 170 [ # # ]: 0 : stream << u64; 171 [ # # ]: 0 : stream >> deserialized_u64; 172 [ # # ][ # # ]: 0 : assert(u64 == deserialized_u64 && stream.empty()); [ # # ] 173 : : 174 : : int64_t deserialized_i64; 175 [ # # ]: 0 : stream << i64; 176 [ # # ]: 0 : stream >> deserialized_i64; 177 [ # # ][ # # ]: 0 : assert(i64 == deserialized_i64 && stream.empty()); [ # # ] 178 : : 179 : : uint32_t deserialized_u32; 180 [ # # ]: 0 : stream << u32; 181 [ # # ]: 0 : stream >> deserialized_u32; 182 [ # # ][ # # ]: 0 : assert(u32 == deserialized_u32 && stream.empty()); [ # # ] 183 : : 184 : : int32_t deserialized_i32; 185 [ # # ]: 0 : stream << i32; 186 [ # # ]: 0 : stream >> deserialized_i32; 187 [ # # ][ # # ]: 0 : assert(i32 == deserialized_i32 && stream.empty()); [ # # ] 188 : : 189 : : uint16_t deserialized_u16; 190 [ # # ]: 0 : stream << u16; 191 [ # # ]: 0 : stream >> deserialized_u16; 192 [ # # ][ # # ]: 0 : assert(u16 == deserialized_u16 && stream.empty()); [ # # ] 193 : : 194 : : int16_t deserialized_i16; 195 [ # # ]: 0 : stream << i16; 196 [ # # ]: 0 : stream >> deserialized_i16; 197 [ # # ][ # # ]: 0 : assert(i16 == deserialized_i16 && stream.empty()); [ # # ] 198 : : 199 : : uint8_t deserialized_u8; 200 [ # # ]: 0 : stream << u8; 201 [ # # ]: 0 : stream >> deserialized_u8; 202 [ # # ][ # # ]: 0 : assert(u8 == deserialized_u8 && stream.empty()); [ # # ] 203 : : 204 : : int8_t deserialized_i8; 205 [ # # ]: 0 : stream << i8; 206 [ # # ]: 0 : stream >> deserialized_i8; 207 [ # # ][ # # ]: 0 : assert(i8 == deserialized_i8 && stream.empty()); [ # # ] 208 : : 209 : : bool deserialized_b; 210 [ # # ]: 0 : stream << b; 211 [ # # ]: 0 : stream >> deserialized_b; 212 [ # # ][ # # ]: 0 : assert(b == deserialized_b && stream.empty()); [ # # ] 213 : 0 : } 214 : : 215 : : { 216 : 0 : const ServiceFlags service_flags = (ServiceFlags)u64; 217 [ # # ]: 0 : (void)HasAllDesirableServiceFlags(service_flags); 218 [ # # ]: 0 : (void)MayHaveUsefulAddressDB(service_flags); 219 : : } 220 : : 221 : : { 222 [ # # ]: 0 : DataStream stream{}; 223 : : 224 [ # # ]: 0 : ser_writedata64(stream, u64); 225 [ # # ]: 0 : const uint64_t deserialized_u64 = ser_readdata64(stream); 226 [ # # ][ # # ]: 0 : assert(u64 == deserialized_u64 && stream.empty()); [ # # ] 227 : : 228 [ # # ]: 0 : ser_writedata32(stream, u32); 229 [ # # ]: 0 : const uint32_t deserialized_u32 = ser_readdata32(stream); 230 [ # # ][ # # ]: 0 : assert(u32 == deserialized_u32 && stream.empty()); [ # # ] 231 : : 232 [ # # ]: 0 : ser_writedata32be(stream, u32); 233 [ # # ]: 0 : const uint32_t deserialized_u32be = ser_readdata32be(stream); 234 [ # # ][ # # ]: 0 : assert(u32 == deserialized_u32be && stream.empty()); [ # # ] 235 : : 236 [ # # ]: 0 : ser_writedata16(stream, u16); 237 [ # # ]: 0 : const uint16_t deserialized_u16 = ser_readdata16(stream); 238 [ # # ][ # # ]: 0 : assert(u16 == deserialized_u16 && stream.empty()); [ # # ] 239 : : 240 [ # # ]: 0 : ser_writedata16be(stream, u16); 241 [ # # ]: 0 : const uint16_t deserialized_u16be = ser_readdata16be(stream); 242 [ # # ][ # # ]: 0 : assert(u16 == deserialized_u16be && stream.empty()); [ # # ] 243 : : 244 [ # # ]: 0 : ser_writedata8(stream, u8); 245 [ # # ]: 0 : const uint8_t deserialized_u8 = ser_readdata8(stream); 246 [ # # ][ # # ]: 0 : assert(u8 == deserialized_u8 && stream.empty()); [ # # ] 247 : 0 : } 248 : : 249 : : { 250 [ # # ]: 0 : DataStream stream{}; 251 : : 252 [ # # ]: 0 : WriteCompactSize(stream, u64); 253 : : try { 254 [ # # ]: 0 : const uint64_t deserialized_u64 = ReadCompactSize(stream); 255 [ # # ][ # # ]: 0 : assert(u64 == deserialized_u64 && stream.empty()); [ # # ] 256 [ # # ]: 0 : } catch (const std::ios_base::failure&) { 257 [ # # ]: 0 : } 258 : 0 : } 259 : : 260 : : try { 261 [ # # ]: 0 : CHECK_NONFATAL(b); 262 [ # # ]: 0 : } catch (const NonFatalCheckError&) { 263 [ # # ]: 0 : } 264 : 0 : }