Skip to content

Commit

Permalink
Merge pull request #777 from pguyot/w34/abort-on-a-decode-we-dont-sup…
Browse files Browse the repository at this point in the history
…port

Abort on a decode we dont support

These changes are made under both the "Apache 2.0" and the "GNU Lesser General
Public License 2.1 or later" license terms (dual license).

SPDX-License-Identifier: Apache-2.0 OR LGPL-2.1-or-later
  • Loading branch information
bettio committed Oct 26, 2023
2 parents 25c09a0 + d6fa2ad commit 8c3e7d1
Showing 1 changed file with 11 additions and 6 deletions.
17 changes: 11 additions & 6 deletions src/libAtomVM/opcodesswitch.h
Original file line number Diff line number Diff line change
Expand Up @@ -198,12 +198,17 @@ typedef dreg_t dreg_gc_safe_t;
case COMPACT_11BITS_VALUE: \
(decode_pc)++; \
break; \
\
case COMPACT_NBITS_VALUE: \
/* TODO: when first_byte >> 5 is 7, a different encoding is used */ \
(decode_pc) += (first_byte >> 5) + 2; \
case COMPACT_NBITS_VALUE:{ \
int sz = (first_byte >> 5) + 2; \
if (UNLIKELY(sz > 8)) { \
/* TODO: when first_byte >> 5 is 7, a different encoding is used */ \
fprintf(stderr, "Unexpected nbits vaue @ %" PRIuPTR "\n", (uintptr_t) ((decode_pc) - 1)); \
AVM_ABORT(); \
break; \
} \
(decode_pc) += sz; \
break; \
\
} \
default: \
assert((first_byte & 0x30) != COMPACT_LARGE_INTEGER); \
break; \
Expand Down Expand Up @@ -240,7 +245,7 @@ typedef dreg_t dreg_gc_safe_t;
case COMPACT_XREG: \
case COMPACT_YREG: \
(dreg).index = first_byte >> 4; \
- break; \
break; \
case COMPACT_LARGE_YREG: \
(dreg).index = (((first_byte & 0xE0) << 3) | *(decode_pc)++); \
break; \
Expand Down

0 comments on commit 8c3e7d1

Please sign in to comment.