aboutsummaryrefslogtreecommitdiff
path: root/src/validation.cpp
diff options
context:
space:
mode:
authorMarcoFalke <falke.marco@gmail.com>2021-06-04 09:21:04 +0200
committerMarcoFalke <falke.marco@gmail.com>2021-06-09 22:20:01 +0200
commitfa9ebedec3f982bb5bb459ea33d74c94d9b5cec4 (patch)
tree9fae9a6558789ac267c0bdc88099f1329b28682c /src/validation.cpp
parent46424e943c0b2e9d006ade6bfe3dc02f19c1d5c0 (diff)
downloadbitcoin-fa9ebedec3f982bb5bb459ea33d74c94d9b5cec4.tar.xz
Reject invalid coin height and output index when loading assumeutxo
Diffstat (limited to 'src/validation.cpp')
-rw-r--r--src/validation.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/validation.cpp b/src/validation.cpp
index 5e3d429c2e..dceceefbdc 100644
--- a/src/validation.cpp
+++ b/src/validation.cpp
@@ -4989,6 +4989,14 @@ bool ChainstateManager::PopulateAndValidateSnapshot(
coins_count - coins_left);
return false;
}
+ if (coin.nHeight > base_height ||
+ outpoint.n >= std::numeric_limits<decltype(outpoint.n)>::max() // Avoid integer wrap-around in coinstats.cpp:ApplyHash
+ ) {
+ LogPrintf("[snapshot] bad snapshot data after deserializing %d coins\n",
+ coins_count - coins_left);
+ return false;
+ }
+
coins_cache.EmplaceCoinInternalDANGER(std::move(outpoint), std::move(coin));
--coins_left;