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 | |
herb | b906daf | 2015-09-29 09:37:59 -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 | ffa4a92 | 2016-05-05 16:05:56 -0700 | [diff] [blame] | 10 | #include "SkOnce.h" |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 11 | |
bungeman | 60e0fee | 2015-08-26 05:15:46 -0700 | [diff] [blame] | 12 | #include <stdlib.h> |
| 13 | |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 14 | class SkDefaultEventTracer : public SkEventTracer { |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 15 | SkEventTracer::Handle |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 16 | addTraceEvent(char phase, |
| 17 | const uint8_t* categoryEnabledFlag, |
| 18 | const char* name, |
| 19 | uint64_t id, |
| 20 | int numArgs, |
| 21 | const char** argNames, |
| 22 | const uint8_t* argTypes, |
| 23 | const uint64_t* argValues, |
mtklein | 36352bf | 2015-03-25 18:17:31 -0700 | [diff] [blame] | 24 | uint8_t flags) override { return 0; } |
skia.committer@gmail.com | 4c18e9f | 2014-01-31 03:01:59 +0000 | [diff] [blame] | 25 | |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 26 | void |
skia.committer@gmail.com | 4c18e9f | 2014-01-31 03:01:59 +0000 | [diff] [blame] | 27 | updateTraceEventDuration(const uint8_t* categoryEnabledFlag, |
| 28 | const char* name, |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 29 | SkEventTracer::Handle handle) override {} |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 30 | |
mtklein | 36352bf | 2015-03-25 18:17:31 -0700 | [diff] [blame] | 31 | const uint8_t* getCategoryGroupEnabled(const char* name) override { |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 32 | static uint8_t no = 0; |
| 33 | return &no; |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 34 | } |
| 35 | const char* getCategoryGroupName( |
mtklein | 36352bf | 2015-03-25 18:17:31 -0700 | [diff] [blame] | 36 | const uint8_t* categoryEnabledFlag) override { |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 37 | static const char* dummy = "dummy"; |
| 38 | return dummy; |
tfarina | 283b587 | 2015-04-25 12:59:44 -0700 | [diff] [blame] | 39 | } |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 40 | }; |
| 41 | |
mtklein | ffa4a92 | 2016-05-05 16:05:56 -0700 | [diff] [blame] | 42 | // We prefer gUserTracer if it's been set, otherwise we fall back on a default tracer; |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 43 | static SkEventTracer* gUserTracer = nullptr; |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 44 | |
Brian Salomon | 175f588 | 2017-05-12 12:02:50 -0400 | [diff] [blame] | 45 | bool SkEventTracer::SetInstance(SkEventTracer* tracer) { |
| 46 | SkEventTracer* expected = nullptr; |
| 47 | if (!sk_atomic_compare_exchange(&gUserTracer, &expected, tracer)) { |
| 48 | delete tracer; |
| 49 | return false; |
| 50 | } |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 51 | // An atomic load during process shutdown is probably overkill, but safe overkill. |
Brian Salomon | 175f588 | 2017-05-12 12:02:50 -0400 | [diff] [blame] | 52 | atexit([]() { delete sk_atomic_load(&gUserTracer); }); |
| 53 | return true; |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 54 | } |
| 55 | |
| 56 | SkEventTracer* SkEventTracer::GetInstance() { |
mtklein | 743be19 | 2015-04-22 20:30:12 -0700 | [diff] [blame] | 57 | if (SkEventTracer* tracer = sk_atomic_load(&gUserTracer, sk_memory_order_acquire)) { |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 58 | return tracer; |
| 59 | } |
mtklein | ffa4a92 | 2016-05-05 16:05:56 -0700 | [diff] [blame] | 60 | static SkOnce once; |
| 61 | static SkDefaultEventTracer* defaultTracer; |
| 62 | once([] { defaultTracer = new SkDefaultEventTracer; }); |
| 63 | return defaultTracer; |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 64 | } |