diff options
-rw-r--r-- | orc-test/orctest.c | 21 | ||||
-rw-r--r-- | orc-test/orctest.h | 2 | ||||
-rw-r--r-- | orc/orcopcodes.c | 2 | ||||
-rw-r--r-- | testsuite/Makefile.am | 1 | ||||
-rw-r--r-- | testsuite/perf_opcodes_sys.c | 2 | ||||
-rw-r--r-- | testsuite/perf_opcodes_sys_compare.c | 81 | ||||
-rw-r--r-- | testsuite/perf_parse.c | 4 | ||||
-rw-r--r-- | testsuite/perf_parse_compare.c | 94 |
8 files changed, 197 insertions, 10 deletions
diff --git a/orc-test/orctest.c b/orc-test/orctest.c index 8ce24c9..07bb334 100644 --- a/orc-test/orctest.c +++ b/orc-test/orctest.c @@ -801,10 +801,16 @@ orc_test_get_program_for_opcode_param (OrcStaticOpcode *opcode) return p; } - void orc_test_performance (OrcProgram *program, int flags) { + orc_test_performance_full (program, flags, NULL); +} + +double +orc_test_performance_full (OrcProgram *program, int flags, + const char *target_name) +{ OrcExecutor *ex; int n; int m; @@ -815,20 +821,21 @@ orc_test_performance (OrcProgram *program, int flags) OrcCompileResult result; OrcProfile prof; double ave, std; + OrcTarget *target; ORC_DEBUG ("got here"); + target = orc_target_get_by_name (target_name); + if (!(flags & ORC_TEST_FLAGS_BACKUP)) { - OrcTarget *target; unsigned int flags; - target = orc_target_get_default (); flags = orc_target_get_default_flags (target); result = orc_program_compile_full (program, target, flags); if (!ORC_COMPILE_RESULT_IS_SUCCESSFUL(result)) { - printf("compile failed\n"); - return; + //printf("compile failed\n"); + return 0; } } @@ -891,7 +898,7 @@ orc_test_performance (OrcProgram *program, int flags) ORC_DEBUG ("done running"); orc_profile_get_ave_std (&prof, &ave, &std); - printf("%g %g\n", ave/(n*m), std/(n*m)); + //printf("%g %g\n", ave/(n*m), std/(n*m)); for(i=0;i<4;i++){ if (dest_exec[i]) orc_array_free (dest_exec[i]); @@ -903,6 +910,6 @@ orc_test_performance (OrcProgram *program, int flags) orc_executor_free (ex); - return; + return ave/(n*m); } diff --git a/orc-test/orctest.h b/orc-test/orctest.h index 325d573..55188de 100644 --- a/orc-test/orctest.h +++ b/orc-test/orctest.h @@ -30,6 +30,8 @@ OrcProgram *orc_test_get_program_for_opcode_const (OrcStaticOpcode *opcode); OrcProgram *orc_test_get_program_for_opcode_param (OrcStaticOpcode *opcode); void orc_test_performance (OrcProgram *program, int flags); +double orc_test_performance_full (OrcProgram *program, int flags, + const char *target); ORC_END_DECLS diff --git a/orc/orcopcodes.c b/orc/orcopcodes.c index a777989..2e7d30e 100644 --- a/orc/orcopcodes.c +++ b/orc/orcopcodes.c @@ -61,6 +61,8 @@ orc_target_get_by_name (const char *name) { int i; + if (name == NULL) return default_target; + for(i=0;i<n_targets;i++){ if (strcmp (name, targets[i]->name) == 0) { return targets[i]; diff --git a/testsuite/Makefile.am b/testsuite/Makefile.am index 3a6f3d8..f68200a 100644 --- a/testsuite/Makefile.am +++ b/testsuite/Makefile.am @@ -9,6 +9,7 @@ TESTS = \ exec_opcodes_sys \ exec_parse \ perf_opcodes_sys perf_parse \ + perf_opcodes_sys_compare perf_parse_compare \ memcpy_speed \ abi diff --git a/testsuite/perf_opcodes_sys.c b/testsuite/perf_opcodes_sys.c index b49be47..074740e 100644 --- a/testsuite/perf_opcodes_sys.c +++ b/testsuite/perf_opcodes_sys.c @@ -70,7 +70,7 @@ test_opcode_src (OrcStaticOpcode *opcode) orc_program_append_str (p, opcode->name, "d1", "s1", "s2"); } - orc_test_performance (p, flags); + printf("%g\n", orc_test_performance_full (p, flags, NULL)); orc_program_free (p); } diff --git a/testsuite/perf_opcodes_sys_compare.c b/testsuite/perf_opcodes_sys_compare.c new file mode 100644 index 0000000..1fdf76f --- /dev/null +++ b/testsuite/perf_opcodes_sys_compare.c @@ -0,0 +1,81 @@ + +#include "config.h" + +#include <stdio.h> + +#include <orc/orc.h> +#include <orc-test/orctest.h> + + +int error = FALSE; + +void test_opcode_src (OrcStaticOpcode *opcode); + +int +main (int argc, char *argv[]) +{ + int i; + OrcOpcodeSet *opcode_set; + + orc_test_init(); + orc_init(); + + opcode_set = orc_opcode_set_get ("sys"); + + for(i=0;i<opcode_set->n_opcodes;i++){ + //printf("opcode_%-20s ", opcode_set->opcodes[i].name); + test_opcode_src (opcode_set->opcodes + i); + } + + if (error) return 1; + return 0; +} + +void +test_opcode_src (OrcStaticOpcode *opcode) +{ + OrcProgram *p; + char s[40]; + int flags = 0; + double perf_mmx, perf_sse; + + p = orc_program_new (); + if (opcode->flags & ORC_STATIC_OPCODE_ACCUMULATOR) { + orc_program_add_accumulator (p, opcode->dest_size[0], "d1"); + } else { + 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"); + } + orc_program_add_source (p, opcode->src_size[0], "s1"); + if (opcode->src_size[1] != 0) { + if (opcode->flags & ORC_STATIC_OPCODE_SCALAR) { + orc_program_add_constant (p, opcode->src_size[1], 1, "s2"); + } else { + orc_program_add_source (p, opcode->src_size[1], "s2"); + } + } + + if ((opcode->flags & ORC_STATIC_OPCODE_FLOAT_SRC) || + (opcode->flags & ORC_STATIC_OPCODE_FLOAT_DEST)) { + flags = ORC_TEST_FLAGS_FLOAT; + } + + sprintf(s, "test_s_%s ", opcode->name); + orc_program_set_name (p, s); + + if (opcode->dest_size[1] != 0) { + orc_program_append_dds_str (p, opcode->name, "d1", "d2", "s1"); + } else { + orc_program_append_str (p, opcode->name, "d1", "s1", "s2"); + } + + perf_mmx = orc_test_performance_full (p, flags, "mmx"); + perf_sse = orc_test_performance_full (p, flags, "sse"); + + printf("%g %g\n", perf_mmx, perf_sse); + + orc_program_free (p); +} + diff --git a/testsuite/perf_parse.c b/testsuite/perf_parse.c index 7eccafe..731c142 100644 --- a/testsuite/perf_parse.c +++ b/testsuite/perf_parse.c @@ -43,8 +43,8 @@ main (int argc, char *argv[]) n = orc_parse (code, &programs); for(i=0;i<n;i++){ - printf("%-30s ", programs[i]->name); - orc_test_performance (programs[i], 0); + printf("%-30s %g\n", programs[i]->name, + orc_test_performance_full (programs[i], 0, NULL)); } if (error) return 1; diff --git a/testsuite/perf_parse_compare.c b/testsuite/perf_parse_compare.c new file mode 100644 index 0000000..c0d4d76 --- /dev/null +++ b/testsuite/perf_parse_compare.c @@ -0,0 +1,94 @@ + +#include <orc/orc.h> +#include <orc-test/orctest.h> +#include <orc/orcparse.h> + +#include <stdio.h> +#include <stdlib.h> + +static char * read_file (const char *filename); +void output_code (OrcProgram *p, FILE *output); +void output_code_header (OrcProgram *p, FILE *output); +void output_code_test (OrcProgram *p, FILE *output); + +int error = FALSE; + +int +main (int argc, char *argv[]) +{ + char *code; + int n; + int i; + OrcProgram **programs; + const char *filename = NULL; + + orc_init (); + orc_test_init (); + + if (argc >= 2) { + filename = argv[1]; + } + if (filename == NULL) { + filename = getenv ("testfile"); + } + if (filename == NULL) { + filename = "test.orc"; + } + code = read_file (filename); + if (!code) { + printf("perf_parse <file.orc>\n"); + exit(1); + } + + n = orc_parse (code, &programs); + + for(i=0;i<n;i++){ + double perf_mmx; + double perf_sse; + perf_mmx = orc_test_performance_full (programs[i], 0, "mmx"); + perf_sse = orc_test_performance_full (programs[i], 0, "sse"); + printf("%g %g\n", perf_mmx, perf_sse); + } + + if (error) return 1; + return 0; +} + + +static char * +read_file (const char *filename) +{ + FILE *file = NULL; + char *contents = NULL; + long size; + int ret; + + file = fopen (filename, "r"); + if (file == NULL) return NULL; + + ret = fseek (file, 0, SEEK_END); + if (ret < 0) goto bail; + + size = ftell (file); + if (size < 0) goto bail; + + ret = fseek (file, 0, SEEK_SET); + if (ret < 0) goto bail; + + contents = malloc (size + 1); + if (contents == NULL) goto bail; + + ret = fread (contents, size, 1, file); + if (ret < 0) goto bail; + + contents[size] = 0; + + return contents; +bail: + /* something failed */ + if (file) fclose (file); + if (contents) free (contents); + + return NULL; +} + |