summaryrefslogtreecommitdiff
path: root/wasm2c/benchmarks/dhrystone
diff options
context:
space:
mode:
authorShravan Narayan <shravanrn@gmail.com>2024-06-26 11:30:44 -0500
committerGitHub <noreply@github.com>2024-06-26 09:30:44 -0700
commit0e871afa4aaac9fe0b1f00cb42a59be666657a06 (patch)
tree22c449953033d0ea98200d9117c11419054a762e /wasm2c/benchmarks/dhrystone
parentf820d171654de2dcb8cbf7078b4c98336c8e3c69 (diff)
downloadwabt-0e871afa4aaac9fe0b1f00cb42a59be666657a06.tar.gz
wabt-0e871afa4aaac9fe0b1f00cb42a59be666657a06.tar.bz2
wabt-0e871afa4aaac9fe0b1f00cb42a59be666657a06.zip
wasm2c: Segue optimization for modules with a single unshared memory (#2395)
Diffstat (limited to 'wasm2c/benchmarks/dhrystone')
-rw-r--r--wasm2c/benchmarks/dhrystone/.gitignore5
-rw-r--r--wasm2c/benchmarks/dhrystone/Makefile38
-rwxr-xr-xwasm2c/benchmarks/dhrystone/dhrystone.wasmbin0 -> 33999 bytes
-rw-r--r--wasm2c/benchmarks/dhrystone/main.c265
-rw-r--r--wasm2c/benchmarks/dhrystone/src/README.md23
-rw-r--r--wasm2c/benchmarks/dhrystone/src/dhry.h306
-rw-r--r--wasm2c/benchmarks/dhrystone/src/dhry_1.c485
-rw-r--r--wasm2c/benchmarks/dhrystone/src/dhry_2.c187
8 files changed, 1309 insertions, 0 deletions
diff --git a/wasm2c/benchmarks/dhrystone/.gitignore b/wasm2c/benchmarks/dhrystone/.gitignore
new file mode 100644
index 00000000..7cc06514
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/.gitignore
@@ -0,0 +1,5 @@
+dhrystone_native
+dhrystone
+dhrystone_segue
+dhrystone.h
+dhrystone.c
diff --git a/wasm2c/benchmarks/dhrystone/Makefile b/wasm2c/benchmarks/dhrystone/Makefile
new file mode 100644
index 00000000..b7af5d4b
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/Makefile
@@ -0,0 +1,38 @@
+WABT_ROOT=../../..
+CC=clang
+CFLAGS=-I$(WABT_ROOT)/wasm2c -I $(WABT_ROOT)/third_party/uvwasi/include/ -O3
+CFLAGS_SEGUE=-DWASM_RT_ALLOW_SEGUE=1 -mfsgsbase
+LDFLAGS=-L$(WABT_ROOT)/build/_deps/libuv-build -L$(WABT_ROOT)/build/third_party/uvwasi
+LDLIBS=-luvwasi_a -luv_a -lm
+
+all: benchmark
+
+clean:
+ rm -rf dhrystone dhrystone.wasm dhrystone.c dhrystone.h
+
+dhrystone.wasm: src/dhry_1.c src/dhry_2.c
+ /opt/wasi-sdk/bin/clang -O3 $^ -o $@
+
+dhrystone.c: dhrystone.wasm $(WABT_ROOT)/bin/wasm2c
+ $(WABT_ROOT)/bin/wasm2c $< -o $@ --disable-simd
+
+dhrystone_native: src/dhry_1.c src/dhry_2.c
+ clang -O3 $^ -o $@
+
+dhrystone: main.c dhrystone.c $(WABT_ROOT)/wasm2c/wasm-rt-impl.c $(WABT_ROOT)/wasm2c/wasm-rt-mem-impl.c
+ $(CC) $(LDFLAGS) $(CFLAGS) $^ -o $@ $(LDLIBS)
+
+dhrystone_segue: main.c dhrystone.c $(WABT_ROOT)/wasm2c/wasm-rt-impl.c $(WABT_ROOT)/wasm2c/wasm-rt-mem-impl.c
+ $(CC) $(LDFLAGS) $(CFLAGS) $(CFLAGS_SEGUE) $^ -o $@ $(LDLIBS)
+
+benchmark: dhrystone_native dhrystone dhrystone_segue
+ @echo "Starting Dhrystone benchmark. (Smaller number is better)"
+ @sleep 2
+ @echo "Native"
+ @./dhrystone_native | grep "one run through Dhrystone"
+ @sleep 2
+ @echo "Wasm"
+ @./dhrystone | grep "one run through Dhrystone"
+ @sleep 2
+ @echo "Wasm+Segue"
+ @./dhrystone_segue | grep "one run through Dhrystone"
diff --git a/wasm2c/benchmarks/dhrystone/dhrystone.wasm b/wasm2c/benchmarks/dhrystone/dhrystone.wasm
new file mode 100755
index 00000000..b652757f
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/dhrystone.wasm
Binary files differ
diff --git a/wasm2c/benchmarks/dhrystone/main.c b/wasm2c/benchmarks/dhrystone/main.c
new file mode 100644
index 00000000..5f7350e4
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/main.c
@@ -0,0 +1,265 @@
+#include <stdint.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "uvwasi.h"
+
+#include "dhrystone.h"
+
+struct w2c_wasi__snapshot__preview1 {
+ wasm_rt_memory_t* w2c_memory;
+ uvwasi_t* uvwasi;
+};
+
+#define WASI_SUCCESS 0
+#define WASI_BADF_ERROR 8
+
+typedef uint32_t u32;
+typedef uint64_t u64;
+
+#if WABT_BIG_ENDIAN
+#define MEM_ADDR(mem, addr, n) &(mem)->data[(mem)->size - (addr) - (n)]
+#else
+#define MEM_ADDR(mem, addr, n) &(mem)->data[addr]
+#endif
+
+#define MEM_ADDR_MEMOP(mem, addr, n) MEM_ADDR(mem, addr, n)
+
+#define TRAP(x) (wasm_rt_trap(WASM_RT_TRAP_##x), 0)
+
+#define RANGE_CHECK(mem, offset, len) \
+ if (offset + (uint64_t)len > mem->size) \
+ TRAP(OOB);
+
+static inline void memory_fill(wasm_rt_memory_t* mem, u32 d, u32 val, u32 n) {
+ RANGE_CHECK(mem, d, n);
+ memset(MEM_ADDR(mem, d, n), val, n);
+}
+
+#define MEMCHECK(mem, a, t) RANGE_CHECK(mem, a, sizeof(t))
+
+#ifdef __GNUC__
+#define FORCE_READ_INT(var) __asm__("" ::"r"(var));
+#else
+#define FORCE_READ_INT(var)
+#endif
+
+#define DEFINE_LOAD(name, t1, t2, t3, force_read) \
+ static inline t3 name(wasm_rt_memory_t* mem, u64 addr) { \
+ MEMCHECK(mem, addr, t1); \
+ t1 result; \
+ wasm_rt_memcpy(&result, MEM_ADDR_MEMOP(mem, addr, sizeof(t1)), \
+ sizeof(t1)); \
+ force_read(result); \
+ return (t3)(t2)result; \
+ }
+
+#define DEFINE_STORE(name, t1, t2) \
+ static inline void name(wasm_rt_memory_t* mem, u64 addr, t2 value) { \
+ MEMCHECK(mem, addr, t1); \
+ t1 wrapped = (t1)value; \
+ wasm_rt_memcpy(MEM_ADDR_MEMOP(mem, addr, sizeof(t1)), &wrapped, \
+ sizeof(t1)); \
+ }
+
+DEFINE_LOAD(i8_load, u8, u8, u8, FORCE_READ_INT)
+DEFINE_LOAD(i16_load, u16, u16, u16, FORCE_READ_INT)
+DEFINE_LOAD(i32_load, u32, u32, u32, FORCE_READ_INT)
+DEFINE_LOAD(i64_load, u64, u64, u64, FORCE_READ_INT)
+DEFINE_STORE(i8_store, u8, u8)
+DEFINE_STORE(i16_store, u16, u16)
+DEFINE_STORE(i32_store, u32, u32)
+DEFINE_STORE(i64_store, u64, u64)
+
+u32 w2c_wasi__snapshot__preview1_args_get(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u32 c) {
+ return WASI_SUCCESS;
+}
+u32 w2c_wasi__snapshot__preview1_args_sizes_get(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 str_count,
+ u32 buff_size) {
+ i32_store(a->w2c_memory, str_count, 0);
+ i32_store(a->w2c_memory, buff_size, 0);
+ return WASI_SUCCESS;
+}
+u32 w2c_wasi__snapshot__preview1_fd_prestat_get(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u32 c) {
+ return WASI_BADF_ERROR;
+}
+
+u32 w2c_wasi__snapshot__preview1_fd_write(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 fd,
+ u32 iovs_offset,
+ u32 iovs_len,
+ u32 nwritten) {
+ if (iovs_len > 32)
+ return UVWASI_EINVAL;
+ uvwasi_ciovec_t iovs[iovs_len];
+
+ for (uvwasi_size_t i = 0; i < iovs_len; ++i) {
+ u32 wasi_iovs_i = iovs_offset + i * sizeof(uvwasi_size_t[2]);
+ u32 buf_loc = i32_load(a->w2c_memory, wasi_iovs_i);
+ u32 buf_len = i32_load(a->w2c_memory, wasi_iovs_i + sizeof(uvwasi_size_t));
+ iovs[i].buf = MEM_ADDR(a->w2c_memory, buf_loc, buf_len);
+ iovs[i].buf_len = buf_len;
+ }
+
+ uvwasi_size_t num_written;
+ uvwasi_errno_t ret =
+ uvwasi_fd_write(a->uvwasi, fd, iovs, iovs_len, &num_written);
+ i32_store(a->w2c_memory, nwritten, num_written);
+ return ret;
+}
+
+uint32_t w2c_wasi__snapshot__preview1_fd_fdstat_get(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 fd,
+ u32 stat) {
+ uvwasi_fdstat_t uvstat;
+ uvwasi_errno_t ret = uvwasi_fd_fdstat_get(a->uvwasi, fd, &uvstat);
+ if (ret == UVWASI_ESUCCESS) {
+ memory_fill(a->w2c_memory, stat, 0, 24);
+ i8_store(a->w2c_memory, stat, uvstat.fs_filetype);
+ i16_store(a->w2c_memory, stat + 2, uvstat.fs_flags);
+ i64_store(a->w2c_memory, stat + 8, uvstat.fs_rights_base);
+ i64_store(a->w2c_memory, stat + 16, uvstat.fs_rights_inheriting);
+ }
+ return ret;
+}
+
+u32 w2c_wasi__snapshot__preview1_clock_time_get(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 clk_id,
+ u64 precision,
+ u32 result) {
+ uvwasi_timestamp_t t;
+ uvwasi_errno_t ret = uvwasi_clock_time_get(a->uvwasi, clk_id, precision, &t);
+ i64_store(a->w2c_memory, result, t);
+ return ret;
+}
+
+u32 w2c_wasi__snapshot__preview1_clock_res_get(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 clk_id,
+ u32 result) {
+ uvwasi_timestamp_t t;
+ uvwasi_errno_t ret = uvwasi_clock_res_get(a->uvwasi, clk_id, &t);
+ i64_store(a->w2c_memory, result, t);
+ return ret;
+}
+
+u32 w2c_wasi__snapshot__preview1_fd_seek(struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u64 c,
+ u32 d,
+ u32 e) {
+ printf("fd_seek not implemented\n");
+ abort();
+}
+u32 w2c_wasi__snapshot__preview1_fd_read(struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u32 c,
+ u32 d,
+ u32 e) {
+ printf("fd_read not implemented\n");
+ abort();
+}
+u32 w2c_wasi__snapshot__preview1_fd_close(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b) {
+ printf("fd_close not implemented\n");
+ abort();
+}
+u32 w2c_wasi__snapshot__preview1_fd_fdstat_set_flags(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u32 c) {
+ printf("fd_fdstat_set_flags not implemented\n");
+ abort();
+}
+u32 w2c_wasi__snapshot__preview1_fd_prestat_dir_name(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u32 c,
+ u32 d) {
+ printf("fd_prestat_dir_name not implemented\n");
+ abort();
+}
+u32 w2c_wasi__snapshot__preview1_path_open(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b,
+ u32 c,
+ u32 d,
+ u32 e,
+ u32 f,
+ u64 g,
+ u64 h,
+ u32 i,
+ u32 end) {
+ printf("path_open not implemented\n");
+ abort();
+}
+void w2c_wasi__snapshot__preview1_proc_exit(
+ struct w2c_wasi__snapshot__preview1* a,
+ u32 b) {
+ printf("proc_exit not implemented\n");
+ abort();
+}
+
+int main(int argc, char const* argv[]) {
+ w2c_dhrystone dhrystone;
+ struct w2c_wasi__snapshot__preview1 wasi;
+ uvwasi_t local_uvwasi_state;
+ uvwasi_options_t init_options;
+
+ // pass in standard descriptors
+ init_options.in = 0;
+ init_options.out = 1;
+ init_options.err = 2;
+ init_options.fd_table_size = 10;
+
+ // pass in args and environement
+ extern const char** environ;
+ init_options.argc = argc;
+ init_options.argv = argv;
+ init_options.envp = (const char**)environ;
+
+ // no sandboxing enforced, binary has access to everything user does
+ init_options.preopenc = 2;
+ init_options.preopens = calloc(2, sizeof(uvwasi_preopen_t));
+
+ init_options.preopens[0].mapped_path = "/";
+ init_options.preopens[0].real_path = "/";
+ init_options.preopens[1].mapped_path = "./";
+ init_options.preopens[1].real_path = ".";
+
+ init_options.allocator = NULL;
+
+ wasm_rt_init();
+ uvwasi_errno_t ret = uvwasi_init(&local_uvwasi_state, &init_options);
+
+ if (ret != UVWASI_ESUCCESS) {
+ printf("uvwasi_init failed with error %d\n", ret);
+ exit(1);
+ }
+
+ wasi.w2c_memory = &dhrystone.w2c_memory;
+ wasi.uvwasi = &local_uvwasi_state,
+
+ wasm2c_dhrystone_instantiate(&dhrystone, &wasi);
+
+ w2c_dhrystone_0x5Fstart(&dhrystone);
+
+ wasm2c_dhrystone_free(&dhrystone);
+
+ uvwasi_destroy(&local_uvwasi_state);
+ wasm_rt_free();
+
+ return 0;
+}
diff --git a/wasm2c/benchmarks/dhrystone/src/README.md b/wasm2c/benchmarks/dhrystone/src/README.md
new file mode 100644
index 00000000..30d270e9
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/src/README.md
@@ -0,0 +1,23 @@
+The Dhrystone benchmark: a popular benchmark for CPU/compiler performance
+measurement. Description and sources available
+[here](https://www.netlib.org/benchmark/dhry-c).
+
+# Running the benchmark
+Use the command `make benchmark` to run the benchmark.
+
+This compares the performance of three builds of Dhrystone (1) Native (2) Wasm2c
+(3) Wasm2C + Segue optimization. The Segue optimization is enabled only on
+specific CPU+OS+Compiler combinations. If unsupported on your platform, builds
+(2) and (3) above will be identical
+
+# Sample output
+
+```
+Starting Dhrystone benchmark. (Smaller number is better)
+Native
+Microseconds for one run through Dhrystone: 0.011133
+Wasm
+Microseconds for one run through Dhrystone: 0.013670
+Wasm+Segue
+Microseconds for one run through Dhrystone: 0.008666
+``` \ No newline at end of file
diff --git a/wasm2c/benchmarks/dhrystone/src/dhry.h b/wasm2c/benchmarks/dhrystone/src/dhry.h
new file mode 100644
index 00000000..be0f701e
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/src/dhry.h
@@ -0,0 +1,306 @@
+/*
+ **************************************************************************
+ * DHRYSTONE 2.1 BENCHMARK PC VERSION
+ **************************************************************************
+ *
+ * "DHRYSTONE" Benchmark Program
+ * -----------------------------
+ *
+ * Version: C, Version 2.1
+ *
+ * File: dhry.h (part 1 of 3)
+ *
+ * Date: May 25, 1988
+ *
+ * Author: Reinhold P. Weicker
+ * Siemens AG, AUT E 51
+ * Postfach 3220
+ * 8520 Erlangen
+ * Germany (West)
+ * Phone: [+49]-9131-7-20330
+ * (8-17 Central European Time)
+ * Usenet: ..!mcsun!unido!estevax!weicker
+ *
+ * Original Version (in Ada) published in
+ * "Communications of the ACM" vol. 27., no. 10 (Oct. 1984),
+ * pp. 1013 - 1030, together with the statistics
+ * on which the distribution of statements etc. is based.
+ *
+ * In this C version, the following C library functions are used:
+ * - strcpy, strcmp (inside the measurement loop)
+ * - printf, scanf (outside the measurement loop)
+ * In addition, Berkeley UNIX system calls "times ()" or "time ()"
+ * are used for execution time measurement. For measurements
+ * on other systems, these calls have to be changed.
+ *
+ * Collection of Results:
+ * Reinhold Weicker (address see above) and
+ *
+ * Rick Richardson
+ * PC Research. Inc.
+ * 94 Apple Orchard Drive
+ * Tinton Falls, NJ 07724
+ * Phone: (201) 389-8963 (9-17 EST)
+ * Usenet: ...!uunet!pcrat!rick
+ *
+ * Please send results to Rick Richardson and/or Reinhold Weicker.
+ * Complete information should be given on hardware and software used.
+ * Hardware information includes: Machine type, CPU, type and size
+ * of caches; for microprocessors: clock frequency, memory speed
+ * (number of wait states).
+ * Software information includes: Compiler (and runtime library)
+ * manufacturer and version, compilation switches, OS version.
+ * The Operating System version may give an indication about the
+ * compiler; Dhrystone itself performs no OS calls in the measurement
+ * loop.
+ *
+ * The complete output generated by the program should be mailed
+ * such that at least some checks for correctness can be made.
+ *
+ **************************************************************************
+ *
+ * This version has changes made by Roy Longbottom to conform to a common
+ * format for a series of standard benchmarks for PCs:
+ *
+ * Running time greater than 5 seconds due to inaccuracy of the PC clock.
+ *
+ * Automatic adjustment of run time, no manually inserted parameters.
+ *
+ * Initial display of calibration times to confirm linearity.
+ *
+ * Display of results within one screen (or at a slow speed as the test
+ * progresses) so that it can be seen to have run successfully.
+ *
+ * Facilities to type in details of system used etc.
+ *
+ * All results and details appended to a results file.
+ *
+ *
+ * Roy Longbottom
+ * 101323.2241@compuserve.com
+ *
+ **************************************************************************
+ *
+ * For details of history, changes, other defines, benchmark construction
+ * statistics see official versions from ftp.nosc.mil/pub/aburto where
+ * the latest table of results (dhry.tbl) are available. See also
+ * netlib@ornl.gov
+ *
+ **************************************************************************
+ *
+ * Defines: The following "Defines" are possible:
+ * -DREG=register (default: Not defined)
+ * As an approximation to what an average C programmer
+ * might do, the "register" storage class is applied
+ * (if enabled by -DREG=register)
+ * - for local variables, if they are used (dynamically)
+ * five or more times
+ * - for parameters if they are used (dynamically)
+ * six or more times
+ * Note that an optimal "register" strategy is
+ * compiler-dependent, and that "register" declarations
+ * do not necessarily lead to faster execution.
+ * -DNOSTRUCTASSIGN (default: Not defined)
+ * Define if the C compiler does not support
+ * assignment of structures.
+ * -DNOENUMS (default: Not defined)
+ * Define if the C compiler does not support
+ * enumeration types.
+ ***************************************************************************
+ *
+ * Compilation model and measurement (IMPORTANT):
+ *
+ * This C version of Dhrystone consists of three files:
+ * - dhry.h (this file, containing global definitions and comments)
+ * - dhry_1.c (containing the code corresponding to Ada package Pack_1)
+ * - dhry_2.c (containing the code corresponding to Ada package Pack_2)
+ *
+ * The following "ground rules" apply for measurements:
+ * - Separate compilation
+ * - No procedure merging
+ * - Otherwise, compiler optimizations are allowed but should be indicated
+ * - Default results are those without register declarations
+ * See the companion paper "Rationale for Dhrystone Version 2" for a more
+ * detailed discussion of these ground rules.
+ *
+ * For 16-Bit processors (e.g. 80186, 80286), times for all compilation
+ * models ("small", "medium", "large" etc.) should be given if possible,
+ * together with a definition of these models for the compiler system used.
+ *
+ **************************************************************************
+ * Examples of Pentium Results
+ *
+ * Dhrystone Benchmark Version 2.1 (Language: C)
+ *
+ * Month run 4/1996
+ * PC model Escom
+ * CPU Pentium
+ * Clock MHz 100
+ * Cache 256K
+ * Options Neptune chipset
+ * OS/DOS Windows 95
+ * Compiler Watcom C/ C++ 10.5 Win386
+ * OptLevel -otexan -zp8 -fp5 -5r
+ * Run by Roy Longbottom
+ * From UK
+ * Mail 101323.2241@compuserve.com
+ *
+ * Final values (* implementation-dependent):
+ *
+ * Int_Glob: O.K. 5
+ * Bool_Glob: O.K. 1
+ * Ch_1_Glob: O.K. A
+ * Ch_2_Glob: O.K. B
+ * Arr_1_Glob[8]: O.K. 7
+ * Arr_2_Glob8/7: O.K. 1600010
+ * Ptr_Glob->
+ * Ptr_Comp: * 98008
+ * Discr: O.K. 0
+ * Enum_Comp: O.K. 2
+ * Int_Comp: O.K. 17
+ * Str_Comp: O.K. DHRYSTONE PROGRAM, SOME STRING
+ * Next_Ptr_Glob->
+ * Ptr_Comp: * 98008 same as above
+ * Discr: O.K. 0
+ * Enum_Comp: O.K. 1
+ * Int_Comp: O.K. 18
+ * Str_Comp: O.K. DHRYSTONE PROGRAM, SOME STRING
+ * Int_1_Loc: O.K. 5
+ * Int_2_Loc: O.K. 13
+ * Int_3_Loc: O.K. 7
+ * Enum_Loc: O.K. 1
+ * Str_1_Loc: O.K. DHRYSTONE PROGRAM, 1'ST STRING
+ * Str_2_Loc: O.K. DHRYSTONE PROGRAM, 2'ND STRING
+ *
+ * Register option Selected.
+ *
+ * Microseconds 1 loop: 4.53
+ * Dhrystones / second: 220690
+ * VAX MIPS rating: 125.61
+ *
+ *
+ * Dhrystone Benchmark Version 2.1 (Language: C)
+ *
+ * Month run 4/1996
+ * PC model Escom
+ * CPU Pentium
+ * Clock MHz 100
+ * Cache 256K
+ * Options Neptune chipset
+ * OS/DOS Windows 95
+ * Compiler Watcom C/ C++ 10.5 Win386
+ * OptLevel No optimisation
+ * Run by Roy Longbottom
+ * From UK
+ * Mail 101323.2241@compuserve.com
+ *
+ * Final values (* implementation-dependent):
+ *
+ * Int_Glob: O.K. 5
+ * Bool_Glob: O.K. 1
+ * Ch_1_Glob: O.K. A
+ * Ch_2_Glob: O.K. B
+ * Arr_1_Glob[8]: O.K. 7
+ * Arr_2_Glob8/7: O.K. 320010
+ * Ptr_Glob->
+ * Ptr_Comp: * 98004
+ * Discr: O.K. 0
+ * Enum_Comp: O.K. 2
+ * Int_Comp: O.K. 17
+ * Str_Comp: O.K. DHRYSTONE PROGRAM, SOME STRING
+ * Next_Ptr_Glob->
+ * Ptr_Comp: * 98004 same as above
+ * Discr: O.K. 0
+ * Enum_Comp: O.K. 1
+ * Int_Comp: O.K. 18
+ * Str_Comp: O.K. DHRYSTONE PROGRAM, SOME STRING
+ * Int_1_Loc: O.K. 5
+ * Int_2_Loc: O.K. 13
+ * Int_3_Loc: O.K. 7
+ * Enum_Loc: O.K. 1
+ * Str_1_Loc: O.K. DHRYSTONE PROGRAM, 1'ST STRING
+ * Str_2_Loc: O.K. DHRYSTONE PROGRAM, 2'ND STRING
+ *
+ * Register option Not selected.
+ *
+ * Microseconds 1 loop: 20.06
+ * Dhrystones / second: 49844
+ * VAX MIPS rating: 28.37
+ *
+ **************************************************************************
+ */
+
+/* Compiler and system dependent definitions: */
+
+#ifndef TIME
+#define TIMES
+#endif
+/* Use times(2) time function unless */
+/* explicitly defined otherwise */
+
+#ifdef TIMES
+/* #include <sys/types.h>
+ #include <sys/times.h> */
+/* for "times" */
+#endif
+
+#define Mic_secs_Per_Second 1000000.0
+/* Berkeley UNIX C returns process times in seconds/HZ */
+
+#ifdef NOSTRUCTASSIGN
+#define structassign(d, s) memcpy(&(d), &(s), sizeof(d))
+#else
+#define structassign(d, s) d = s
+#endif
+
+#ifdef NOENUM
+#define Ident_1 0
+#define Ident_2 1
+#define Ident_3 2
+#define Ident_4 3
+#define Ident_5 4
+typedef int Enumeration;
+#else
+typedef enum { Ident_1, Ident_2, Ident_3, Ident_4, Ident_5 } Enumeration;
+#endif
+/* for boolean and enumeration types in Ada, Pascal */
+
+/* General definitions: */
+
+#include <stdio.h>
+#include <string.h>
+
+/* for strcpy, strcmp */
+
+#define Null 0
+/* Value of a Null pointer */
+#define true 1
+#define false 0
+
+typedef int One_Thirty;
+typedef int One_Fifty;
+typedef char Capital_Letter;
+typedef int Boolean;
+typedef char Str_30[31];
+typedef int Arr_1_Dim[50];
+typedef int Arr_2_Dim[50][50];
+
+typedef struct record {
+ struct record *Ptr_Comp;
+ Enumeration Discr;
+ union {
+ struct {
+ Enumeration Enum_Comp;
+ int Int_Comp;
+ char Str_Comp[31];
+ } var_1;
+ struct {
+ Enumeration E_Comp_2;
+ char Str_2_Comp[31];
+ } var_2;
+ struct {
+ char Ch_1_Comp;
+ char Ch_2_Comp;
+ } var_3;
+ } variant;
+} Rec_Type, *Rec_Pointer;
diff --git a/wasm2c/benchmarks/dhrystone/src/dhry_1.c b/wasm2c/benchmarks/dhrystone/src/dhry_1.c
new file mode 100644
index 00000000..fb23dd3a
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/src/dhry_1.c
@@ -0,0 +1,485 @@
+/*
+ *************************************************************************
+ *
+ * "DHRYSTONE" Benchmark Program
+ * -----------------------------
+ *
+ * Version: C, Version 2.1
+ *
+ * File: dhry_1.c (part 2 of 3)
+ *
+ * Date: May 25, 1988
+ *
+ * Author: Reinhold P. Weicker
+ *
+ *************************************************************************
+ */
+
+#include <time.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include "dhry.h"
+
+/* Global Variables: */
+
+Rec_Pointer Ptr_Glob, Next_Ptr_Glob;
+int Int_Glob;
+Boolean Bool_Glob;
+char Ch_1_Glob, Ch_2_Glob;
+int Arr_1_Glob[50];
+int Arr_2_Glob[50][50];
+
+Enumeration
+Func_1(Capital_Letter Ch_1_Par_Val, Capital_Letter Ch_2_Par_Val);
+/*
+forward declaration necessary since Enumeration may not simply be int
+*/
+
+#ifndef ROPT
+#define REG
+/* REG becomes defined as empty */
+/* i.e. no register variables */
+#else
+#define REG register
+#endif
+
+void
+Proc_1(REG Rec_Pointer Ptr_Val_Par);
+void
+Proc_2(One_Fifty *Int_Par_Ref);
+void
+Proc_3(Rec_Pointer *Ptr_Ref_Par);
+void
+Proc_4();
+void
+Proc_5();
+void
+Proc_6(Enumeration Enum_Val_Par, Enumeration *Enum_Ref_Par);
+void
+Proc_7(One_Fifty Int_1_Par_Val, One_Fifty Int_2_Par_Val,
+ One_Fifty *Int_Par_Ref);
+void
+Proc_8(Arr_1_Dim Arr_1_Par_Ref, Arr_2_Dim Arr_2_Par_Ref, int Int_1_Par_Val,
+ int Int_2_Par_Val);
+
+Boolean
+Func_2(Str_30 Str_1_Par_Ref, Str_30 Str_2_Par_Ref);
+
+/* variables for time measurement: */
+
+#define Too_Small_Time 2
+/* Measurements should last at least 2 seconds */
+
+#define BILLION 1000000000L
+#define MILLION 1000000
+struct timespec Begin_Time, End_Time;
+double User_Time;
+
+double Microseconds, Dhrystones_Per_Second, Vax_Mips;
+
+/* end of variables for time measurement */
+
+int
+main(int argc, char *argv[])
+/*****/
+
+/* main program, corresponds to procedures */
+/* Main and Proc_0 in the Ada version */
+{
+ One_Fifty Int_1_Loc;
+ REG One_Fifty Int_2_Loc;
+ One_Fifty Int_3_Loc;
+ REG char Ch_Index;
+ Enumeration Enum_Loc;
+ Str_30 Str_1_Loc;
+ Str_30 Str_2_Loc;
+ REG int Run_Index;
+ REG int Number_Of_Runs;
+ int endit, count = 10;
+ char general[9][80] = { " " };
+
+ /***********************************************************************
+ * Change for compiler and optimisation used *
+ ***********************************************************************/
+
+ Next_Ptr_Glob = (Rec_Pointer)malloc(sizeof(Rec_Type));
+ Ptr_Glob = (Rec_Pointer)malloc(sizeof(Rec_Type));
+
+ Ptr_Glob->Ptr_Comp = Next_Ptr_Glob;
+ Ptr_Glob->Discr = Ident_1;
+ Ptr_Glob->variant.var_1.Enum_Comp = Ident_3;
+ Ptr_Glob->variant.var_1.Int_Comp = 40;
+ strcpy(Ptr_Glob->variant.var_1.Str_Comp, "DHRYSTONE PROGRAM, SOME STRING");
+ strcpy(Str_1_Loc, "DHRYSTONE PROGRAM, 1'ST STRING");
+
+ Arr_2_Glob[8][7] = 10;
+ /* Was missing in published program. Without this statement, */
+ /* Arr_2_Glob [8][7] would have an undefined value. */
+ /* Warning: With 16-Bit processors and Number_Of_Runs > 32000, */
+ /* overflow may occur for this array element. */
+
+ printf("\n");
+ printf("Dhrystone Benchmark, Version 2.1 (Language: C or C++)\n");
+ printf("\n");
+
+ Number_Of_Runs = 5000;
+
+ do {
+
+ Number_Of_Runs = Number_Of_Runs * 2;
+ count = count - 1;
+ Arr_2_Glob[8][7] = 10;
+
+ /***************/
+ /* Start timer */
+ /***************/
+
+ clock_gettime(CLOCK_MONOTONIC, &Begin_Time);
+
+ for (Run_Index = 1; Run_Index <= Number_Of_Runs; ++Run_Index) {
+
+ Proc_5();
+ Proc_4();
+ /* Ch_1_Glob == 'A', Ch_2_Glob == 'B', Bool_Glob == true */
+ Int_1_Loc = 2;
+ Int_2_Loc = 3;
+ strcpy(Str_2_Loc, "DHRYSTONE PROGRAM, 2'ND STRING");
+ Enum_Loc = Ident_2;
+ Bool_Glob = !Func_2(Str_1_Loc, Str_2_Loc);
+ /* Bool_Glob == 1 */
+ while (Int_1_Loc < Int_2_Loc) /* loop body executed once */
+ {
+ Int_3_Loc = 5 * Int_1_Loc - Int_2_Loc;
+ /* Int_3_Loc == 7 */
+ Proc_7(Int_1_Loc, Int_2_Loc, &Int_3_Loc);
+ /* Int_3_Loc == 7 */
+ Int_1_Loc += 1;
+ } /* while */
+ /* Int_1_Loc == 3, Int_2_Loc == 3, Int_3_Loc == 7 */
+ Proc_8(Arr_1_Glob, Arr_2_Glob, Int_1_Loc, Int_3_Loc);
+ /* Int_Glob == 5 */
+ Proc_1(Ptr_Glob);
+ for (Ch_Index = 'A'; Ch_Index <= Ch_2_Glob; ++Ch_Index)
+ /* loop body executed twice */
+ {
+ if (Enum_Loc == Func_1(Ch_Index, 'C'))
+ /* then, not executed */
+ {
+ Proc_6(Ident_1, &Enum_Loc);
+ strcpy(Str_2_Loc, "DHRYSTONE PROGRAM, 3'RD STRING");
+ Int_2_Loc = Run_Index;
+ Int_Glob = Run_Index;
+ }
+ }
+ /* Int_1_Loc == 3, Int_2_Loc == 3, Int_3_Loc == 7 */
+ Int_2_Loc = Int_2_Loc * Int_1_Loc;
+ Int_1_Loc = Int_2_Loc / Int_3_Loc;
+ Int_2_Loc = 7 * (Int_2_Loc - Int_3_Loc) - Int_1_Loc;
+ /* Int_1_Loc == 1, Int_2_Loc == 13, Int_3_Loc == 7 */
+ Proc_2(&Int_1_Loc);
+ /* Int_1_Loc == 5 */
+
+ } /* loop "for Run_Index" */
+
+ /**************/
+ /* Stop timer */
+ /**************/
+
+ clock_gettime(CLOCK_MONOTONIC, &End_Time);
+
+ User_Time = (End_Time.tv_sec - Begin_Time.tv_sec) * MILLION
+ + (End_Time.tv_nsec - Begin_Time.tv_nsec) / 1000;
+ User_Time = User_Time / MILLION; /* convert to seconds */
+
+ printf("%ld runs %lf seconds \n", (long)Number_Of_Runs, User_Time);
+ if (User_Time > 5.0) {
+ count = 0;
+ }
+ else {
+ if (User_Time < 0.1) {
+ Number_Of_Runs = Number_Of_Runs * 5;
+ }
+ }
+ } /* calibrate/run do while */
+ while (count > 0);
+
+ printf("\n");
+ printf("Final values (* implementation-dependent):\n");
+ printf("\n");
+ printf("Int_Glob: ");
+ if (Int_Glob == 5)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Int_Glob);
+
+ printf("Bool_Glob: ");
+ if (Bool_Glob == 1)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d\n", Bool_Glob);
+
+ printf("Ch_1_Glob: ");
+ if (Ch_1_Glob == 'A')
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%c ", Ch_1_Glob);
+
+ printf("Ch_2_Glob: ");
+ if (Ch_2_Glob == 'B')
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%c\n", Ch_2_Glob);
+
+ printf("Arr_1_Glob[8]: ");
+ if (Arr_1_Glob[8] == 7)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Arr_1_Glob[8]);
+
+ printf("Arr_2_Glob8/7: ");
+ if (Arr_2_Glob[8][7] == Number_Of_Runs + 10)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%10d\n", Arr_2_Glob[8][7]);
+
+ printf("Ptr_Glob-> ");
+ printf(" Ptr_Comp: * %p\n", Ptr_Glob->Ptr_Comp);
+
+ printf(" Discr: ");
+ if (Ptr_Glob->Discr == 0)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Ptr_Glob->Discr);
+
+ printf("Enum_Comp: ");
+ if (Ptr_Glob->variant.var_1.Enum_Comp == 2)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d\n", Ptr_Glob->variant.var_1.Enum_Comp);
+
+ printf(" Int_Comp: ");
+ if (Ptr_Glob->variant.var_1.Int_Comp == 17)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Ptr_Glob->variant.var_1.Int_Comp);
+
+ printf("Str_Comp: ");
+ if (strcmp(Ptr_Glob->variant.var_1.Str_Comp,
+ "DHRYSTONE PROGRAM, SOME STRING")
+ == 0)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%s\n", Ptr_Glob->variant.var_1.Str_Comp);
+
+ printf("Next_Ptr_Glob-> ");
+ printf(" Ptr_Comp: * %p", Next_Ptr_Glob->Ptr_Comp);
+ printf(" same as above\n");
+
+ printf(" Discr: ");
+ if (Next_Ptr_Glob->Discr == 0)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Next_Ptr_Glob->Discr);
+
+ printf("Enum_Comp: ");
+ if (Next_Ptr_Glob->variant.var_1.Enum_Comp == 1)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d\n", Next_Ptr_Glob->variant.var_1.Enum_Comp);
+
+ printf(" Int_Comp: ");
+ if (Next_Ptr_Glob->variant.var_1.Int_Comp == 18)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Next_Ptr_Glob->variant.var_1.Int_Comp);
+
+ printf("Str_Comp: ");
+ if (strcmp(Next_Ptr_Glob->variant.var_1.Str_Comp,
+ "DHRYSTONE PROGRAM, SOME STRING")
+ == 0)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%s\n", Next_Ptr_Glob->variant.var_1.Str_Comp);
+
+ printf("Int_1_Loc: ");
+ if (Int_1_Loc == 5)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Int_1_Loc);
+
+ printf("Int_2_Loc: ");
+ if (Int_2_Loc == 13)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d\n", Int_2_Loc);
+
+ printf("Int_3_Loc: ");
+ if (Int_3_Loc == 7)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d ", Int_3_Loc);
+
+ printf("Enum_Loc: ");
+ if (Enum_Loc == 1)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%d\n", Enum_Loc);
+
+ printf("Str_1_Loc: ");
+ if (strcmp(Str_1_Loc, "DHRYSTONE PROGRAM, 1'ST STRING") == 0)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%s\n", Str_1_Loc);
+
+ printf("Str_2_Loc: ");
+ if (strcmp(Str_2_Loc, "DHRYSTONE PROGRAM, 2'ND STRING") == 0)
+ printf("O.K. ");
+ else
+ printf("WRONG ");
+ printf("%s\n", Str_2_Loc);
+
+ printf("\n");
+
+ if (User_Time < Too_Small_Time) {
+ printf("Measured time too small to obtain meaningful results\n");
+ printf("Please increase number of runs\n");
+ printf("\n");
+ }
+ else {
+ Microseconds = User_Time * Mic_secs_Per_Second / (double)Number_Of_Runs;
+ Dhrystones_Per_Second = (double)Number_Of_Runs / User_Time;
+ Vax_Mips = Dhrystones_Per_Second / 1757.0;
+
+ printf("Microseconds for one run through Dhrystone: ");
+ printf("%lf \n", Microseconds);
+ printf("Dhrystones per Second: ");
+ printf("%lf \n", Dhrystones_Per_Second);
+ printf("VAX MIPS rating = ");
+ printf("%lf \n", Vax_Mips);
+ printf("\n");
+ }
+
+ free(Next_Ptr_Glob);
+ free(Ptr_Glob);
+ return 0;
+}
+
+void
+Proc_1(REG Rec_Pointer Ptr_Val_Par)
+/******************/
+
+/* executed once */
+{
+ REG Rec_Pointer Next_Record = Ptr_Val_Par->Ptr_Comp;
+ /* == Ptr_Glob_Next */
+ /* Local variable, initialized with Ptr_Val_Par->Ptr_Comp, */
+ /* corresponds to "rename" in Ada, "with" in Pascal */
+
+ structassign(*Ptr_Val_Par->Ptr_Comp, *Ptr_Glob);
+ Ptr_Val_Par->variant.var_1.Int_Comp = 5;
+ Next_Record->variant.var_1.Int_Comp = Ptr_Val_Par->variant.var_1.Int_Comp;
+ Next_Record->Ptr_Comp = Ptr_Val_Par->Ptr_Comp;
+ Proc_3(&Next_Record->Ptr_Comp);
+ /* Ptr_Val_Par->Ptr_Comp->Ptr_Comp
+ == Ptr_Glob->Ptr_Comp */
+ if (Next_Record->Discr == Ident_1)
+ /* then, executed */
+ {
+ Next_Record->variant.var_1.Int_Comp = 6;
+ Proc_6(Ptr_Val_Par->variant.var_1.Enum_Comp,
+ &Next_Record->variant.var_1.Enum_Comp);
+ Next_Record->Ptr_Comp = Ptr_Glob->Ptr_Comp;
+ Proc_7(Next_Record->variant.var_1.Int_Comp, 10,
+ &Next_Record->variant.var_1.Int_Comp);
+ }
+ else { /* not executed */
+ structassign(*Ptr_Val_Par, *Ptr_Val_Par->Ptr_Comp);
+ }
+} /* Proc_1 */
+
+void
+Proc_2(One_Fifty *Int_Par_Ref)
+/******************/
+/* executed once */
+/* *Int_Par_Ref == 1, becomes 4 */
+
+{
+ One_Fifty Int_Loc;
+ Enumeration Enum_Loc;
+
+ Int_Loc = *Int_Par_Ref + 10;
+ do /* executed once */
+ if (Ch_1_Glob == 'A')
+ /* then, executed */
+ {
+ Int_Loc -= 1;
+ *Int_Par_Ref = Int_Loc - Int_Glob;
+ Enum_Loc = Ident_1;
+ } /* if */
+ while (Enum_Loc != Ident_1); /* true */
+} /* Proc_2 */
+
+void
+Proc_3(Rec_Pointer *Ptr_Ref_Par)
+/******************/
+/* executed once */
+/* Ptr_Ref_Par becomes Ptr_Glob */
+
+{
+ if (Ptr_Glob != Null)
+ /* then, executed */
+ *Ptr_Ref_Par = Ptr_Glob->Ptr_Comp;
+ Proc_7(10, Int_Glob, &Ptr_Glob->variant.var_1.Int_Comp);
+} /* Proc_3 */
+
+void
+Proc_4() /* without parameters */
+/*******/
+/* executed once */
+{
+ Boolean Bool_Loc;
+
+ Bool_Loc = Ch_1_Glob == 'A';
+ Bool_Glob = Bool_Loc | Bool_Glob;
+ Ch_2_Glob = 'B';
+} /* Proc_4 */
+
+void
+Proc_5() /* without parameters */
+/*******/
+/* executed once */
+{
+ Ch_1_Glob = 'A';
+ Bool_Glob = false;
+} /* Proc_5 */
+
+/* Procedure for the assignment of structures, */
+/* if the C compiler doesn't support this feature */
+#ifdef NOSTRUCTASSIGN
+memcpy(d, s, l) register char *d;
+register char *s;
+register int l;
+{
+ while (l--)
+ *d++ = *s++;
+}
+#endif
diff --git a/wasm2c/benchmarks/dhrystone/src/dhry_2.c b/wasm2c/benchmarks/dhrystone/src/dhry_2.c
new file mode 100644
index 00000000..276785cb
--- /dev/null
+++ b/wasm2c/benchmarks/dhrystone/src/dhry_2.c
@@ -0,0 +1,187 @@
+/*
+ *************************************************************************
+ *
+ * "DHRYSTONE" Benchmark Program
+ * -----------------------------
+ *
+ * Version: C, Version 2.1
+ *
+ * File: dhry_2.c (part 3 of 3)
+ *
+ * Date: May 25, 1988
+ *
+ * Author: Reinhold P. Weicker
+ *
+ *************************************************************************
+ */
+
+#include "dhry.h"
+
+#ifndef REG
+#define REG
+/* REG becomes defined as empty */
+/* i.e. no register variables */
+#else
+#define REG register
+#endif
+
+extern int Int_Glob;
+extern char Ch_1_Glob;
+
+Boolean
+Func_3(Enumeration Enum_Par_Val);
+
+void
+Proc_6(Enumeration Enum_Val_Par, Enumeration *Enum_Ref_Par)
+/*********************************/
+/* executed once */
+/* Enum_Val_Par == Ident_3, Enum_Ref_Par becomes Ident_2 */
+
+{
+ *Enum_Ref_Par = Enum_Val_Par;
+ if (!Func_3(Enum_Val_Par))
+ /* then, not executed */
+ *Enum_Ref_Par = Ident_4;
+ switch (Enum_Val_Par) {
+ case Ident_1:
+ *Enum_Ref_Par = Ident_1;
+ break;
+ case Ident_2:
+ if (Int_Glob > 100)
+ /* then */
+ *Enum_Ref_Par = Ident_1;
+ else
+ *Enum_Ref_Par = Ident_4;
+ break;
+ case Ident_3: /* executed */
+ *Enum_Ref_Par = Ident_2;
+ break;
+ case Ident_4:
+ break;
+ case Ident_5:
+ *Enum_Ref_Par = Ident_3;
+ break;
+ } /* switch */
+} /* Proc_6 */
+
+void
+Proc_7(One_Fifty Int_1_Par_Val, One_Fifty Int_2_Par_Val, One_Fifty *Int_Par_Ref)
+/**********************************************/
+/* executed three times */
+/* first call: Int_1_Par_Val == 2, Int_2_Par_Val == 3, */
+/* Int_Par_Ref becomes 7 */
+/* second call: Int_1_Par_Val == 10, Int_2_Par_Val == 5, */
+/* Int_Par_Ref becomes 17 */
+/* third call: Int_1_Par_Val == 6, Int_2_Par_Val == 10, */
+/* Int_Par_Ref becomes 18 */
+
+{
+ One_Fifty Int_Loc;
+
+ Int_Loc = Int_1_Par_Val + 2;
+ *Int_Par_Ref = Int_2_Par_Val + Int_Loc;
+} /* Proc_7 */
+
+void
+Proc_8(Arr_1_Dim Arr_1_Par_Ref, Arr_2_Dim Arr_2_Par_Ref, int Int_1_Par_Val,
+ int Int_2_Par_Val)
+/*********************************************************************/
+/* executed once */
+/* Int_Par_Val_1 == 3 */
+/* Int_Par_Val_2 == 7 */
+
+{
+ REG One_Fifty Int_Index;
+ REG One_Fifty Int_Loc;
+
+ Int_Loc = Int_1_Par_Val + 5;
+ Arr_1_Par_Ref[Int_Loc] = Int_2_Par_Val;
+ Arr_1_Par_Ref[Int_Loc + 1] = Arr_1_Par_Ref[Int_Loc];
+ Arr_1_Par_Ref[Int_Loc + 30] = Int_Loc;
+ for (Int_Index = Int_Loc; Int_Index <= Int_Loc + 1; ++Int_Index)
+ Arr_2_Par_Ref[Int_Loc][Int_Index] = Int_Loc;
+ Arr_2_Par_Ref[Int_Loc][Int_Loc - 1] += 1;
+ Arr_2_Par_Ref[Int_Loc + 20][Int_Loc] = Arr_1_Par_Ref[Int_Loc];
+ Int_Glob = 5;
+} /* Proc_8 */
+
+Enumeration
+Func_1(Capital_Letter Ch_1_Par_Val, Capital_Letter Ch_2_Par_Val)
+/*************************************************/
+/* executed three times */
+/* first call: Ch_1_Par_Val == 'H', Ch_2_Par_Val == 'R' */
+/* second call: Ch_1_Par_Val == 'A', Ch_2_Par_Val == 'C' */
+/* third call: Ch_1_Par_Val == 'B', Ch_2_Par_Val == 'C' */
+
+{
+ Capital_Letter Ch_1_Loc;
+ Capital_Letter Ch_2_Loc;
+
+ Ch_1_Loc = Ch_1_Par_Val;
+ Ch_2_Loc = Ch_1_Loc;
+ if (Ch_2_Loc != Ch_2_Par_Val)
+ /* then, executed */
+ return (Ident_1);
+ else /* not executed */
+ {
+ Ch_1_Glob = Ch_1_Loc;
+ return (Ident_2);
+ }
+} /* Func_1 */
+
+Boolean
+Func_2(Str_30 Str_1_Par_Ref, Str_30 Str_2_Par_Ref)
+/*************************************************/
+/* executed once */
+/* Str_1_Par_Ref == "DHRYSTONE PROGRAM, 1'ST STRING" */
+/* Str_2_Par_Ref == "DHRYSTONE PROGRAM, 2'ND STRING" */
+
+{
+ REG One_Thirty Int_Loc;
+ Capital_Letter Ch_Loc;
+
+ Int_Loc = 2;
+ while (Int_Loc <= 2) /* loop body executed once */
+ if (Func_1(Str_1_Par_Ref[Int_Loc], Str_2_Par_Ref[Int_Loc + 1])
+ == Ident_1)
+ /* then, executed */
+ {
+ Ch_Loc = 'A';
+ Int_Loc += 1;
+ } /* if, while */
+ if (Ch_Loc >= 'W' && Ch_Loc < 'Z')
+ /* then, not executed */
+ Int_Loc = 7;
+ if (Ch_Loc == 'R')
+ /* then, not executed */
+ return (true);
+ else /* executed */
+ {
+ if (strcmp(Str_1_Par_Ref, Str_2_Par_Ref) > 0)
+ /* then, not executed */
+ {
+ Int_Loc += 7;
+ Int_Glob = Int_Loc;
+ return (true);
+ }
+ else /* executed */
+ return (false);
+ } /* if Ch_Loc */
+} /* Func_2 */
+
+Boolean
+Func_3(Enumeration Enum_Par_Val)
+/***************************/
+/* executed once */
+/* Enum_Par_Val == Ident_3 */
+
+{
+ Enumeration Enum_Loc;
+
+ Enum_Loc = Enum_Par_Val;
+ if (Enum_Loc == Ident_3)
+ /* then, executed */
+ return (true);
+ else /* not executed */
+ return (false);
+} /* Func_3 */