Files
swift-mirror/stdlib/public/runtime/Tracing.cpp
Mike Ash 110f428780 [Runtime] Add tracing for section scans.
Section scans (for metadata, protocols, etc.) can be costly. This change adds tracing calls to those scans so we can more easily see how much time is spent in these scans and where they're initiated.

This adds an os_signpost implementation controlled by SWIFT_STDLIB_TRACING, and a default empty implementation for when that's disabled.

rdar://110266743
2023-06-14 12:07:44 -04:00

40 lines
1.1 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;
void setupLogs(void *unused) {
ScanLog = os_log_create(SWIFT_LOG_SUBSYSTEM, SWIFT_LOG_SECTION_SCAN_CATEGORY);
}
} // namespace trace
} // namespace runtime
} // namespace swift
#endif