Loading...
cache_builder/Timer.h /dev/null dyld-1340
--- /dev/null
+++ dyld/dyld-1340/cache_builder/Timer.h
@@ -0,0 +1,117 @@
+/* -*- mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
+*
+* Copyright (c) 2017 Apple Inc. All rights reserved.
+*
+* @APPLE_LICENSE_HEADER_START@
+*
+* This file contains Original Code and/or Modifications of Original Code
+* as defined in and that are subject to the Apple Public Source License
+* Version 2.0 (the 'License'). You may not use this file except in
+* compliance with the License. Please obtain a copy of the License at
+* http://www.opensource.apple.com/apsl/ and read it before using this
+* file.
+*
+* The Original Code and all software distributed under the License are
+* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
+* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
+* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
+* FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
+* Please see the License for the specific language governing rights and
+* limitations under the License.
+*
+* @APPLE_LICENSE_HEADER_END@
+*/
+
+#ifndef Timer_hpp
+#define Timer_hpp
+
+#include "BuilderOptions.h"
+
+#include <os/signpost.h>
+#include <string_view>
+
+namespace cache_builder
+{
+
+struct BuilderConfig;
+
+struct Timer
+{
+    Timer();
+
+    struct Scope
+    {
+        Scope(const BuilderConfig& config, std::string_view name);
+        ~Scope();
+
+    private:
+        const BuilderConfig&    config;
+        std::string_view        name;
+        os_log_t                log;
+        os_signpost_id_t        signpost;
+        uint64_t                startTimeNanos = 0;
+    };
+
+    // Similar to Scope, but aggregates multiple clients to a single time.  Eg, every dylib
+    // has a "binding" Timer::Scope, and its too noisy to print them all for 2000 dylibs
+    struct AggregateTimer
+    {
+        AggregateTimer(const BuilderConfig& config);
+        ~AggregateTimer();
+        void record(std::string_view name, uint64_t startTime, uint64_t endTime);
+
+        // FIXME: Should we just have an AggregateTimer* in Timer::Scope instead?
+        struct Scope
+        {
+            Scope(AggregateTimer& timer, std::string_view name);
+            ~Scope();
+
+        private:
+            AggregateTimer&         timer;
+            std::string_view        name;
+            uint64_t                startTimeNanos = 0;
+        };
+
+    private:
+        const BuilderConfig&                                config;
+        std::unordered_map<std::string_view, uint32_t>      timeMap;
+        std::vector<std::pair<std::string_view, uint64_t>>  timesNanos;
+        pthread_mutex_t                                     mapLock;
+    };
+
+private:
+    os_log_t            log;
+    os_signpost_id_t    signpost;
+};
+
+struct Stats
+{
+    Stats(const BuilderConfig& config);
+    ~Stats();
+
+    void add(const char* format, ...)  __attribute__((format(printf, 2, 3)));
+
+private:
+    const BuilderConfig& config;
+    std::vector<std::string> stats;
+};
+
+struct Logger
+{
+    Logger(const BuilderOptions& options);
+
+    void log(const char* format, ...)  const __attribute__((format(printf, 2, 3)));
+
+    bool printTimers            = false;
+    bool printStats             = false;
+    bool printDebug             = false;
+    bool printDebugIMPCaches    = false;
+    bool printDebugCacheLayout  = false;
+
+private:
+    std::string logPrefix;
+};
+
+} // namespace cache_builder
+
+#endif /* Timer_hpp */