mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
We can't use os_log functionality in logd, diagnosticd, or notifyd. Check for them and disable tracing in those processes. Add a new TracingCommon.h for common code shared between swiftCore and swift_Concurrency tracing. Add a single function that checks if tracing should be enabled, which now checks if os_signpost_enabled is available, and if the process is one of these. Modify the tracing code to check this before creating os_log objects. rdar://124226334
54 lines
1.5 KiB
C++
54 lines
1.5 KiB
C++
//===--- TracingSignpost.cpp - Tracing with the signpost API -------*- 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Concurrency tracing implemented with the os_signpost API.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#if SWIFT_STDLIB_CONCURRENCY_TRACING
|
|
|
|
#include "TracingSignpost.h"
|
|
#include "swift/Runtime/TracingCommon.h"
|
|
#include <stdio.h>
|
|
|
|
#define SWIFT_LOG_CONCURRENCY_SUBSYSTEM "com.apple.swift.concurrency"
|
|
#define SWIFT_LOG_ACTOR_CATEGORY "Actor"
|
|
#define SWIFT_LOG_TASK_CATEGORY "Task"
|
|
|
|
namespace swift {
|
|
namespace concurrency {
|
|
namespace trace {
|
|
|
|
os_log_t ActorLog;
|
|
os_log_t TaskLog;
|
|
swift::once_t LogsToken;
|
|
bool TracingEnabled;
|
|
|
|
void setupLogs(void *unused) {
|
|
if (!swift::runtime::trace::shouldEnableTracing()) {
|
|
TracingEnabled = false;
|
|
return;
|
|
}
|
|
|
|
TracingEnabled = true;
|
|
ActorLog = os_log_create(SWIFT_LOG_CONCURRENCY_SUBSYSTEM,
|
|
SWIFT_LOG_ACTOR_CATEGORY);
|
|
TaskLog = os_log_create(SWIFT_LOG_CONCURRENCY_SUBSYSTEM,
|
|
SWIFT_LOG_TASK_CATEGORY);
|
|
}
|
|
|
|
} // namespace trace
|
|
} // namespace concurrency
|
|
} // namespace swift
|
|
|
|
#endif
|