Publication | Open Access
Efficient path profiling
179
Citations
8
References
2002
Year
Unknown Venue
Path ProfilingEngineeringComputer ArchitectureSoftware EngineeringEmpirical AlgorithmicsSoftware AnalysisProfiling TechniqueEfficient Path ProfilingData ScienceData MiningEdge ProfilingParallel ComputingPerformance PredictionProfiling ToolKnowledge DiscoveryComputer EngineeringComputer ScienceProgram OptimizationPerformance Analysis ToolStatic Program AnalysisEfficient Edge ProfilingProgram AnalysisSoftware TestingParallel Programming
A path profile determines how many times each acyclic path in a routine executes. This type of profiling subsumes the more common basic block and edge profiling, which only approximate path frequencies. Path profiles have many potential uses in program performance tuning, profile-directed compilation, and software test coverage. This paper describes a new algorithm for path profiling. This simple, fast algorithm selects and places profile instrumentation to minimize run-time overhead. Instrumented programs run with overhead comparable to the best previous profiling techniques. On the SPEC95 benchmarks, path profiling overhead averaged 31%, as compared to 16% for efficient edge profiling. Path profiling also identifies longer paths than a previous technique, which predicted paths from edge profiles (average of 88, versus 34 instructions). Moreover, profiling shows that the SPEC95 train input datasets covered most of the paths executed in the ref datasets.
| Year | Citations | |
|---|---|---|
Page 1
Page 1