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

Unified Diff: third_party/mojo/src/mojo/edk/system/channel_manager.h

Issue 954643002: Update mojo sdk to rev 3d23dae011859a2aae49f1d1adde705c8e85d819 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: use run_renderer_in_process() Created 5 years, 10 months 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: third_party/mojo/src/mojo/edk/system/channel_manager.h
diff --git a/third_party/mojo/src/mojo/edk/system/channel_manager.h b/third_party/mojo/src/mojo/edk/system/channel_manager.h
index da3e030929caa5b194932dcd1aaa589af8baedf4..77ff953b5b36a41f8a0c8eeb35413e33b2c59c27 100644
--- a/third_party/mojo/src/mojo/edk/system/channel_manager.h
+++ b/third_party/mojo/src/mojo/edk/system/channel_manager.h
@@ -29,6 +29,7 @@ namespace system {
class Channel;
class ChannelEndpoint;
+class ConnectionManager;
class MessagePipeDispatcher;
// IDs for |Channel|s managed by a |ChannelManager|. (IDs should be thought of
@@ -42,17 +43,37 @@ const ChannelId kInvalidChannelId = 0;
// specifically noted.
class MOJO_SYSTEM_IMPL_EXPORT ChannelManager {
public:
- // |*platform_support| must remain alive longer than this object.
- explicit ChannelManager(embedder::PlatformSupport* platform_support);
+ // |io_thread_task_runner| should be the |TaskRunner| for the I/O thread, on
+ // which this channel manager will create all channels. Connection manager is
+ // optional and may be null. All arguments (if non-null) must remain alive at
+ // least until after shutdown completion.
+ ChannelManager(embedder::PlatformSupport* platform_support,
+ scoped_refptr<base::TaskRunner> io_thread_task_runner,
+ ConnectionManager* connection_manager);
~ChannelManager();
+ // Shuts down the channel manager, including shutting down all channels (as if
+ // |ShutdownChannelOnIOThread()| were called for each channel). This must be
+ // called from the I/O thread (given to the constructor) and completes
+ // synchronously. This, or |Shutdown()|, must be called before destroying this
+ // object.
+ void ShutdownOnIOThread();
+
+ // Like |ShutdownOnIOThread()|, but may be called from any thread. On
+ // completion, will call |callback| ("on" |io_thread_task_runner| if
+ // |callback_thread_task_runner| is null else by posted using
+ // |callback_thread_task_runner|). Note: This will always post a task to the
+ // I/O thread, even it is the current thread.
+ // TODO(vtl): Consider if this is really necessary, since it only has one use
+ // (in tests).
+ void Shutdown(const base::Closure& callback,
+ scoped_refptr<base::TaskRunner> callback_thread_task_runner);
+
// Creates a |Channel| and adds it to the set of channels managed by this
- // |ChannelManager|. |channel_id| should be a valid |ChannelId| (i.e.,
- // nonzero) not "assigned" to any other |Channel| being managed by this
+ // |ChannelManager|. This must be called from the I/O thread (given to the
+ // constructor). |channel_id| should be a valid |ChannelId| (i.e., nonzero)
+ // not "assigned" to any other |Channel| being managed by this
// |ChannelManager|.
- // TODO(vtl): Currently, this should be called on any I/O thread (which will
- // become the new channel's "channel thread"). Eventually, the channel manager
- // will have an assigned I/O thread, on which this must be called.
scoped_refptr<MessagePipeDispatcher> CreateChannelOnIOThread(
ChannelId channel_id,
embedder::ScopedPlatformHandle platform_handle);
@@ -69,7 +90,7 @@ class MOJO_SYSTEM_IMPL_EXPORT ChannelManager {
ChannelId channel_id,
embedder::ScopedPlatformHandle platform_handle,
scoped_refptr<base::TaskRunner> io_thread_task_runner,
- base::Closure callback,
+ const base::Closure& callback,
scoped_refptr<base::TaskRunner> callback_thread_task_runner);
// Gets the |Channel| with the given ID (which must exist).
@@ -82,14 +103,31 @@ class MOJO_SYSTEM_IMPL_EXPORT ChannelManager {
// the channel).
void WillShutdownChannel(ChannelId channel_id);
- // Shuts down the channel specified by the given ID. It is up to the caller to
- // guarantee that this is only called once per channel (that was added using
- // |CreateChannelOnIOThread()|). If called from the channel's creation thread
- // (i.e., |base::MessageLoopProxy::current()| is the channel thread's
- // |TaskRunner|), this will complete synchronously.
- void ShutdownChannel(ChannelId channel_id);
+ // Shuts down the channel specified by the given ID. This, or
+ // |ShutdownChannel()|, should be called once per channel (created using
+ // |CreateChannelOnIOThread()| or |CreateChannel()|). This must be called from
+ // the channel's "channel thread", and completes synchronously.
+ // TODO(vtl): "channel thread" will become "this object's I/O thread".
+ void ShutdownChannelOnIOThread(ChannelId channel_id);
+
+ // Like |ShutdownChannelOnIOThread()|, but may be called from any thread. It
+ // will always post a task to the channel's "channel thread", and post
+ // |callback| to |callback_thread_task_runner| (or execute it directly on the
+ // "channel thread" if |callback_thread_task_runner| is null) on completion.
+ // TODO(vtl): "channel thread" will become "this object's I/O thread".
+ void ShutdownChannel(
+ ChannelId channel_id,
+ const base::Closure& callback,
+ scoped_refptr<base::TaskRunner> callback_thread_task_runner);
+
+ ConnectionManager* connection_manager() const { return connection_manager_; }
private:
+ // Used by |Shutdown()|. Called on the I/O thread.
+ void ShutdownHelper(
+ const base::Closure& callback,
+ scoped_refptr<base::TaskRunner> callback_thread_task_runner);
+
// Used by |CreateChannelOnIOThread()| and |CreateChannelHelper()|. Called on
// the I/O thread.
void CreateChannelOnIOThreadHelper(
@@ -102,10 +140,13 @@ class MOJO_SYSTEM_IMPL_EXPORT ChannelManager {
ChannelId channel_id,
embedder::ScopedPlatformHandle platform_handle,
scoped_refptr<system::ChannelEndpoint> bootstrap_channel_endpoint,
- base::Closure callback,
+ const base::Closure& callback,
scoped_refptr<base::TaskRunner> callback_thread_task_runner);
+ // Note: These must not be used after shutdown.
embedder::PlatformSupport* const platform_support_;
+ const scoped_refptr<base::TaskRunner> io_thread_task_runner_;
+ ConnectionManager* const connection_manager_;
// Note: |Channel| methods should not be called under |lock_|.
mutable base::Lock lock_; // Protects the members below.
« no previous file with comments | « third_party/mojo/src/mojo/edk/system/async_waiter.cc ('k') | third_party/mojo/src/mojo/edk/system/channel_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698