⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dhry2.cpp

📁 一个硬件测试工具的源代码
💻 CPP
字号:
#include <stdio.h>
#include <stdlib.h>
#include <sys/timeb.h>
#include <string.h>
#include "dhry2.h"


#define Null 0 
#define true  1
#define false 0
#define REG
#define structassign(d, s)      memcpy(&(d), &(s), sizeof(d))

/*typedef enum Enumeration {Ident_1, Ident_2, Ident_3, Ident_4, Ident_5}  Enum ; 
typedef unsigned long     One_Thirty;
typedef unsigned long     One_Fifty;   
typedef char    Capital_Letter;
typedef char    Str_30 [61]; //this was 31
typedef unsigned long     Arr_1_Dim [100];		//originally this was set to 50
typedef unsigned long     Arr_2_Dim [100] [100];
 
typedef struct record 
     {
     struct record *Ptr_Comp;
     Enumeration    Discr;
     union {
           struct {
                   Enumeration Enum_Comp;
                   unsigned long         Int_Comp;
                   char        Str_Comp [61];
                   } var_1;
           struct {
                   Enumeration E_Comp_2;
                   char        Str_2_Comp [61];
                   } var_2;
           struct {
                   char        Ch_1_Comp;
                   char        Ch_2_Comp;
                   } var_3;
           } variant;
       } Rec_Type, *Rec_Pointer;

*/
//const unsigned long Too_Small_Time = 2000;
//Rec_Pointer     Ptr_Glob=0;
//Rec_Pointer		Next_Ptr_Glob=0;
//unsigned long             Int_Glob=0;
//bool         Bool_Glob=0;
//char            Ch_1_Glob=' ';
//char			Ch_2_Glob=' ';
//unsigned long             Arr_1_Glob [100];
//unsigned long             Arr_2_Glob [100] [100]; //originally this was 50

//bool Reg = false;
//#define REG
//struct _timeb   Begin_Time,
//                End_Time;  
//unsigned long   User_Time=0;
//unsigned long   Microseconds=0,
  //              Dhrystones_Per_Second=0;
 
Enumeration CDhryApp::Func_1( Capital_Letter Ch_1_Par_Val,  Capital_Letter Ch_2_Par_Val)
 {
   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 */
 
bool CDhryApp::Func_3 (Enumeration Enum_Par_Val)

 {
   Enumeration Enum_Loc;
 
   Enum_Loc = Enum_Par_Val;
   if (Enum_Loc == Ident_3)
     /* then, executed */
     return (true);
   else /* not executed */
     return (false);
 } /* Func_3 */


 void CDhryApp::Proc_6 (Enumeration Enum_Val_Par, Enumeration *Enum_Ref_Par)
 /*********************************/
     /* executed once */
     /* Enum_Val_Par == Ident_3, Enum_Ref_Par becomes Ident_2 */
 
 //Enumeration  Enum_Val_Par;
 //Enumeration *Enum_Ref_Par;
 {
   *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) //opriginally 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 CDhryApp::Proc_7 ( One_Fifty Int_1_Par_Val,  One_Fifty Int_2_Par_Val,  One_Fifty *Int_Par_Ref)
 /**********************************************/
     /* executed three _ftime                                      */ 
     /* 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 CDhryApp::Proc_8 (Arr_1_Dim Arr_1_Par_Ref, Arr_2_Dim Arr_2_Par_Ref,  unsigned long Int_1_Par_Val,  unsigned long Int_2_Par_Val)
 /*********************************************************************/
     /* executed once      */
     /* Int_Par_Val_1 == 3 */
     /* Int_Par_Val_2 == 7 */
 {
   REG One_Fifty Int_Index=0;
   REG One_Fifty Int_Loc=0;
 
   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 */
 
 
 
 
 
 bool CDhryApp::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" */
 
 //  Str_30 Str_1_Par_Ref;
 //Str_30  Str_2_Par_Ref;
 {
   REG One_Thirty        Int_Loc=0;
       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 */
 
 
 
 
 /*
  ****************************************************************************
  *
  *                   "DHRYSTONE" Benchmark Program
  *                                                
  *                                                                            
  *  Version:    C, Version 2.1
  *                                                                            
  *  File:       dhry_1.c (part 2 of 3)
  *
  *  Date:       May 25, 1988
  *
  *  Author:     Reinhold P. Weicker
  *
  ****************************************************************************
  */

 


 /* end of variables for time measurement */
 
 void CDhryApp::Proc_5 () /* without parameters */
 /*******/
     /* executed once */
 {
   Ch_1_Glob = 'A';
   Bool_Glob = false;
 } /* Proc_5 */
 
 void CDhryApp::Proc_4 () /* without parameters */
 /*******/
     /* executed once */
 {
   bool Bool_Loc;
 
   Bool_Loc = Ch_1_Glob == 'A';
   Bool_Glob = Bool_Loc | Bool_Glob;
   Ch_2_Glob = 'B';
 } /* Proc_4*/


 void CDhryApp::Proc_3 (Rec_Pointer Ptr_Ref_Par)
 /******************/
     /* executed once */
     /* Ptr_Ref_Par becomes Ptr_Glob */
 
 //Rec_Pointer *Ptr_Ref_Par;
 
 {
   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 CDhryApp::Proc_2 (One_Fifty Int_Par_Ref)
 /******************/
     /* executed once */
     /* *Int_Par_Ref == 1, becomes 4 */
 
 //One_Fifty   *Int_Par_Ref;
 {
   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 CDhryApp::Proc_1 (REG Rec_Pointer Ptr_Val_Par)
 /******************/
 
 // 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 */
 
 
 
unsigned long CDhryApp::main(unsigned long Number_Of_Runs)
 {
         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   unsigned long   Run_Index;
 
   /* Initializations */
Ptr_Glob=0;
Next_Ptr_Glob=0;
Int_Glob=0;
Bool_Glob=0;
Ch_1_Glob=' ';
Ch_2_Glob=' ';
Arr_1_Glob [100];
Arr_2_Glob [100] [100]; //originally was set to 50
//User_Time=0;
 
   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.                   */
 
   /***************/
   /* Start timer */
   /***************/
  
//   _ftime (&Begin_Time);

	
   
	Run_Index=1;
   while (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" */
 
   
//   _ftime (&End_Time);
	//free (Func_1);
	delete (Next_Ptr_Glob);
	delete (Ptr_Glob);
 
  //  User_Time = 1000*(End_Time.time-Begin_Time.time)+(End_Time.millitm-Begin_Time.millitm);
 
 
    //return ((Number_Of_Runs)/(User_Time+1));
	return (Number_Of_Runs);
}
 
 

 
 
 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -