home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Meeting Pearls 3
/
Meeting_Pearls_III.iso
/
Pearls
/
bench
/
Dhrystone
/
source
/
dhrystone1.c
next >
Wrap
C/C++ Source or Header
|
1995-06-04
|
7KB
|
382 lines
/* Accuracy of timings and human fatigue controlled by next two lines */
/*#define LOOPS 50000 /* Use this for slow or 16 bit machines */
#define LOOPS 100000 /* Use this for faster machines */
/*#define LOOPS 5000000 /* Use THIS with a 68040 ! */
/* Compiler dependent options */
#undef NOENUM /* Define if compiler has no enum's */
#undef NOSTRUCTASSIGN /* Define if compiler can't assign structures */
/* define only one of the next two defines */
#define TIME /* Use time(2) time function */
/* define the granularity of your times(2) function (when used) */
#define HZ 1000 /* times(2) returns 1/60 second (most) */
/* #define HZ 100 /* times(2) returns 1/100 second (WECo) */
/* for compatibility with goofed up version */
#define GOOF /* Define GOOF if you want version 1.0 or */
/* don't define for version 1.1 */
#ifdef GOOF
char Ver[] = "$VER: Dhrystone 1.0 68000+ (29.5.95)";
char Version[] = "1.0";
#else
char Ver[] = "$VER: Dhrystone 1.1 68000+ (29.5.95)";
char Version[] = "1.1";
#endif
#ifdef NOSTRUCTASSIGN
#define structassign(d, s) memcpy(&(d), &(s), sizeof(d))
#else
#define structassign(d, s) d = s
#endif
#ifdef NOENUM
#define Ident1 1
#define Ident2 2
#define Ident3 3
#define Ident4 4
#define Ident5 5
typedef int Enumeration;
#else
typedef enum {Ident1, Ident2, Ident3, Ident4, Ident5} Enumeration;
#endif
typedef int OneToThirty;
typedef int OneToFifty;
typedef char CapitalLetter;
typedef char String30[31];
typedef int Array1Dim[51];
typedef int Array2Dim[51][51];
struct Record
{
struct Record *PtrComp;
Enumeration Discr;
Enumeration EnumComp;
OneToFifty intComp;
String30 StringComp;
};
typedef struct Record RecordType;
typedef RecordType * RecordPtr;
typedef int boolean;
#define NULL 0
#define TRUE 1
#define FALSE 0
#ifndef REG
#define REG
#endif
extern Enumeration Func1();
extern boolean Func2();
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* #include <sys/types.h> */
#include <time.h>
/*
* Package 1
*/
int intGlob;
boolean BoolGlob;
char Char1Glob;
char Char2Glob;
Array1Dim Array1Glob;
Array2Dim Array2Glob;
RecordPtr PtrGlb;
RecordPtr PtrGlbNext;
Proc0(void)
{
unsigned long time1,time2,time3;
OneToFifty intLoc1;
REG OneToFifty intLoc2;
OneToFifty intLoc3;
REG char CharLoc;
REG char CharIndex;
Enumeration EnumLoc;
String30 String1Loc;
String30 String2Loc;
/* extern char *malloc(); */
register unsigned int i;
PtrGlbNext = (RecordPtr) malloc(sizeof(RecordType));
PtrGlb = (RecordPtr) malloc(sizeof(RecordType));
PtrGlb->PtrComp = PtrGlbNext;
PtrGlb->Discr = Ident1;
PtrGlb->EnumComp = Ident3;
PtrGlb->intComp = 40;
strcpy(PtrGlb->StringComp, "DHRYSTONE PROGRAM, SOME STRING");
#ifndef GOOF
strcpy(String1Loc, "DHRYSTONE PROGRAM, 1'ST STRING"); /*GOOF*/
#endif
Array2Glob[8][7] = 10; /* Was missing in published program */
/*****************
-- Start Timer --
*****************/
//Forbid();
time1=GetSysTime();
for (i = 0; i < LOOPS; ++i)
{
Proc5();
Proc4();
intLoc1 = 2;
intLoc2 = 3;
strcpy(String2Loc, "DHRYSTONE PROGRAM, 2'ND STRING");
EnumLoc = Ident2;
BoolGlob = ! Func2(String1Loc, String2Loc);
while (intLoc1 < intLoc2)
{
intLoc3 = 5 * intLoc1 - intLoc2;
Proc7(intLoc1, intLoc2, &intLoc3);
++intLoc1;
}
Proc8(Array1Glob, Array2Glob, intLoc1, intLoc3);
Proc1(PtrGlb);
for (CharIndex = 'A'; CharIndex <= Char2Glob; ++CharIndex)
if (EnumLoc == Func1(CharIndex, 'C'))
Proc6(Ident1, &EnumLoc);
intLoc3 = intLoc2 * intLoc1;
intLoc2 = intLoc3 / intLoc1;
intLoc2 = 7 * (intLoc3 - intLoc2) - intLoc1;
Proc2(&intLoc1);
}
/*****************
-- Stop Timer --
*****************/
time2 = GetSysTime();
time3 = time2-time1;
//Permit();
printf("Dhrystone (%s) time for %ld passes = %d.%03d seconds.\n",
Version,(long) LOOPS,time3/1000,time3%1000);
printf("This machine benchmarks at %ld dhrystones/second.\n",
(LOOPS*1000) / time3 );
}
GetSysTime(void)
{
unsigned int t1[2]={0,0};
timer(t1);
// printf("t1=%ld t2=%ld\n",t1[0],t1[1]);
return ((unsigned long) (1000*t1[0])+(t1[1]/1000) );
}
main()
{
Proc0();
exit(0);
}
Proc1(PtrParIn)
REG RecordPtr PtrParIn;
{
#define NextRecord (*(PtrParIn->PtrComp))
structassign(NextRecord, *PtrGlb);
PtrParIn->intComp = 5;
NextRecord.intComp = PtrParIn->intComp;
NextRecord.PtrComp = PtrParIn->PtrComp;
Proc3(NextRecord.PtrComp);
if (NextRecord.Discr == Ident1)
{
NextRecord.intComp = 6;
Proc6(PtrParIn->EnumComp, &NextRecord.EnumComp);
NextRecord.PtrComp = PtrGlb->PtrComp;
Proc7(NextRecord.intComp, 10, &NextRecord.intComp);
}
else
structassign(*PtrParIn, NextRecord);
#undef NextRecord
}
Proc2(intParIO)
OneToFifty *intParIO;
{
REG OneToFifty intLoc;
REG Enumeration EnumLoc;
intLoc = *intParIO + 10;
for(;;)
{
if (Char1Glob == 'A')
{
--intLoc;
*intParIO = intLoc - intGlob;
EnumLoc = Ident1;
}
if (EnumLoc == Ident1)
break;
}
}
Proc3(PtrParOut)
RecordPtr *PtrParOut;
{
if (PtrGlb != NULL)
*PtrParOut = PtrGlb->PtrComp;
else
intGlob = 100;
Proc7(10, intGlob, &PtrGlb->intComp);
}
Proc4()
{
REG boolean BoolLoc;
BoolLoc = Char1Glob == 'A';
BoolLoc |= BoolGlob;
Char2Glob = 'B';
}
Proc5()
{
Char1Glob = 'A';
BoolGlob = FALSE;
}
extern boolean Func3();
Proc6(EnumParIn, EnumParOut)
REG Enumeration EnumParIn;
REG Enumeration *EnumParOut;
{
*EnumParOut = EnumParIn;
if (! Func3(EnumParIn) )
*EnumParOut = Ident4;
switch (EnumParIn)
{
case Ident1: *EnumParOut = Ident1; break;
case Ident2: if (intGlob > 100) *EnumParOut = Ident1;
else *EnumParOut = Ident4;
break;
case Ident3: *EnumParOut = Ident2; break;
case Ident4: break;
case Ident5: *EnumParOut = Ident3;
}
}
Proc7(intParI1, intParI2, intParOut)
OneToFifty intParI1;
OneToFifty intParI2;
OneToFifty *intParOut;
{
REG OneToFifty intLoc;
intLoc = intParI1 + 2;
*intParOut = intParI2 + intLoc;
}
Proc8(Array1Par, Array2Par, intParI1, intParI2)
Array1Dim Array1Par;
Array2Dim Array2Par;
OneToFifty intParI1;
OneToFifty intParI2;
{
REG OneToFifty intLoc;
REG OneToFifty intIndex;
intLoc = intParI1 + 5;
Array1Par[intLoc] = intParI2;
Array1Par[intLoc+1] = Array1Par[intLoc];
Array1Par[intLoc+30] = intLoc;
for (intIndex = intLoc; intIndex <= (intLoc+1); ++intIndex)
Array2Par[intLoc][intIndex] = intLoc;
++Array2Par[intLoc][intLoc-1];
Array2Par[intLoc+20][intLoc] = Array1Par[intLoc];
intGlob = 5;
}
Enumeration Func1(CharPar1, CharPar2)
CapitalLetter CharPar1;
CapitalLetter CharPar2;
{
REG CapitalLetter CharLoc1;
REG CapitalLetter CharLoc2;
CharLoc1 = CharPar1;
CharLoc2 = CharLoc1;
if (CharLoc2 != CharPar2)
return (Ident1);
else
return (Ident2);
}
boolean Func2(StrParI1, StrParI2)
String30 StrParI1;
String30 StrParI2;
{
REG OneToThirty intLoc;
REG CapitalLetter CharLoc;
intLoc = 1;
while (intLoc <= 1)
if (Func1(StrParI1[intLoc], StrParI2[intLoc+1]) == Ident1)
{
CharLoc = 'A';
++intLoc;
}
if (CharLoc >= 'W' && CharLoc <= 'Z')
intLoc = 7;
if (CharLoc == 'X')
return(TRUE);
else
{
if (strcmp(StrParI1, StrParI2) > 0)
{
intLoc += 7;
return (TRUE);
}
else
return (FALSE);
}
}
boolean Func3(EnumParIn)
REG Enumeration EnumParIn;
{
REG Enumeration EnumLoc;
EnumLoc = EnumParIn;
if (EnumLoc == Ident3) return (TRUE);
return (FALSE);
}
#ifdef NOSTRUCTASSIGN
memcpy(d, s, l)
register char *d;
register char *s;
register int l;
{
while (l--) *d++ = *s++;
}
#endif