From 7f677d50b25f29a9ae8d733fdc2f00c94c3ed6be Mon Sep 17 00:00:00 2001 From: mrsharm Date: Wed, 14 Feb 2024 21:54:12 -0800 Subject: [PATCH] Added the new benchmark based types that enable the Benchmark provider --- .../Configurations/GCPerfSim/LowVolatilityRuns.yaml | 2 +- .../Configurations/GCPerfSim/Normal_Server.yaml | 2 +- .../gc/GC.Infrastructure/Configurations/Run.yaml | 2 +- .../Configurations/GCPerfSim.Configuration.cs | 2 +- .../TraceCollection/TraceCollector.cs | 9 +++++++++ .../Commands/RunCommand/BaseSuite/LowVolatilityRuns.yaml | 2 +- 6 files changed, 14 insertions(+), 5 deletions(-) diff --git a/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/LowVolatilityRuns.yaml b/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/LowVolatilityRuns.yaml index fc888946946..6b0f1a71f43 100644 --- a/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/LowVolatilityRuns.yaml +++ b/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/LowVolatilityRuns.yaml @@ -140,4 +140,4 @@ output: - json name: Normal_Server trace_configurations: - type: gc # gc, verbose, cpu, cpu_managed, threadtime, threadtime_managed, join. \ No newline at end of file + type: gc # none, gc, gc_benchmarks, verbose, cpu, cpu_benchmarks, cpu_managed, cpu_managed_benchmarks, threadtime, join. \ No newline at end of file diff --git a/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/Normal_Server.yaml b/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/Normal_Server.yaml index 0171039f125..8da1541b1fd 100644 --- a/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/Normal_Server.yaml +++ b/src/benchmarks/gc/GC.Infrastructure/Configurations/GCPerfSim/Normal_Server.yaml @@ -133,4 +133,4 @@ output: - json name: Normal_Server trace_configurations: - type: gc # gc, verbose, cpu, cpu_managed, threadtime, threadtime_managed, join. + type: gc # none, gc, gc_benchmarks, verbose, cpu, cpu_benchmarks, cpu_managed, cpu_managed_benchmarks, threadtime, join. diff --git a/src/benchmarks/gc/GC.Infrastructure/Configurations/Run.yaml b/src/benchmarks/gc/GC.Infrastructure/Configurations/Run.yaml index 021983d8de9..86aa316301d 100644 --- a/src/benchmarks/gc/GC.Infrastructure/Configurations/Run.yaml +++ b/src/benchmarks/gc/GC.Infrastructure/Configurations/Run.yaml @@ -12,7 +12,7 @@ coreruns: environment_variables: COMPlus_GCName: clrgc.dll -trace_configuration_type: gc # Choose between: none, gc, verbose, cpu, cpu_managed, threadtime, join. +trace_configuration_type: gc # Choose between: none, gc, gc_benchmarks, verbose, cpu, cpu_benchmarks, cpu_managed, cpu_managed_benchmarks, threadtime, join. # Optional fields: the contents of both the symbol_path and the source_path will be copied over to the output path. symbol_path: diff --git a/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/Configurations/GCPerfSim.Configuration.cs b/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/Configurations/GCPerfSim.Configuration.cs index 9a69f061b8d..b3cda225788 100644 --- a/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/Configurations/GCPerfSim.Configuration.cs +++ b/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/Configurations/GCPerfSim.Configuration.cs @@ -116,7 +116,7 @@ public static GCPerfSimConfiguration Parse(string path, bool isIncompleteConfigu // Trace Configurations if specified, must have a type specified. if (configuration.TraceConfigurations != null && string.IsNullOrEmpty(configuration.TraceConfigurations.Type)) { - throw new ArgumentException($"{nameof(GCPerfSimConfigurationParser)}: Please ensure a trace configuration type is specified. If you don't want to collect a trace, simply don't include the trace_configuration type or choose either: gc, verbose, cpu, cpu_managed, threadtime, threadtime_managed."); + throw new ArgumentException($"{nameof(GCPerfSimConfigurationParser)}: Please ensure a trace configuration type is specified. If you don't want to collect a trace, simply don't include the trace_configuration type or choose either: gc, gc_benchmarks, verbose, cpu, cpu_benchmarks, cpu_managed, cpu_managed_benchmarks, threadtime, threadtime_managed."); } // If the user passes in a null output path, default to the current directory. diff --git a/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/TraceCollection/TraceCollector.cs b/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/TraceCollection/TraceCollector.cs index 181bff12de6..9472a7baa04 100644 --- a/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/TraceCollection/TraceCollector.cs +++ b/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure.Core/TraceCollection/TraceCollector.cs @@ -7,9 +7,12 @@ public enum CollectType { none, gc, + gc_benchmarks, verbose, cpu, + cpu_benchmarks, cpu_managed, + cpu_managed_benchmarks, threadtime, threadtime_managed, join @@ -28,9 +31,12 @@ public sealed class TraceCollector : IDisposable internal static readonly Dictionary WindowsCollectTypeMap = new() { { CollectType.gc, "/GCCollectOnly" }, + { CollectType.gc_benchmarks, "/GCCollectOnly /Providers:Benchmarks" }, { CollectType.verbose, "/ClrEventLevel:Verbose /ClrEvents:GC+Stack" }, { CollectType.cpu, "/KernelEvents=Process+Thread+ImageLoad+Profile /ClrEventLevel:Informational /ClrEvents:GC+Stack /BufferSize:3000 /CircularMB:3000" }, + { CollectType.cpu_benchmarks, "/KernelEvents=Process+Thread+ImageLoad+Profile /Providers:Benchmarks /ClrEventLevel:Informational /ClrEvents:GC+Stack /BufferSize:3000 /CircularMB:3000" }, { CollectType.cpu_managed, "/KernelEvents=Process+Thread+ImageLoad+Profile /ClrEventLevel:Informational /ClrEvents:GC+Stack+Codesymbols+JitSymbols+Compilation+Type+GCHeapAndTypeNames /BufferSize:3000 /CircularMB:3000" }, + { CollectType.cpu_managed_benchmarks, "/KernelEvents=Process+Thread+ImageLoad+Profile /Providers:Benchmarks /ClrEventLevel:Informational /ClrEvents:GC+Stack+Codesymbols+JitSymbols+Compilation+Type+GCHeapAndTypeNames /BufferSize:3000 /CircularMB:3000" }, { CollectType.threadtime_managed, "/KernelEvents=Process+Thread+ImageLoad+Profile+ContextSwitch+Dispatcher /ClrEvents:GC+Stack+Codesymbols+JitSymbols+Compilation+Type+GCHeapAndTypeNames /BufferSize:3000 /CircularMB:3000 /ClrEventLevel=Verbose" }, { CollectType.threadtime, "/KernelEvents=Process+Thread+ImageLoad+Profile+ContextSwitch+Dispatcher /ClrEvents:GC /ClrEventLevel=Verbose /BufferSize:3000 /CircularMB:3000 " }, { CollectType.join, " /BufferSizeMB:4096 /CircularMB:4096 /KernelEvents:Process+Thread+ImageLoad /ClrEvents:GC+Threading /ClrEventLevel=Verbose " }, @@ -46,9 +52,12 @@ public sealed class TraceCollector : IDisposable internal static readonly Dictionary StringToCollectTypeMap = new(StringComparer.OrdinalIgnoreCase) { { "gc", CollectType.gc }, + { "gc_benchmarks", CollectType.gc_benchmarks }, { "verbose", CollectType.verbose }, { "cpu", CollectType.cpu }, + { "cpu_benchmarks", CollectType.cpu_benchmarks }, { "cpu_managed", CollectType.cpu_managed }, + { "cpu_managed_benchmarks", CollectType.cpu_managed_benchmarks }, { "threadtime", CollectType.threadtime }, { "threadtime_managed", CollectType.threadtime_managed }, { "join", CollectType.join }, diff --git a/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure/Commands/RunCommand/BaseSuite/LowVolatilityRuns.yaml b/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure/Commands/RunCommand/BaseSuite/LowVolatilityRuns.yaml index 8e2ddff6fc2..46890f6dc77 100644 --- a/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure/Commands/RunCommand/BaseSuite/LowVolatilityRuns.yaml +++ b/src/benchmarks/gc/GC.Infrastructure/GC.Infrastructure/Commands/RunCommand/BaseSuite/LowVolatilityRuns.yaml @@ -128,4 +128,4 @@ output: - json name: Normal_Server trace_configurations: - type: gc # gc, verbose, cpu, cpu_managed, threadtime, threadtime_managed, join. \ No newline at end of file + type: gc # none, gc, gc_benchmarks, verbose, cpu, cpu_benchmarks, cpu_managed, cpu_managed_benchmarks, threadtime, join. \ No newline at end of file