| /* |
| * Copyright 2012 Google Inc. |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| #include "SkBenchmark.h" |
| #include "SkCanvas.h" |
| #include "SkChecksum.h" |
| #include "SkCityHash.h" |
| #include "SkMD5.h" |
| #include "SkRandom.h" |
| #include "SkSHA1.h" |
| |
| template<typename T> inline void sk_ignore_unused(const T&) { } |
| |
| enum ChecksumType { |
| kChecksum_ChecksumType, |
| kMD5_ChecksumType, |
| kSHA1_ChecksumType, |
| kCityHash32, |
| kCityHash64 |
| }; |
| |
| class ComputeChecksumBench : public SkBenchmark { |
| enum { |
| U32COUNT = 256, |
| SIZE = U32COUNT * 4, |
| N = SkBENCHLOOP(100000), |
| }; |
| uint32_t fData[U32COUNT]; |
| ChecksumType fType; |
| |
| public: |
| ComputeChecksumBench(void* param, ChecksumType type) : INHERITED(param), fType(type) { |
| SkRandom rand; |
| for (int i = 0; i < U32COUNT; ++i) { |
| fData[i] = rand.nextU(); |
| } |
| fIsRendering = false; |
| } |
| |
| protected: |
| virtual const char* onGetName() { |
| switch (fType) { |
| case kChecksum_ChecksumType: return "compute_checksum"; |
| case kMD5_ChecksumType: return "compute_md5"; |
| case kSHA1_ChecksumType: return "compute_sha1"; |
| case kCityHash32: return "compute_cityhash32"; |
| case kCityHash64: return "compute_cityhash64"; |
| default: SK_CRASH(); return ""; |
| } |
| } |
| |
| virtual void onDraw(SkCanvas* canvas) { |
| switch (fType) { |
| case kChecksum_ChecksumType: { |
| for (int i = 0; i < N; i++) { |
| volatile uint32_t result = SkChecksum::Compute(fData, sizeof(fData)); |
| sk_ignore_unused(result); |
| } |
| } break; |
| case kMD5_ChecksumType: { |
| for (int i = 0; i < N; i++) { |
| SkMD5 md5; |
| md5.update(reinterpret_cast<uint8_t*>(fData), sizeof(fData)); |
| SkMD5::Digest digest; |
| md5.finish(digest); |
| sk_ignore_unused(digest); |
| } |
| } break; |
| case kSHA1_ChecksumType: { |
| for (int i = 0; i < N; i++) { |
| SkSHA1 sha1; |
| sha1.update(reinterpret_cast<uint8_t*>(fData), sizeof(fData)); |
| SkSHA1::Digest digest; |
| sha1.finish(digest); |
| sk_ignore_unused(digest); |
| } |
| } break; |
| case kCityHash32: { |
| for (int i = 0; i < N; i++) { |
| volatile uint32_t result = SkCityHash::Compute32(reinterpret_cast<char*>(fData), sizeof(fData)); |
| sk_ignore_unused(result); |
| } |
| } break; |
| case kCityHash64: { |
| for (int i = 0; i < N; i++) { |
| volatile uint64_t result = SkCityHash::Compute64(reinterpret_cast<char*>(fData), sizeof(fData)); |
| sk_ignore_unused(result); |
| } |
| } break; |
| } |
| |
| } |
| |
| private: |
| typedef SkBenchmark INHERITED; |
| }; |
| |
| /////////////////////////////////////////////////////////////////////////////// |
| |
| static SkBenchmark* Fact0(void* p) { return new ComputeChecksumBench(p, kChecksum_ChecksumType); } |
| static SkBenchmark* Fact1(void* p) { return new ComputeChecksumBench(p, kMD5_ChecksumType); } |
| static SkBenchmark* Fact2(void* p) { return new ComputeChecksumBench(p, kSHA1_ChecksumType); } |
| static SkBenchmark* Fact3(void* p) { return new ComputeChecksumBench(p, kCityHash32); } |
| static SkBenchmark* Fact4(void* p) { return new ComputeChecksumBench(p, kCityHash64); } |
| |
| static BenchRegistry gReg0(Fact0); |
| static BenchRegistry gReg1(Fact1); |
| static BenchRegistry gReg2(Fact2); |
| static BenchRegistry gReg3(Fact3); |
| static BenchRegistry gReg4(Fact4); |