2012-08-01 17:53:29 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2012 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2012-09-07 15:21:18 +00:00
|
|
|
#include "SkBenchLogger.h"
|
2012-08-01 17:53:29 +00:00
|
|
|
#include "BenchTimer.h"
|
|
|
|
#include "PictureBenchmark.h"
|
|
|
|
#include "SkCanvas.h"
|
|
|
|
#include "SkPicture.h"
|
|
|
|
#include "SkString.h"
|
|
|
|
#include "picture_utils.h"
|
2012-09-07 15:21:18 +00:00
|
|
|
#include "TimerData.h"
|
2012-08-01 17:53:29 +00:00
|
|
|
|
|
|
|
namespace sk_tools {
|
|
|
|
|
2012-09-11 19:15:32 +00:00
|
|
|
PictureBenchmark::PictureBenchmark()
|
|
|
|
: fRepeats(1)
|
|
|
|
, fLogger(NULL)
|
|
|
|
, fRenderer(NULL)
|
|
|
|
, fLogPerIter(false)
|
|
|
|
, fPrintMin(false)
|
|
|
|
, fShowWallTime(false)
|
|
|
|
, fShowTruncatedWallTime(false)
|
|
|
|
, fShowCpuTime(true)
|
|
|
|
, fShowTruncatedCpuTime(false)
|
|
|
|
, fShowGpuTime(false)
|
|
|
|
{}
|
|
|
|
|
|
|
|
PictureBenchmark::~PictureBenchmark() {
|
|
|
|
SkSafeUnref(fRenderer);
|
|
|
|
}
|
|
|
|
|
2012-08-20 15:03:47 +00:00
|
|
|
BenchTimer* PictureBenchmark::setupTimer() {
|
|
|
|
#if SK_SUPPORT_GPU
|
2012-09-11 19:15:32 +00:00
|
|
|
if (fRenderer != NULL && fRenderer->isUsingGpuDevice()) {
|
|
|
|
return SkNEW_ARGS(BenchTimer, (fRenderer->getGLContext()));
|
2012-08-20 15:03:47 +00:00
|
|
|
} else {
|
2012-08-20 15:03:54 +00:00
|
|
|
return SkNEW_ARGS(BenchTimer, (NULL));
|
2012-08-20 15:03:47 +00:00
|
|
|
}
|
|
|
|
#else
|
2012-08-20 15:03:54 +00:00
|
|
|
return SkNEW_ARGS(BenchTimer, (NULL));
|
2012-08-20 15:03:47 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2012-09-07 15:21:18 +00:00
|
|
|
void PictureBenchmark::logProgress(const char msg[]) {
|
|
|
|
if (fLogger != NULL) {
|
|
|
|
fLogger->logProgress(msg);
|
2012-08-07 17:11:33 +00:00
|
|
|
}
|
2012-08-01 17:53:29 +00:00
|
|
|
}
|
|
|
|
|
2012-09-11 19:15:32 +00:00
|
|
|
PictureRenderer* PictureBenchmark::setRenderer(sk_tools::PictureRenderer* renderer) {
|
|
|
|
SkRefCnt_SafeAssign(fRenderer, renderer);
|
|
|
|
return renderer;
|
|
|
|
}
|
|
|
|
|
2012-09-07 15:21:18 +00:00
|
|
|
void PictureBenchmark::run(SkPicture* pict) {
|
2012-08-07 17:11:33 +00:00
|
|
|
SkASSERT(pict);
|
2012-08-20 15:03:44 +00:00
|
|
|
if (NULL == pict) {
|
2012-08-07 17:11:33 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-09-11 19:15:32 +00:00
|
|
|
SkASSERT(fRenderer != NULL);
|
|
|
|
if (NULL == fRenderer) {
|
2012-08-07 17:11:33 +00:00
|
|
|
return;
|
|
|
|
}
|
2012-08-01 17:53:29 +00:00
|
|
|
|
2012-09-11 19:15:32 +00:00
|
|
|
fRenderer->init(pict);
|
|
|
|
|
|
|
|
// We throw this away to remove first time effects (such as paging in this program)
|
|
|
|
fRenderer->setup();
|
2012-09-20 14:54:21 +00:00
|
|
|
fRenderer->render(NULL);
|
2012-09-11 19:15:32 +00:00
|
|
|
fRenderer->resetState();
|
2012-08-01 17:53:29 +00:00
|
|
|
|
2012-08-20 15:03:47 +00:00
|
|
|
BenchTimer* timer = this->setupTimer();
|
2012-09-07 15:21:18 +00:00
|
|
|
bool usingGpu = false;
|
2012-08-20 15:03:52 +00:00
|
|
|
#if SK_SUPPORT_GPU
|
2012-09-11 19:15:32 +00:00
|
|
|
usingGpu = fRenderer->isUsingGpuDevice();
|
2012-08-20 15:03:52 +00:00
|
|
|
#endif
|
2012-08-20 15:03:47 +00:00
|
|
|
|
2012-09-11 19:15:32 +00:00
|
|
|
TimerData timerData(fRenderer->getPerIterTimeFormat(), fRenderer->getNormalTimeFormat());
|
2012-08-01 17:53:29 +00:00
|
|
|
for (int i = 0; i < fRepeats; ++i) {
|
2012-09-11 19:15:32 +00:00
|
|
|
fRenderer->setup();
|
2012-08-01 17:53:29 +00:00
|
|
|
|
2012-08-20 15:03:52 +00:00
|
|
|
timer->start();
|
2012-09-25 17:36:36 +00:00
|
|
|
fRenderer->render(NULL);
|
2012-09-07 15:21:18 +00:00
|
|
|
timer->truncatedEnd();
|
2012-08-20 15:03:52 +00:00
|
|
|
|
2012-09-07 15:21:18 +00:00
|
|
|
// Finishes gl context
|
2012-09-11 19:15:32 +00:00
|
|
|
fRenderer->resetState();
|
2012-08-20 15:03:47 +00:00
|
|
|
timer->end();
|
2012-08-01 17:53:29 +00:00
|
|
|
|
2012-09-07 15:21:18 +00:00
|
|
|
timerData.appendTimes(timer, fRepeats - 1 == i);
|
2012-08-01 17:53:29 +00:00
|
|
|
}
|
|
|
|
|
2012-11-02 22:01:26 +00:00
|
|
|
SkString configName = fRenderer->getConfigName();
|
2012-09-11 19:15:32 +00:00
|
|
|
SkString result = timerData.getResult(fLogPerIter, fPrintMin, fRepeats,
|
2012-11-02 22:01:26 +00:00
|
|
|
configName.c_str(), fShowWallTime, fShowTruncatedWallTime,
|
2012-09-11 19:15:32 +00:00
|
|
|
fShowCpuTime, fShowTruncatedCpuTime,
|
|
|
|
usingGpu && fShowGpuTime);
|
2012-09-07 15:21:18 +00:00
|
|
|
result.append("\n");
|
|
|
|
this->logProgress(result.c_str());
|
2012-08-20 15:04:09 +00:00
|
|
|
|
2012-09-11 19:15:32 +00:00
|
|
|
fRenderer->end();
|
2012-08-20 15:04:09 +00:00
|
|
|
SkDELETE(timer);
|
2012-08-01 17:53:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|