Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1091)

Unified Diff: services/service_manager/runner/host/mach_broker.h

Issue 2566663004: Revert of Build services as standalone executables (Closed)
Patch Set: Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: services/service_manager/runner/host/mach_broker.h
diff --git a/services/service_manager/runner/host/mach_broker.h b/services/service_manager/runner/host/mach_broker.h
new file mode 100644
index 0000000000000000000000000000000000000000..5d139da9916a7bb9ec31ef1cba501655eb7b5687
--- /dev/null
+++ b/services/service_manager/runner/host/mach_broker.h
@@ -0,0 +1,53 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef SERVICES_SERVICE_MANAGER_RUNNER_HOST_MACH_BROKER_H_
+#define SERVICES_SERVICE_MANAGER_RUNNER_HOST_MACH_BROKER_H_
+
+#include "base/mac/mach_port_broker.h"
+
+namespace base {
+template <typename T> struct DefaultSingletonTraits;
+}
+
+namespace service_manager {
+
+// A global singleton |MachBroker| is used by the service manager to provide
+// access to
+// Mach task ports for service manager out-of-process applications.
+class MachBroker {
+ public:
+ // Sends the task port of the current process to the parent over Mach IPC.
+ // For use in child processes.
+ static void SendTaskPortToParent();
+
+ // Returns the global |MachBroker|. For use in the service manager.
+ static MachBroker* GetInstance();
+
+ // Registers |pid| with a MACH_PORT_NULL task port in the port provider. A
+ // child's pid must be registered before the broker will accept a task port
+ // from that child.
+ // Callers MUST acquire the lock given by GetLock() before calling this method
+ // (and release the lock afterwards).
+ void ExpectPid(base::ProcessHandle pid);
+
+ // Removes |pid| from the port provider.
+ // Callers MUST acquire the lock given by GetLock() before calling this method
+ // (and release the lock afterwards).
+ void RemovePid(base::ProcessHandle pid);
+
+ base::Lock& GetLock() { return broker_.GetLock(); }
+ base::PortProvider* port_provider() { return &broker_; }
+
+ private:
+ MachBroker();
+ ~MachBroker();
+ friend struct base::DefaultSingletonTraits<MachBroker>;
+
+ base::MachPortBroker broker_;
+};
+
+} // namespace service_manager
+
+#endif // SERVICES_SERVICE_MANAGER_RUNNER_HOST_MACH_BROKER_H_
« no previous file with comments | « services/service_manager/runner/host/linux_sandbox.cc ('k') | services/service_manager/runner/host/mach_broker.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698