source: trunk/Softwares/Dhrystone/src/c/dhry21b.c @ 129

Last change on this file since 129 was 112, checked in by rosiere, 16 years ago

1) Stat_list : fix retire old and new register bug
2) Stat_list : remove read_counter and valid flag, because validation of destination is in retire step (not in commit step)
3) Model : add class Model (cf Morpheo.sim)
4) Allocation : alloc_interface_begin and alloc_interface_end to delete temporary array.
5) Script : add distexe.sh
6) Add Comparator, Multiplier, Divider. But this component are not implemented
7) Software : add Dhrystone

  • Property svn:keywords set to Id
File size: 5.1 KB
Line 
1/*
2 *************************************************************************
3 *
4 *                   "DHRYSTONE" Benchmark Program
5 *                   -----------------------------
6 *
7 *  Version:    C, Version 2.1
8 *
9 *  File:       dhry_2.c (part 3 of 3)
10 *
11 *  Date:       May 25, 1988
12 *
13 *  Author:     Reinhold P. Weicker
14 *
15 *************************************************************************
16 */
17
18#include "dhry.h"
19#include "dhry21.h"
20#include <string.h>
21
22#ifndef REG
23#define REG
24        /* REG becomes defined as empty */
25        /* i.e. no register variables   */
26#else
27#define REG register
28#endif
29
30int     Int_Glob;
31char    Ch_1_Glob;
32
33void
34Proc_6 (Enum_Val_Par, Enum_Ref_Par)
35/*********************************/
36    /* executed once */
37    /* Enum_Val_Par == Ident_3, Enum_Ref_Par becomes Ident_2 */
38
39Enumeration  Enum_Val_Par;
40Enumeration *Enum_Ref_Par;
41{
42  *Enum_Ref_Par = Enum_Val_Par;
43  if (! Func_3 (Enum_Val_Par))
44    /* then, not executed */
45    *Enum_Ref_Par = Ident_4;
46  switch (Enum_Val_Par)
47  {
48    case Ident_1: 
49      *Enum_Ref_Par = Ident_1;
50      break;
51    case Ident_2: 
52      if (Int_Glob > 100)
53        /* then */
54      *Enum_Ref_Par = Ident_1;
55      else *Enum_Ref_Par = Ident_4;
56      break;
57    case Ident_3: /* executed */
58      *Enum_Ref_Par = Ident_2;
59      break;
60    case Ident_4: break;
61    case Ident_5: 
62      *Enum_Ref_Par = Ident_3;
63      break;
64  } /* switch */
65} /* Proc_6 */
66
67void
68Proc_7 (Int_1_Par_Val, Int_2_Par_Val, Int_Par_Ref)
69/**********************************************/
70    /* executed three times                                      */
71    /* first call:      Int_1_Par_Val == 2, Int_2_Par_Val == 3,  */
72    /*                  Int_Par_Ref becomes 7                    */
73    /* second call:     Int_1_Par_Val == 10, Int_2_Par_Val == 5, */
74    /*                  Int_Par_Ref becomes 17                   */
75    /* third call:      Int_1_Par_Val == 6, Int_2_Par_Val == 10, */
76    /*                  Int_Par_Ref becomes 18                   */
77One_Fifty       Int_1_Par_Val;
78One_Fifty       Int_2_Par_Val;
79One_Fifty      *Int_Par_Ref;
80{
81  One_Fifty Int_Loc;
82
83  Int_Loc = Int_1_Par_Val + 2;
84  *Int_Par_Ref = Int_2_Par_Val + Int_Loc;
85} /* Proc_7 */
86
87void
88Proc_8 (Arr_1_Par_Ref, Arr_2_Par_Ref, Int_1_Par_Val, Int_2_Par_Val)
89/*********************************************************************/
90    /* executed once      */
91    /* Int_Par_Val_1 == 3 */
92    /* Int_Par_Val_2 == 7 */
93Arr_1_Dim       Arr_1_Par_Ref;
94Arr_2_Dim       Arr_2_Par_Ref;
95int             Int_1_Par_Val;
96int             Int_2_Par_Val;
97{
98  REG One_Fifty Int_Index;
99  REG One_Fifty Int_Loc;
100
101  Int_Loc = Int_1_Par_Val + 5;
102  Arr_1_Par_Ref [Int_Loc] = Int_2_Par_Val;
103  Arr_1_Par_Ref [Int_Loc+1] = Arr_1_Par_Ref [Int_Loc];
104  Arr_1_Par_Ref [Int_Loc+30] = Int_Loc;
105  for (Int_Index = Int_Loc; Int_Index <= Int_Loc+1; ++Int_Index)
106    Arr_2_Par_Ref [Int_Loc] [Int_Index] = Int_Loc;
107  Arr_2_Par_Ref [Int_Loc] [Int_Loc-1] += 1;
108  Arr_2_Par_Ref [Int_Loc+20] [Int_Loc] = Arr_1_Par_Ref [Int_Loc];
109  Int_Glob = 5;
110} /* Proc_8 */
111
112
113Enumeration Func_1 (Ch_1_Par_Val, Ch_2_Par_Val)
114/*************************************************/
115    /* executed three times                                         */
116    /* first call:      Ch_1_Par_Val == 'H', Ch_2_Par_Val == 'R'    */
117    /* second call:     Ch_1_Par_Val == 'A', Ch_2_Par_Val == 'C'    */
118    /* third call:      Ch_1_Par_Val == 'B', Ch_2_Par_Val == 'C'    */
119
120Capital_Letter   Ch_1_Par_Val;
121Capital_Letter   Ch_2_Par_Val;
122{
123  Capital_Letter        Ch_1_Loc;
124  Capital_Letter        Ch_2_Loc;
125
126  Ch_1_Loc = Ch_1_Par_Val;
127  Ch_2_Loc = Ch_1_Loc;
128  if (Ch_2_Loc != Ch_2_Par_Val)
129    /* then, executed */
130    return (Ident_1);
131  else  /* not executed */
132  {
133    Ch_1_Glob = Ch_1_Loc;
134    return (Ident_2);
135   }
136} /* Func_1 */
137
138
139Boolean Func_2 (Str_1_Par_Ref, Str_2_Par_Ref)
140/*************************************************/
141    /* executed once */
142    /* Str_1_Par_Ref == "DHRYSTONE PROGRAM, 1'ST STRING" */
143    /* Str_2_Par_Ref == "DHRYSTONE PROGRAM, 2'ND STRING" */
144
145Str_30  Str_1_Par_Ref;
146Str_30  Str_2_Par_Ref;
147{
148  REG One_Thirty        Int_Loc;
149      Capital_Letter    Ch_Loc ;
150
151  Int_Loc = 2;
152  while (Int_Loc <= 2) /* loop body executed once */
153    if (Func_1 (Str_1_Par_Ref[Int_Loc],
154                Str_2_Par_Ref[Int_Loc+1]) == Ident_1)
155      /* then, executed */
156    {
157      Ch_Loc = 'A';
158      Int_Loc += 1;
159    } /* if, while */
160  if (Ch_Loc >= 'W' && Ch_Loc < 'Z')
161    /* then, not executed */
162    Int_Loc = 7;
163  if (Ch_Loc == 'R')
164    /* then, not executed */
165    return (true);
166  else /* executed */
167  {
168    if (strcmp (Str_1_Par_Ref, Str_2_Par_Ref) > 0)
169      /* then, not executed */
170    {
171      Int_Loc += 7;
172      Int_Glob = Int_Loc;
173      return (true);
174    }
175    else /* executed */
176      return (false);
177  } /* if Ch_Loc */
178} /* Func_2 */
179
180
181Boolean Func_3 (Enum_Par_Val)
182/***************************/
183    /* executed once        */
184    /* Enum_Par_Val == Ident_3 */
185Enumeration Enum_Par_Val;
186{
187  Enumeration Enum_Loc;
188
189  Enum_Loc = Enum_Par_Val;
190  if (Enum_Loc == Ident_3)
191    /* then, executed */
192    return (true);
193  else /* not executed */
194    return (false);
195} /* Func_3 */
Note: See TracBrowser for help on using the repository browser.