mirror of
https://fuchsia.googlesource.com/third_party/pigweed.googlesource.com/pigweed/pigweed
synced 2024-09-20 22:00:58 +00:00
1502a40b68
Updates the pw_trace_tokenized's host_trace_time backend to use the std::chrono::steady_clock which is monotonic, instead of the std::chrono::system_clock which may unexpectedly jump backwards causing odd trace artifacts. Change-Id: I42749e7a8272650c23f2ff420615a23191df3b1a Reviewed-on: https://pigweed-review.googlesource.com/c/pigweed/pigweed/+/23222 Reviewed-by: Rob Oliver <rgoliver@google.com> Reviewed-by: Keir Mierle <keir@google.com> Commit-Queue: Auto-Submit <auto-submit@pigweed.google.com.iam.gserviceaccount.com> Pigweed-Auto-Submit: Ewout van Bekkum <ewout@google.com>
37 lines
1.1 KiB
C++
37 lines
1.1 KiB
C++
// Copyright 2020 The Pigweed Authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
// use this file except in compliance with the License. You may obtain a copy of
|
|
// the License at
|
|
//
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
// License for the specific language governing permissions and limitations under
|
|
// the License.
|
|
//==============================================================================
|
|
//
|
|
|
|
#include <chrono>
|
|
|
|
#include "pw_trace_tokenized/trace_tokenized.h"
|
|
|
|
using namespace std::chrono;
|
|
|
|
namespace {
|
|
|
|
auto start = steady_clock::now();
|
|
|
|
} // namespace
|
|
|
|
// Define trace time as a counter for tests.
|
|
PW_TRACE_TIME_TYPE pw_trace_GetTraceTime() {
|
|
auto delta = steady_clock::now() - start;
|
|
return duration_cast<microseconds>(delta).count();
|
|
}
|
|
|
|
// Microsecond time source
|
|
size_t pw_trace_GetTraceTimeTicksPerSecond() { return 1000000; }
|