Files
swift-mirror/stdlib/public/runtime/Tracing.cpp
Mike Ash dd24d8e71f [Runtime] Don't emit signposts until the system is ready.
Emitting a signpost for the first time can trigger lazy setup of the logging system, and doing this in the wrong context can cause deadlocks. Check to see if the logging system is already set up, and only emit signposts if it has been to avoid triggering this.

As it's hard to determine if the "is it set up?" function is available in the SDK we're building against, only do this in OS builds, as it's not particularly useful in local builds.

rdar://124620772
2024-05-15 11:02:23 -04:00

47 lines
1.2 KiB
C++

//===--- Tracing.cpp - Support code for runtime tracing ------------*- C++ -*-//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2021 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
//
// Support code for tracing events in the Swift runtime
//
//===----------------------------------------------------------------------===//
#include "Tracing.h"
#if SWIFT_STDLIB_TRACING
#define SWIFT_LOG_SUBSYSTEM "com.apple.swift"
#define SWIFT_LOG_SECTION_SCAN_CATEGORY "SectionScan"
namespace swift {
namespace runtime {
namespace trace {
os_log_t ScanLog;
swift::once_t LogsToken;
bool TracingEnabled;
void setupLogs(void *unused) {
if (!shouldEnableTracing()) {
TracingEnabled = false;
return;
}
TracingEnabled = true;
ScanLog = os_log_create(SWIFT_LOG_SUBSYSTEM, SWIFT_LOG_SECTION_SCAN_CATEGORY);
}
} // namespace trace
} // namespace runtime
} // namespace swift
#endif