05ead8afe5
Reason for revert: Caused segmentation fault on many builders. Please see reverted CL's msg #21 for details. Original issue's description: > Support using OpenGL ES context on desktop > > Support using OpenGL ES context on desktop for unix and Android platforms. This > is mainly useful in development. > > Add --gpuAPI flag to gm, dm, bench, bench_pictures and render_pictures. The > possible parameters for the flag are "gl" and "gles". > > Committed: https://skia.googlesource.com/skia/+/74fc727dc88ee24d89f88cb1709f963e9073aeb3 R=bsalomon@google.com, mtklein@google.com, robertphillips@google.com, kkinnunen@nvidia.com TBR=bsalomon@google.com, kkinnunen@nvidia.com NOTREECHECKS=true NOTRY=true Author: rmistry@google.com Review URL: https://codereview.chromium.org/351583002
84 lines
2.7 KiB
C++
84 lines
2.7 KiB
C++
#include "DMBenchTask.h"
|
|
#include "DMUtil.h"
|
|
#include "SkSurface.h"
|
|
|
|
namespace DM {
|
|
|
|
static SkString bench_name(const char* name, const char* config) {
|
|
SkString result("bench ");
|
|
result.appendf("%s_%s", name, config);
|
|
return result;
|
|
}
|
|
|
|
NonRenderingBenchTask::NonRenderingBenchTask(const char* config,
|
|
Reporter* reporter,
|
|
TaskRunner* tasks,
|
|
BenchRegistry::Factory factory)
|
|
: CpuTask(reporter, tasks)
|
|
, fBench(factory(NULL))
|
|
, fName(bench_name(fBench->getName(), config)) {}
|
|
|
|
CpuBenchTask::CpuBenchTask(const char* config,
|
|
Reporter* reporter,
|
|
TaskRunner* tasks,
|
|
BenchRegistry::Factory factory,
|
|
SkColorType colorType)
|
|
: CpuTask(reporter, tasks)
|
|
, fBench(factory(NULL))
|
|
, fName(bench_name(fBench->getName(), config))
|
|
, fColorType(colorType) {}
|
|
|
|
GpuBenchTask::GpuBenchTask(const char* config,
|
|
Reporter* reporter,
|
|
TaskRunner* tasks,
|
|
BenchRegistry::Factory factory,
|
|
GrContextFactory::GLContextType contextType,
|
|
int sampleCount)
|
|
: GpuTask(reporter, tasks)
|
|
, fBench(factory(NULL))
|
|
, fName(bench_name(fBench->getName(), config))
|
|
, fContextType(contextType)
|
|
, fSampleCount(sampleCount) {}
|
|
|
|
bool NonRenderingBenchTask::shouldSkip() const {
|
|
return !fBench->isSuitableFor(Benchmark::kNonRendering_Backend);
|
|
}
|
|
|
|
bool CpuBenchTask::shouldSkip() const {
|
|
return !fBench->isSuitableFor(Benchmark::kRaster_Backend);
|
|
}
|
|
|
|
bool GpuBenchTask::shouldSkip() const {
|
|
return kGPUDisabled || !fBench->isSuitableFor(Benchmark::kGPU_Backend);
|
|
}
|
|
|
|
static void draw_raster(Benchmark* bench, SkColorType colorType) {
|
|
SkBitmap bitmap;
|
|
AllocatePixels(colorType, bench->getSize().x(), bench->getSize().y(), &bitmap);
|
|
SkCanvas canvas(bitmap);
|
|
|
|
bench->preDraw();
|
|
bench->draw(1, &canvas);
|
|
}
|
|
|
|
void NonRenderingBenchTask::draw() {
|
|
draw_raster(fBench.get(), kN32_SkColorType);
|
|
}
|
|
|
|
void CpuBenchTask::draw() {
|
|
draw_raster(fBench.get(), fColorType);
|
|
}
|
|
|
|
void GpuBenchTask::draw(GrContextFactory* grFactory) {
|
|
SkImageInfo info = SkImageInfo::Make(fBench->getSize().x(),
|
|
fBench->getSize().y(),
|
|
kN32_SkColorType,
|
|
kPremul_SkAlphaType);
|
|
SkAutoTUnref<SkSurface> surface(NewGpuSurface(grFactory, fContextType, info, fSampleCount));
|
|
|
|
fBench->preDraw();
|
|
fBench->draw(1, surface->getCanvas());
|
|
}
|
|
|
|
} // namespace DM
|