From e45ff46a6587ac0e481a62a85cc42b1a0865d856 Mon Sep 17 00:00:00 2001 From: Mike Reed Date: Wed, 6 Dec 2017 10:47:03 -0500 Subject: add benchType deserial to time deserializing pictures Piece of the larger effort to merge readbuffer and validatingreadbuffer Bug: skia: Change-Id: I79305e27c4712c3b91d213d09d6c2ef24b86e671 Reviewed-on: https://skia-review.googlesource.com/81120 Commit-Queue: Mike Reed Commit-Queue: Mike Klein Reviewed-by: Mike Klein --- bench/nanobench.cpp | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'bench/nanobench.cpp') diff --git a/bench/nanobench.cpp b/bench/nanobench.cpp index 550e0b7744..d475e164e5 100644 --- a/bench/nanobench.cpp +++ b/bench/nanobench.cpp @@ -607,6 +607,7 @@ public: , fGMs(skiagm::GMRegistry::Head()) , fCurrentRecording(0) , fCurrentPiping(0) + , fCurrentDeserialPicture(0) , fCurrentScale(0) , fCurrentSKP(0) , fCurrentSVG(0) @@ -765,6 +766,21 @@ public: return new PipingBench(name.c_str(), pic.get()); } + // Add all .skps as DeserializePictureBenchs. + while (fCurrentDeserialPicture < fSKPs.count()) { + const SkString& path = fSKPs[fCurrentDeserialPicture++]; + sk_sp data = SkData::MakeFromFileName(path.c_str()); + if (!data) { + continue; + } + SkString name = SkOSPath::Basename(path.c_str()); + fSourceType = "skp"; + fBenchType = "deserial"; + fSKPBytes = static_cast(data->size()); + fSKPOps = 0; + return new DeserializePictureBench(name.c_str(), std::move(data)); + } + // Then once each for each scale as SKPBenches (playback). while (fCurrentScale < fScales.count()) { while (fCurrentSKP < fSKPs.count()) { @@ -1091,6 +1107,7 @@ private: const char* fBenchType; // How we bench it: micro, recording, playback, ... int fCurrentRecording; int fCurrentPiping; + int fCurrentDeserialPicture; int fCurrentScale; int fCurrentSKP; int fCurrentSVG; -- cgit v1.2.3