From 099a3b413780324d81f66004bdf74d8a56dfca1b Mon Sep 17 00:00:00 2001 From: evoskuil Date: Thu, 22 Aug 2024 18:51:54 -0400 Subject: [PATCH] Do not allow nullptr witness stack elements. --- src/chain/witness.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/chain/witness.cpp b/src/chain/witness.cpp index 8880df19e6..feee8131a2 100644 --- a/src/chain/witness.cpp +++ b/src/chain/witness.cpp @@ -176,8 +176,12 @@ void witness::assign_data(reader& source, bool prefix) NOEXCEPT for (size_t element = 0; element < count; ++element) { + // If read_bytes_raw returns nullptr invalid source is implied. const auto size = source.read_size(max_block_weight); const auto bytes = source.read_bytes_raw(size); + if (is_null(bytes)) + break; + stack_.emplace_back(POINTER(data_chunk, allocator, bytes)); size_ = element_size(size_, stack_.back()); } @@ -186,8 +190,12 @@ void witness::assign_data(reader& source, bool prefix) NOEXCEPT { while (!source.is_exhausted()) { + // If read_bytes_raw returns nullptr invalid source is implied. const auto size = source.read_size(max_block_weight); const auto bytes = source.read_bytes_raw(size); + if (is_null(bytes)) + break; + stack_.emplace_back(POINTER(data_chunk, allocator, bytes)); size_ = element_size(size_, stack_.back()); }