372 lines
16 KiB
C#
372 lines
16 KiB
C#
//---------------------------------------------------------------------------
|
|
// File: TraceTest
|
|
//
|
|
// A Test Program for using the ETW Trace Listener
|
|
//
|
|
// Author: Melur Raghuraman
|
|
// Date: 01 Oct 2001
|
|
//---------------------------------------------------------------------------
|
|
|
|
using System;
|
|
using System.Threading;
|
|
using System.Diagnostics;
|
|
using System.IO;
|
|
using System.Data;
|
|
using System.Configuration;
|
|
using Microsoft.Win32.Diagnostics;
|
|
using System.Reflection;
|
|
/// <summary>
|
|
/// Summary description for TraceTest.
|
|
/// </summary>
|
|
///
|
|
|
|
class TraceTest
|
|
//TraceTest
|
|
{
|
|
|
|
//
|
|
// This routine is a sample of what a performance and capacity planning trace
|
|
// provider will do to generate ETW traces.
|
|
//
|
|
|
|
static void PerfTracingSample(int eventCount, int argCount, bool bString)
|
|
{
|
|
uint i;
|
|
uint Status;
|
|
Int64 AvgTime;
|
|
int arg1 = 3276;
|
|
int arg2 = 56797;
|
|
Guid TransactionGuid = new Guid("{b4955bf0-3af1-4740-b475-99055d3fe9aa}");
|
|
Console.WriteLine("Perf Tracing Sample running");
|
|
TimerTest MyTimer = new TimerTest();
|
|
|
|
WinTraceProvider MyProvider = new WinTraceProvider (new Guid("{98bea4af-ef37-424a-b457-9ea1cfd77dd9}") );
|
|
|
|
MyTimer.Start();
|
|
|
|
for (i=0; i < eventCount; i++)
|
|
{
|
|
if (MyProvider.enabled)
|
|
{
|
|
if (!bString)
|
|
{
|
|
switch (argCount)
|
|
{
|
|
case 0: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start); break;
|
|
case 1: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1); break;
|
|
case 2: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2); break;
|
|
case 3: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2, arg1); break;
|
|
case 4: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2, arg1, arg2); break;
|
|
case 5: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2, arg1, arg2, arg1); break;
|
|
case 6: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2, arg1, arg2, arg1, arg2); break;
|
|
case 7: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2, arg1, arg2, arg1, arg2, arg1); break;
|
|
case 8: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, arg1, arg2, arg1, arg2, arg1, arg2, arg1, arg1); break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
switch (argCount)
|
|
{
|
|
case 0: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start); break;
|
|
case 1: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012"); break;
|
|
case 2: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012"); break;
|
|
case 3: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012"); break;
|
|
case 4: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012"); break;
|
|
case 5: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012"); break;
|
|
case 6: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012"); break;
|
|
case 7: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012"); break;
|
|
case 8: Status = MyProvider.TraceEvent(TransactionGuid, EventType.Start, "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012", "12345678901234567890123456789012","12345678901234567890123456789012"); break;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
}
|
|
|
|
MyTimer.Stop();
|
|
AvgTime = MyTimer.Average() / eventCount;
|
|
Console.WriteLine("Start {0} End {1} Count {2} Delta {3} Freq {4}", MyTimer.m_Start, MyTimer.m_End, MyTimer.m_Count, MyTimer.m_Sum, MyTimer.m_Freq);
|
|
|
|
|
|
AvgTime = MyTimer.m_Sum / MyTimer.m_Freq; // This is in seconds
|
|
|
|
Console.WriteLine("Elapsed Time {0} milli seconds ", AvgTime*1000);
|
|
// Assumes you are running on a 1700 MHz box.
|
|
AvgTime = MyTimer.m_Sum * (1700 * 1000000 / eventCount);
|
|
AvgTime = AvgTime / MyTimer.m_Freq;
|
|
Console.WriteLine("Done! Average Time for {0} calls = {1} Cycles", eventCount, AvgTime);
|
|
}
|
|
|
|
//
|
|
// Here's what a debug trace provider will have to do to generate debug traces
|
|
//
|
|
|
|
static void DebugTracingSample(int eventCount, int argCount, bool bString)
|
|
{
|
|
uint i;
|
|
int EventCount = eventCount;
|
|
uint Status;
|
|
long AvgTime;
|
|
|
|
|
|
unsafe
|
|
{
|
|
/* Test to determine how characters are encoded in the String class */
|
|
sbyte[] b ={ 0x64, 0x65, 0x66, 0x67 };
|
|
fixed(sbyte* sbyteArray = b)
|
|
{
|
|
String s = new String(sbyteArray,0,4);
|
|
Console.WriteLine("Test String = " + s + " Length = " + s.Length);
|
|
int len = s.Length*2;
|
|
fixed(char* cArray = s.ToCharArray())
|
|
{
|
|
byte* bArray = (byte*)cArray;
|
|
for(int h = 0; h < len; h++)
|
|
Console.WriteLine("[{0}]:{1}",h,bArray[h]);
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
|
|
Console.WriteLine("DebugTracing Sample Running");
|
|
unsafe {Console.WriteLine("sizeof char = " + sizeof(char));}
|
|
TimerTest MyTimer = new TimerTest();
|
|
WinTraceProvider MyProvider = new WinTraceProvider (new Guid("{98bea4af-ef37-424a-b457-9ea1cfd77dd9}") );
|
|
|
|
/*** scratch work - start ***/
|
|
Assembly assembly;
|
|
assembly = Assembly.GetAssembly(MyTimer.GetType());
|
|
Console.WriteLine("Code base : " + assembly.CodeBase);
|
|
/*** scratch work - end ***/
|
|
|
|
string frmtstr = "Hello {0}";
|
|
string frmtstr2 = "Arg0 = {0} Arg1 = {1}";
|
|
string frmtstr3 = "Arg0 ={0} Arg1 = {1} Arg2 = {2}";
|
|
bool bool_v=false;
|
|
byte byte_v=(byte)99;
|
|
sbyte sbyte_v = (sbyte)-114;
|
|
short short_v = (short)-54;
|
|
ushort ushort_v = (ushort)5000;
|
|
int int_v = -654;
|
|
uint uint_v = (uint)12345;
|
|
long long_v = (long)-98765;
|
|
ulong ulong_v = (ulong)1234567;
|
|
string string_v = "Does it work [2]?";
|
|
char char_v='G';
|
|
decimal decimal_v=(decimal)200.876543243213D;
|
|
object decimal_obj = decimal_v;
|
|
double double_v=(double)3.00;
|
|
float float_v=2.00F;
|
|
|
|
//This is a string of length 128 bytes
|
|
string testStr = "We began in earnest on Microsoft Windows 2000 in August 1996!!!!";
|
|
//string testStr = "12345678"; //16 bytes in length
|
|
//Yes, it is only a performance test and hence we do not need the actual formatting. Yet....
|
|
string testFmtStr1="Test Message = {0}", testFmtStr2 = testFmtStr1+",{1}", testFmtStr3 = testFmtStr2+",{2}";
|
|
string testFmtStr4=testFmtStr3+",{3}", testFmtStr5=testFmtStr4+",{4}",testFmtStr6=testFmtStr5+",{5}";
|
|
string testFmtStr7=testFmtStr6+",{6}", testFmtStr8=testFmtStr7+",{7}";
|
|
Console.WriteLine("Length = " + testStr.Length);
|
|
string emptyString = "";
|
|
Console.WriteLine("Length of empty string = "+emptyString.Length);
|
|
//Console.WriteLine(String.Format("Dummy Format {0} {1}","Hello"));
|
|
unsafe{Console.WriteLine("size of decimal = " + sizeof(decimal));}
|
|
Console.WriteLine("Length of decimal string = " + decimal_obj.ToString().Length);
|
|
if (bString)
|
|
{
|
|
|
|
//Gather performance results for logging a message containing 1 128-byte argument.
|
|
Console.WriteLine("Helooooo {0} {1} {2}",decimal_v,(object)null,decimal_v);
|
|
//MyProvider.DoTraceMessage(1,"Helloooo {0} {1} {2}",decimal_v,(object)null,decimal_v);
|
|
MyTimer.Start();
|
|
for(i=0; i < eventCount; i++)
|
|
{
|
|
if (MyProvider.enabled)
|
|
{
|
|
|
|
switch(argCount)
|
|
{
|
|
case 1:MyProvider.DoTraceMessage(1,testFmtStr1,testStr);break;
|
|
case 2:MyProvider.DoTraceMessage(1,testFmtStr2,testStr,testStr);break;
|
|
case 3:MyProvider.DoTraceMessage(1,testFmtStr3,testStr,testStr,testStr);break;
|
|
case 4:MyProvider.DoTraceMessage(1,testFmtStr4,testStr,testStr,testStr,testStr);break;
|
|
case 5:MyProvider.DoTraceMessage(1,testFmtStr5,testStr,testStr,testStr,testStr, testStr);break;
|
|
case 6:MyProvider.DoTraceMessage(1,testFmtStr6,testStr,testStr,testStr,testStr, testStr, testStr);break;
|
|
case 7:MyProvider.DoTraceMessage(1,testFmtStr7,testStr,testStr,testStr,testStr, testStr, testStr, testStr);break;
|
|
case 8:MyProvider.DoTraceMessage(1,testFmtStr8,testStr,testStr,testStr,testStr, testStr, testStr, testStr, testStr);break;
|
|
}
|
|
}
|
|
}
|
|
MyTimer.Stop();
|
|
|
|
|
|
}
|
|
|
|
else
|
|
{
|
|
MyTimer.Start();
|
|
MyProvider.DoTraceMessage(1,frmtstr,bool_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,byte_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,sbyte_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,short_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,ushort_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,int_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,uint_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,long_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,ulong_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,float_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,double_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,decimal_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,char_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr,string_v);
|
|
MyProvider.DoTraceMessage(1,frmtstr2,uint_v,byte_v);
|
|
Status = MyProvider.DoTraceMessage(1,frmtstr3,decimal_v,float_v,long_v);
|
|
/*
|
|
for (i=0; i < eventCount; i++)
|
|
{
|
|
if (MyProvider.enabled)
|
|
{
|
|
for(i=0; i < eventCount; i++)
|
|
{
|
|
if (MyProvider.enabled)
|
|
{
|
|
switch(argCount)
|
|
{
|
|
case 1:MyProvider.DoTraceMessage(1,testFmtStr1,decimal_v);break;
|
|
case 2:MyProvider.DoTraceMessage(1,testFmtStr2,decimal_v,decimal_v);break;
|
|
case 3:MyProvider.DoTraceMessage(1,testFmtStr3,decimal_v,decimal_v,decimal_v);break;
|
|
case 4:MyProvider.DoTraceMessage(1,testFmtStr4,decimal_v,decimal_v,decimal_v,decimal_v);break;
|
|
case 5:MyProvider.DoTraceMessage(1,testFmtStr5,decimal_v,decimal_v,decimal_v,decimal_v, decimal_v);break;
|
|
case 6:MyProvider.DoTraceMessage(1,testFmtStr6,decimal_v,decimal_v,decimal_v,decimal_v, decimal_v, decimal_v);break;
|
|
case 7:MyProvider.DoTraceMessage(1,testFmtStr7,decimal_v,decimal_v,decimal_v,decimal_v, decimal_v, decimal_v, decimal_v);break;
|
|
case 8:MyProvider.DoTraceMessage(1,testFmtStr8,decimal_v,decimal_v,decimal_v,decimal_v, decimal_v, decimal_v, decimal_v, decimal_v);break;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
}
|
|
}
|
|
*/
|
|
MyTimer.Stop();
|
|
|
|
|
|
|
|
/*
|
|
|
|
AvgTime = MyTimer.m_Sum * (1700 * 1000000 / eventCount);
|
|
AvgTime = AvgTime / MyTimer.m_Freq;
|
|
Console.WriteLine("Encoding Scheme [{2} args] : Average Time for {0} calls = {1} Cycles", eventCount, AvgTime, argCount);
|
|
|
|
MyTimer.Clear();
|
|
MyTimer.Start();
|
|
for (i=0; i < eventCount; i++)
|
|
{
|
|
if (MyProvider.enabled)
|
|
{
|
|
for(i=0; i < eventCount; i++)
|
|
{
|
|
if (MyProvider.enabled)
|
|
{
|
|
switch(argCount)
|
|
{
|
|
case 1:MyProvider.DoTraceMessage(1,testFmtStr1,((object)decimal_v).ToString());break;
|
|
case 2:MyProvider.DoTraceMessage(1,testFmtStr2,((object)decimal_v).ToString(),((object)decimal_v).ToString());break;
|
|
case 3:MyProvider.DoTraceMessage(1,testFmtStr3,((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString());break;
|
|
case 4:MyProvider.DoTraceMessage(1,testFmtStr4,((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString());break;
|
|
case 5:MyProvider.DoTraceMessage(1,testFmtStr5,((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(), ((object)decimal_v).ToString());break;
|
|
case 6:MyProvider.DoTraceMessage(1,testFmtStr6,((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(), ((object)decimal_v).ToString(), ((object)decimal_v).ToString());break;
|
|
case 7:MyProvider.DoTraceMessage(1,testFmtStr7,((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(), ((object)decimal_v).ToString(), ((object)decimal_v).ToString(), ((object)decimal_v).ToString());break;
|
|
case 8:MyProvider.DoTraceMessage(1,testFmtStr8,((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(),((object)decimal_v).ToString(), ((object)decimal_v).ToString(), ((object)decimal_v).ToString(), ((object)decimal_v).ToString(), ((object)decimal_v).ToString());break;
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
MyTimer.Stop();
|
|
|
|
|
|
|
|
|
|
AvgTime = MyTimer.m_Sum * (1700 * 1000000 / eventCount);
|
|
AvgTime = AvgTime / MyTimer.m_Freq;
|
|
Console.WriteLine("ToString() Scheme [{2} args] : Average Time for {0} calls = {1} Cycles", eventCount, AvgTime, argCount);
|
|
*/
|
|
}
|
|
Console.WriteLine("Debug Test Complete. Timing Results:");
|
|
|
|
|
|
AvgTime = MyTimer.Average() / eventCount;
|
|
Console.WriteLine("StartTime {0} EndTime {1} Count {2} Sum {3} Freq {4}", MyTimer.m_Start, MyTimer.m_End, eventCount, MyTimer.m_Sum, MyTimer.m_Freq);
|
|
|
|
AvgTime = MyTimer.m_Sum / MyTimer.m_Freq; // This is in seconds
|
|
|
|
AvgTime = MyTimer.m_Sum * (1700 * 1000000 / eventCount);
|
|
AvgTime = AvgTime / MyTimer.m_Freq;
|
|
Console.WriteLine("Done! Average Time for {0} calls = {1} Cycles", eventCount, AvgTime);
|
|
|
|
}
|
|
|
|
static void Main(string[] args)
|
|
{
|
|
uint i;
|
|
int eventCount = 10000;
|
|
int argCount = 0;
|
|
bool testDebug=false;
|
|
bool bString=false;
|
|
|
|
try
|
|
{
|
|
i = 0;
|
|
while (i < args.Length)
|
|
{
|
|
if (args[i] == "-Debug")
|
|
{
|
|
testDebug = true;
|
|
}
|
|
else if (args[i] == "-nArg")
|
|
{
|
|
i++;
|
|
if (i >= args.Length) return;
|
|
argCount = System.Convert.ToInt32(args[i]);
|
|
}
|
|
else if (args[i] == "-bString")
|
|
{
|
|
bString = true;
|
|
}
|
|
else
|
|
{
|
|
eventCount = 10000; //default
|
|
eventCount = System.Convert.ToInt32(args[i]);
|
|
}
|
|
i++;
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
Console.WriteLine("{0} Exception caught.", e);
|
|
|
|
Console.WriteLine("Usage: trace [EventCount] [-nArg argCount] [-bString] [-Debug]");
|
|
return;
|
|
}
|
|
|
|
if (testDebug)
|
|
{
|
|
DebugTracingSample(eventCount, argCount, bString);
|
|
}
|
|
else
|
|
{
|
|
Console.WriteLine("PerfTracing with eventCount{0}, argCount {1}, bString {2}", eventCount, argCount, bString);
|
|
PerfTracingSample(eventCount, argCount, bString);
|
|
}
|
|
|
|
|
|
return;
|
|
}
|
|
}
|