Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/GStreamer/orc.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Schleef <ds@schleef.org>2010-08-13 22:50:04 +0400
committerDavid Schleef <ds@schleef.org>2010-08-13 22:50:04 +0400
commit9d3a16f7feba9fea4efd673be170bf6927c01b6e (patch)
treeec171f5c4ae873cf45c5e5cc39c26d0ca33fa34f /testsuite
parent2283cd00d72d9b130567c0d47691b7371f0fd695 (diff)
Fixes to handle opcodes with 3 sources
Diffstat (limited to 'testsuite')
-rw-r--r--testsuite/exec_opcodes_sys.c51
1 files changed, 37 insertions, 14 deletions
diff --git a/testsuite/exec_opcodes_sys.c b/testsuite/exec_opcodes_sys.c
index 09c3cea..0a8dec7 100644
--- a/testsuite/exec_opcodes_sys.c
+++ b/testsuite/exec_opcodes_sys.c
@@ -147,32 +147,43 @@ test_opcode_const (OrcStaticOpcode *opcode)
char s[40];
int ret;
int flags = 0;
+ int args[4] = { -1, -1, -1, -1 };
+ int n_args = 0;
if (opcode->src_size[1] == 0) {
return;
}
-
p = orc_program_new ();
if (opcode->flags & ORC_STATIC_OPCODE_ACCUMULATOR) {
- orc_program_add_accumulator (p, opcode->dest_size[0], "d1");
+ args[n_args++] =
+ orc_program_add_accumulator (p, opcode->dest_size[0], "d1");
} else {
- orc_program_add_destination (p, opcode->dest_size[0], "d1");
+ args[n_args++] =
+ orc_program_add_destination (p, opcode->dest_size[0], "d1");
}
if (opcode->dest_size[1] != 0) {
- orc_program_add_destination (p, opcode->dest_size[1], "d2");
+ args[n_args++] =
+ orc_program_add_destination (p, opcode->dest_size[1], "d2");
+ }
+ args[n_args++] =
+ orc_program_add_source (p, opcode->src_size[0], "s1");
+ args[n_args++] =
+ orc_program_add_constant (p, opcode->src_size[1], 1, "c1");
+ if (opcode->src_size[2]) {
+ args[n_args++] =
+ orc_program_add_constant (p, opcode->src_size[2], 1, "c2");
}
- orc_program_add_source (p, opcode->src_size[0], "s1");
- orc_program_add_constant (p, opcode->src_size[1], 1, "c1");
if ((opcode->flags & ORC_STATIC_OPCODE_FLOAT_SRC) ||
(opcode->flags & ORC_STATIC_OPCODE_FLOAT_DEST)) {
flags = ORC_TEST_FLAGS_FLOAT;
}
- sprintf(s, "test_c_%s", opcode->name);
+ sprintf(s, "test_const_%s", opcode->name);
orc_program_set_name (p, s);
- orc_program_append_str (p, opcode->name, "d1", "s1", "c1");
+ orc_program_append_2 (p, opcode->name, 0, args[0], args[1],
+ args[2], args[3]);
ret = orc_test_compare_output_full (p, flags);
if (!ret) {
@@ -190,21 +201,32 @@ test_opcode_param (OrcStaticOpcode *opcode)
char s[40];
int ret;
int flags = 0;
+ int args[4] = { -1, -1, -1, -1 };
+ int n_args = 0;
if (opcode->src_size[1] == 0) {
return;
}
p = orc_program_new ();
if (opcode->flags & ORC_STATIC_OPCODE_ACCUMULATOR) {
- orc_program_add_accumulator (p, opcode->dest_size[0], "d1");
+ args[n_args++] =
+ orc_program_add_accumulator (p, opcode->dest_size[0], "d1");
} else {
- orc_program_add_destination (p, opcode->dest_size[0], "d1");
+ args[n_args++] =
+ orc_program_add_destination (p, opcode->dest_size[0], "d1");
}
if (opcode->dest_size[1] != 0) {
- orc_program_add_destination (p, opcode->dest_size[1], "d2");
+ args[n_args++] =
+ orc_program_add_destination (p, opcode->dest_size[1], "d2");
+ }
+ args[n_args++] =
+ orc_program_add_source (p, opcode->src_size[0], "s1");
+ args[n_args++] =
+ orc_program_add_parameter (p, opcode->src_size[1], "p1");
+ if (opcode->src_size[2]) {
+ args[n_args++] =
+ orc_program_add_parameter (p, opcode->src_size[2], "p2");
}
- orc_program_add_source (p, opcode->src_size[0], "s1");
- orc_program_add_parameter (p, opcode->src_size[1], "p1");
if ((opcode->flags & ORC_STATIC_OPCODE_FLOAT_SRC) ||
(opcode->flags & ORC_STATIC_OPCODE_FLOAT_DEST)) {
@@ -214,7 +236,8 @@ test_opcode_param (OrcStaticOpcode *opcode)
sprintf(s, "test_p_%s", opcode->name);
orc_program_set_name (p, s);
- orc_program_append_str (p, opcode->name, "d1", "s1", "p1");
+ orc_program_append_2 (p, opcode->name, 0, args[0], args[1],
+ args[2], args[3]);
ret = orc_test_compare_output_full (p, flags);
if (!ret) {