home *** CD-ROM | disk | FTP | other *** search
/ Chip 2003 January / Chip_2003-01_cd1.bin / zkuste / delphi / nastroje / d234567 / PRODEL.ZIP / PROCAL.PAS < prev    next >
Pascal/Delphi Source File  |  2002-07-23  |  4KB  |  148 lines

  1. //PROFILE-NO
  2. unit Procal;
  3. {$O-}  // Do not remove! Delphi might crash !!!!
  4. {$R-}
  5. {$Q-}
  6. {$A+}
  7.  
  8. interface
  9. USES
  10.   Windows;
  11.  
  12. TYPE
  13. {$IFDEF VER90 }
  14.   TMyComp  = Comp;
  15. {$ELSE }
  16.   {$IFDEF VER100 }
  17.     TMyComp  = Comp;
  18.   {$ELSE }
  19.     TMyComp  = Int64;
  20.   {$ENDIF }
  21. {$ENDIF }
  22.   TMyLargeInteger = RECORD
  23.                     CASE Byte OF
  24.                      0 : ( LowPart  : DWORD; HighPart : LongInt );
  25.                      1 : ( QuadPart : TMyComp );
  26.                   END;
  27.  
  28. FUNCTION TopFunction ( VAR index : Integer ) : TMyLargeInteger;
  29. FUNCTION FunctionWith100( VAR index : Integer; loops : Integer ) : TMyLargeInteger;
  30. FUNCTION FunctionWith1000( VAR index : Integer; loops : Integer ) : TMyLargeInteger;
  31.  
  32. VAR
  33.   QPCAss : TMyLargeInteger; // Time used for PRTSC + mov + mov
  34. implementation
  35.  
  36. VAR
  37.   tsum   : TMyLargeInteger;
  38.  
  39. FUNCTION DeepFunction : Integer;
  40. BEGIN
  41.   Result := 0;
  42. END;
  43.  
  44. FUNCTION MidFunction  : Integer;
  45. VAR
  46.   i : Integer;
  47. BEGIN
  48.   FOR i := 1 TO 10 DO
  49.     Result := DeepFunction;
  50. END;
  51.  
  52. FUNCTION TopFunction ( VAR index : Integer ) : TMyLargeInteger;
  53. VAR
  54.   i  : Integer;
  55.   ta : TMyLargeInteger;
  56. BEGIN
  57.   asm
  58.     DW 310FH;   // first PRTSC, get cycles before tested instruction
  59.     mov ta.lowpart,eax
  60.     mov ta.highpart,edx
  61.   end;
  62.  
  63.   FOR i := 1 TO 10 DO
  64.     index := MidFunction;
  65.   Result.highpart := 0;
  66.   Result.lowpart := 0;
  67.  
  68.   asm
  69.     DW 310FH;   // get cycles after tested instructions
  70.     // Next lines calculate the no of cycles now - no of cycles before first PRTSC
  71.     sub eax,ta.lowpart
  72.     sbb edx,ta.highpart
  73.     // Next lines subtract no of cycles for the first PRTSC + mov instructions
  74.     sub eax,QPCAss.lowpart
  75.     sbb edx,QPCAss.highpart
  76.     // = No of cycles for the measured instructions
  77.     // stored in tsum
  78.     mov tsum.lowpart,eax
  79.     mov tsum.highpart,edx
  80.   end;
  81.   result.lowpart := tsum.lowpart;
  82. END;
  83.  
  84. FUNCTION FunctionWith100( VAR index : Integer; loops : Integer ) : TMyLargeInteger;
  85. VAR
  86.   i  : Integer;
  87.   ta : TMyLargeInteger;
  88. BEGIN
  89.   asm
  90.     DW 310FH;   // first PRTSC, get cycles before tested instruction
  91.     mov ta.lowpart,eax
  92.     mov ta.highpart,edx
  93.   end;
  94.  
  95.   FOR i := 1 TO loops DO
  96.     index := index + 1;
  97.   Result.lowpart  := 0;
  98.   Result.highpart := 0;
  99.   asm
  100.     DW 310FH;   // get cycles after tested instructions
  101.     // Next lines calculate the no of cycles now - no of cycles before first PRTSC
  102.     sub eax,ta.lowpart
  103.     sbb edx,ta.highpart
  104.     // Next lines subtract no of cycles for the first PRTSC + mov instructions
  105.     sub eax,QPCAss.lowpart
  106.     sbb edx,QPCAss.highpart
  107.     // = No of cycles for the measured instructions
  108.     // stored in tsum
  109.     mov tsum.lowpart,eax
  110.     mov tsum.highpart,edx
  111.   end;
  112.   result.lowpart := tsum.lowpart;
  113. END;
  114.  
  115. FUNCTION FunctionWith1000( VAR index : Integer; loops : Integer ) : TMyLargeInteger;
  116. VAR
  117.   i  : Integer;
  118.   ta : TMyLargeInteger;
  119. BEGIN
  120.   asm
  121.     DW 310FH;   // first PRTSC, get cycles before tested instruction
  122.     mov ta.lowpart,eax
  123.     mov ta.highpart,edx
  124.   end;
  125.  
  126.   FOR i := 1 TO loops DO
  127.     index := index + 1;
  128.   Result.highpart := 0;
  129.   Result.lowpart := 0;
  130.  
  131.   asm
  132.     DW 310FH;   // get cycles after tested instructions
  133.     // Next lines calculate the no of cycles now - no of cycles before first PRTSC
  134.     sub eax,ta.lowpart
  135.     sbb edx,ta.highpart
  136.     // Next lines subtract no of cycles for the first PRTSC + mov instructions
  137.     sub eax,QPCAss.lowpart
  138.     sbb edx,QPCAss.highpart
  139.     // = No of cycles for the measured instructions
  140.     // stored in tsum
  141.     mov tsum.lowpart,eax
  142.     mov tsum.highpart,edx
  143.   end;
  144.   result.lowpart := tsum.lowpart;
  145. END;
  146.  
  147. end.
  148.