summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2023-04-12 22:01:25 +0300
committerSebastian Dröge <sebastian@centricular.com>2023-04-12 22:01:25 +0300
commit013610ed21e609ff14e6bf43cfbaa413cc6e7f6c (patch)
treecb2f181f5531b195d5435fcf34650dcc032f2a51
parent0b8ba0ba747b9123f9cecbbabfc021564850caeb (diff)
downloadorc-013610ed21e609ff14e6bf43cfbaa413cc6e7f6c.tar.gz
Make sure beforehand that enough tokens are available for opcode parsing
Part-of: <https://gitlab.freedesktop.org/gstreamer/orc/-/merge_requests/30>
-rw-r--r--orc/orcparse.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/orc/orcparse.c b/orc/orcparse.c
index 6e1be10..a938d2c 100644
--- a/orc/orcparse.c
+++ b/orc/orcparse.c
@@ -776,9 +776,17 @@ orc_parse_handle_opcode (OrcParser *parser, const OrcLine *line)
if (strcmp (line->tokens[0], "x4") == 0) {
flags |= ORC_INSTRUCTION_FLAG_X4;
offset = 1;
+ if (line->n_tokens < 2) {
+ orc_parse_add_error (parser, "too few arguments for x4 (expected at least 2)");
+ return 0;
+ }
} else if (strcmp (line->tokens[0], "x2") == 0) {
flags |= ORC_INSTRUCTION_FLAG_X2;
offset = 1;
+ if (line->n_tokens < 2) {
+ orc_parse_add_error (parser, "too few arguments for x2 (expected at least 2)");
+ return 0;
+ }
}
o = orc_parse_find_opcode (parser, line->tokens[offset]);
@@ -794,6 +802,7 @@ orc_parse_handle_opcode (OrcParser *parser, const OrcLine *line)
orc_parse_add_error (parser, "too %s arguments for %s (expected %d)",
(line->n_tokens < 1+offset+n_args) ? "few" : "many",
line->tokens[offset], n_args);
+ return 0;
}
for(i=offset+1,j=0;i<line->n_tokens;i++,j++){