// Copyright 2017 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef COMPONENTS_SERVICES_HEAP_PROFILING_PUBLIC_CPP_PROFILING_CLIENT_H_ #define COMPONENTS_SERVICES_HEAP_PROFILING_PUBLIC_CPP_PROFILING_CLIENT_H_ #include "components/services/heap_profiling/public/mojom/heap_profiling_client.mojom.h" #include "mojo/public/cpp/bindings/pending_receiver.h" #include "mojo/public/cpp/bindings/receiver_set.h" namespace heap_profiling { // The Client listens on the interface for a StartProfiling message. On // receiving the message, it begins profiling the current process. // // The owner of this object is responsible for binding it to the BinderRegistry. class ProfilingClient : public mojom::ProfilingClient { … }; // Initializes the TLS slot globally. This will be called early in Chrome's // lifecycle to prevent re-entrancy from occurring while trying to set up the // TLS slot, which is the entity that's supposed to prevent re-entrancy. void InitTLSSlot(); // Exists for testing only. // A return value of |true| means that the allocator shim was already // initialized and |callback| will never be called. Otherwise, |callback| will // be called on |task_runner| after the allocator shim is initialized. bool SetOnInitAllocatorShimCallbackForTesting( base::OnceClosure callback, scoped_refptr<base::TaskRunner> task_runner); } // namespace heap_profiling #endif // COMPONENTS_SERVICES_HEAP_PROFILING_PUBLIC_CPP_PROFILING_CLIENT_H_