Skip to content

Commit

Permalink
Fix handling of data count without data section (WebAssembly#2432)
Browse files Browse the repository at this point in the history
  • Loading branch information
SoniEx2 authored Sep 24, 2024
1 parent 3fd8c70 commit 3852498
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 6 deletions.
17 changes: 11 additions & 6 deletions src/binary-reader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,7 @@ class BinaryReader {
Index num_tag_imports_ = 0;
Index num_function_signatures_ = 0;
Index num_function_bodies_ = 0;
Index num_data_segments_ = 0;
Index data_count_ = kInvalidIndex;

using ReadEndRestoreGuard =
Expand Down Expand Up @@ -2829,13 +2830,13 @@ Result BinaryReader::ReadCodeSection(Offset section_size) {

Result BinaryReader::ReadDataSection(Offset section_size) {
CALLBACK(BeginDataSection, section_size);
Index num_data_segments;
CHECK_RESULT(ReadCount(&num_data_segments, "data segment count"));
CALLBACK(OnDataSegmentCount, num_data_segments);
CHECK_RESULT(ReadCount(&num_data_segments_, "data segment count"));
CALLBACK(OnDataSegmentCount, num_data_segments_);
// If the DataCount section is not present, then data_count_ will be invalid.
ERROR_UNLESS(data_count_ == kInvalidIndex || data_count_ == num_data_segments,
"data segment count does not equal count in DataCount section");
for (Index i = 0; i < num_data_segments; ++i) {
ERROR_UNLESS(
data_count_ == kInvalidIndex || data_count_ == num_data_segments_,
"data segment count does not equal count in DataCount section");
for (Index i = 0; i < num_data_segments_; ++i) {
uint32_t flags;
CHECK_RESULT(ReadU32Leb128(&flags, "data segment flags"));
ERROR_IF(flags != 0 && !options_.features.bulk_memory_enabled(),
Expand Down Expand Up @@ -3037,6 +3038,10 @@ Result BinaryReader::ReadModule(const ReadModuleOptions& options) {
// in case the code section was omitted.
ERROR_UNLESS(num_function_signatures_ == num_function_bodies_,
"function signature count != function body count");
// This is checked in ReadDataSection, but it must be checked at the end too,
// in case the data section was omitted.
ERROR_IF(num_data_segments_ == 0 && data_count_ != kInvalidIndex,
"Data section missing but DataCount non-zero");
CALLBACK0(EndModule);

return Result::Ok;
Expand Down
14 changes: 14 additions & 0 deletions test/regress/data-count-without-data-section.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
;;; TOOL: run-interp-spec
(assert_malformed
(module binary
"\00asm" "\01\00\00\00"
"\05\03\01\00\01" ;; Memory section with one entry
"\0c\01\01" ;; Data count section with value 1
)
"data count and data section have inconsistent lengths"
)
(;; STDOUT ;;;
out/test/regress/data-count-without-data-section.txt:3: assert_malformed passed:
0000010: error: Data section missing but DataCount non-zero
1/1 tests passed.
;;; STDOUT ;;)

0 comments on commit 3852498

Please sign in to comment.