1cb93a386Sopenharmony_ci/* 2cb93a386Sopenharmony_ci * Copyright 2021 Google Inc. 3cb93a386Sopenharmony_ci * 4cb93a386Sopenharmony_ci * Use of this source code is governed by a BSD-style license that can be 5cb93a386Sopenharmony_ci * found in the LICENSE file. 6cb93a386Sopenharmony_ci */ 7cb93a386Sopenharmony_ci 8cb93a386Sopenharmony_ci#include "src/gpu/GrThreadSafePipelineBuilder.h" 9cb93a386Sopenharmony_ci 10cb93a386Sopenharmony_ci#if GR_GPU_STATS 11cb93a386Sopenharmony_ci#if GR_TEST_UTILS 12cb93a386Sopenharmony_ci#include "include/core/SkString.h" 13cb93a386Sopenharmony_ci 14cb93a386Sopenharmony_ciusing Stats = GrThreadSafePipelineBuilder::Stats; 15cb93a386Sopenharmony_ci 16cb93a386Sopenharmony_cistatic const char* cache_result_to_str(int i) { 17cb93a386Sopenharmony_ci const char* kCacheResultStrings[Stats::kNumProgramCacheResults] = { 18cb93a386Sopenharmony_ci "hits", 19cb93a386Sopenharmony_ci "misses", 20cb93a386Sopenharmony_ci "partials" 21cb93a386Sopenharmony_ci }; 22cb93a386Sopenharmony_ci static_assert(0 == (int) Stats::ProgramCacheResult::kHit); 23cb93a386Sopenharmony_ci static_assert(1 == (int) Stats::ProgramCacheResult::kMiss); 24cb93a386Sopenharmony_ci static_assert(2 == (int) Stats::ProgramCacheResult::kPartial); 25cb93a386Sopenharmony_ci static_assert(Stats::kNumProgramCacheResults == 3); 26cb93a386Sopenharmony_ci return kCacheResultStrings[i]; 27cb93a386Sopenharmony_ci} 28cb93a386Sopenharmony_ci 29cb93a386Sopenharmony_civoid GrThreadSafePipelineBuilder::Stats::dump(SkString* out) { 30cb93a386Sopenharmony_ci out->appendf("Shader Compilations: %d\n", fShaderCompilations.load()); 31cb93a386Sopenharmony_ci 32cb93a386Sopenharmony_ci SkASSERT(fNumInlineCompilationFailures == 0); 33cb93a386Sopenharmony_ci out->appendf("Number of Inline compile failures %d\n", fNumInlineCompilationFailures.load()); 34cb93a386Sopenharmony_ci for (int i = 0; i < Stats::kNumProgramCacheResults-1; ++i) { 35cb93a386Sopenharmony_ci out->appendf("Inline Program Cache %s %d\n", cache_result_to_str(i), 36cb93a386Sopenharmony_ci fInlineProgramCacheStats[i].load()); 37cb93a386Sopenharmony_ci } 38cb93a386Sopenharmony_ci 39cb93a386Sopenharmony_ci SkASSERT(fNumPreCompilationFailures == 0); 40cb93a386Sopenharmony_ci out->appendf("Number of precompile failures %d\n", fNumPreCompilationFailures.load()); 41cb93a386Sopenharmony_ci for (int i = 0; i < Stats::kNumProgramCacheResults-1; ++i) { 42cb93a386Sopenharmony_ci out->appendf("Precompile Program Cache %s %d\n", cache_result_to_str(i), 43cb93a386Sopenharmony_ci fPreProgramCacheStats[i].load()); 44cb93a386Sopenharmony_ci } 45cb93a386Sopenharmony_ci 46cb93a386Sopenharmony_ci SkASSERT(fNumCompilationFailures == 0); 47cb93a386Sopenharmony_ci out->appendf("Total number of compilation failures %d\n", fNumCompilationFailures.load()); 48cb93a386Sopenharmony_ci out->appendf("Total number of partial compilation successes %d\n", 49cb93a386Sopenharmony_ci fNumPartialCompilationSuccesses.load()); 50cb93a386Sopenharmony_ci out->appendf("Total number of compilation successes %d\n", fNumCompilationSuccesses.load()); 51cb93a386Sopenharmony_ci} 52cb93a386Sopenharmony_ci 53cb93a386Sopenharmony_civoid GrThreadSafePipelineBuilder::Stats::dumpKeyValuePairs(SkTArray<SkString>* keys, 54cb93a386Sopenharmony_ci SkTArray<double>* values) { 55cb93a386Sopenharmony_ci keys->push_back(SkString("shader_compilations")); values->push_back(fShaderCompilations); 56cb93a386Sopenharmony_ci} 57cb93a386Sopenharmony_ci 58cb93a386Sopenharmony_ci#endif // GR_TEST_UTILS 59cb93a386Sopenharmony_ci#endif // GR_GPU_STATS 60