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 | |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 8 | #include "include/private/SkOnce.h" |
| 9 | #include "include/utils/SkEventTracer.h" |
Mike Klein | b24f7f4 | 2018-12-04 09:05:26 -0500 | [diff] [blame] | 10 | #include <atomic> |
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; |
Mike Klein | b24f7f4 | 2018-12-04 09:05:26 -0500 | [diff] [blame] | 43 | static std::atomic<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; |
Mike Klein | b24f7f4 | 2018-12-04 09:05:26 -0500 | [diff] [blame] | 47 | if (!gUserTracer.compare_exchange_strong(expected, tracer)) { |
Brian Salomon | 175f588 | 2017-05-12 12:02:50 -0400 | [diff] [blame] | 48 | delete tracer; |
| 49 | return false; |
| 50 | } |
Mike Klein | b24f7f4 | 2018-12-04 09:05:26 -0500 | [diff] [blame] | 51 | atexit([]() { delete gUserTracer.load(); }); |
Brian Salomon | 175f588 | 2017-05-12 12:02:50 -0400 | [diff] [blame] | 52 | return true; |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 53 | } |
| 54 | |
| 55 | SkEventTracer* SkEventTracer::GetInstance() { |
Mike Klein | b24f7f4 | 2018-12-04 09:05:26 -0500 | [diff] [blame] | 56 | if (auto tracer = gUserTracer.load(std::memory_order_acquire)) { |
mtklein | 59bcfae | 2015-04-21 09:38:03 -0700 | [diff] [blame] | 57 | return tracer; |
| 58 | } |
mtklein | ffa4a92 | 2016-05-05 16:05:56 -0700 | [diff] [blame] | 59 | static SkOnce once; |
| 60 | static SkDefaultEventTracer* defaultTracer; |
| 61 | once([] { defaultTracer = new SkDefaultEventTracer; }); |
| 62 | return defaultTracer; |
commit-bot@chromium.org | 6169f2b | 2014-01-31 00:04:25 +0000 | [diff] [blame] | 63 | } |