commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2014 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 8 | #include "SkAtomics.h" |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 9 | #include "SkEventTracer.h" |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 10 | #include "SkLazyPtr.h" |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 11 | |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 12 | class SkDefaultEventTracer : public SkEventTracer { |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 13 | SkEventTracer::Handle |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 14 | addTraceEvent(char phase, |
| 15 | const uint8_t* categoryEnabledFlag, |
| 16 | const char* name, |
| 17 | uint64_t id, |
| 18 | int numArgs, |
| 19 | const char** argNames, |
| 20 | const uint8_t* argTypes, |
| 21 | const uint64_t* argValues, |
mtklein | 36352bf | 2015-03-25 18:17:31 -0700 | [diff] [blame] | 22 | uint8_t flags) override { return 0; } |
skia.committer@gmail.com | 4c18e9f | 2014-01-31 03:01:59 +0000 | [diff] [blame] | 23 | |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 24 | void |
skia.committer@gmail.com | 4c18e9f | 2014-01-31 03:01:59 +0000 | [diff] [blame] | 25 | updateTraceEventDuration(const uint8_t* categoryEnabledFlag, |
| 26 | const char* name, |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 27 | SkEventTracer::Handle handle) override {} |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 28 | |
mtklein | 36352bf | 2015-03-25 18:17:31 -0700 | [diff] [blame] | 29 | const uint8_t* getCategoryGroupEnabled(const char* name) override { |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 30 | static uint8_t no = 0; |
| 31 | return &no; |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 32 | } |
| 33 | const char* getCategoryGroupName( |
mtklein | 36352bf | 2015-03-25 18:17:31 -0700 | [diff] [blame] | 34 | const uint8_t* categoryEnabledFlag) override { |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 35 | static const char* dummy = "dummy"; |
| 36 | return dummy; |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 37 | } |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 38 | }; |
| 39 | |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 40 | // We prefer gUserTracer if it's been set, otherwise we fall back on gDefaultTracer. |
| 41 | static SkEventTracer* gUserTracer = nullptr; |
| 42 | SK_DECLARE_STATIC_LAZY_PTR(SkDefaultEventTracer, gDefaultTracer); |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 43 | |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 44 | void SkEventTracer::SetInstance(SkEventTracer* tracer) { |
mtklein | 743be19 | 2015-04-22 20:30:12 -0700 | [diff] [blame] | 45 | SkASSERT(nullptr == sk_atomic_load(&gUserTracer, sk_memory_order_acquire)); |
| 46 | sk_atomic_store(&gUserTracer, tracer, sk_memory_order_release); |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 47 | // An atomic load during process shutdown is probably overkill, but safe overkill. |
mtklein | 743be19 | 2015-04-22 20:30:12 -0700 | [diff] [blame] | 48 | atexit([](){ SkDELETE(sk_atomic_load(&gUserTracer, sk_memory_order_acquire)); }); |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 49 | } |
| 50 | |
| 51 | SkEventTracer* SkEventTracer::GetInstance() { |
mtklein | 743be19 | 2015-04-22 20:30:12 -0700 | [diff] [blame] | 52 | if (SkEventTracer* tracer = sk_atomic_load(&gUserTracer, sk_memory_order_acquire)) { |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 53 | return tracer; |
| 54 | } |
| 55 | return gDefaultTracer.get(); |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 56 | } |