diff options
author | rsesek@chromium.org <rsesek@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-07-17 06:36:54 +0000 |
---|---|---|
committer | rsesek@chromium.org <rsesek@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-07-17 06:36:54 +0000 |
commit | 6e9bfe1e87c80238666d32878e18322e108d8700 (patch) | |
tree | aa1899cb7109d5c9edbd44b68d601342e5c4fef6 /sandbox/mac/dispatch_source_mach.h | |
parent | ff84e05ab824d27fc77890028afa15b2635ff4cd (diff) | |
download | chromium_src-6e9bfe1e87c80238666d32878e18322e108d8700.zip chromium_src-6e9bfe1e87c80238666d32878e18322e108d8700.tar.gz chromium_src-6e9bfe1e87c80238666d32878e18322e108d8700.tar.bz2 |
Create DispatchSourceMach to run a MACH_RECV dispatch source.
This implements RAII semantics so that when the destructor runs, the source
is cancelled and event handler blocks cannot call methods on a destructed
object.
BUG=382931
R=mark@chromium.org
Review URL: https://codereview.chromium.org/392273002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@283664 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'sandbox/mac/dispatch_source_mach.h')
-rw-r--r-- | sandbox/mac/dispatch_source_mach.h | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/sandbox/mac/dispatch_source_mach.h b/sandbox/mac/dispatch_source_mach.h new file mode 100644 index 0000000..e7234f8 --- /dev/null +++ b/sandbox/mac/dispatch_source_mach.h @@ -0,0 +1,61 @@ +// Copyright 2014 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 SANDBOX_MAC_DISPATCH_SOURCE_MACH_H_ +#define SANDBOX_MAC_DISPATCH_SOURCE_MACH_H_ + +#include <dispatch/dispatch.h> + +#include "base/basictypes.h" +#include "sandbox/sandbox_export.h" + +namespace sandbox { + +// This class encapsulates a MACH_RECV dispatch source. When this object is +// destroyed, the source will be cancelled and it will wait for the source +// to stop executing work. The source can run on either a user-supplied queue, +// or it can create its own for the source. +class SANDBOX_EXPORT DispatchSourceMach { + public: + // Creates a new dispatch source for the |port| and schedules it on a new + // queue that will be created with |name|. When a Mach message is received, + // the |event_handler| will be called. + DispatchSourceMach(const char* name, + mach_port_t port, + void (^event_handler)()); + + // Creates a new dispatch source with the same semantics as above, but rather + // than creating a new queue, it schedules the source on |queue|. + DispatchSourceMach(dispatch_queue_t queue, + mach_port_t port, + void (^event_handler)()); + + // Cancels the source and waits for it to become fully cancelled before + // releasing the source. + ~DispatchSourceMach(); + + // Resumes the source. This must be called before any Mach messages will + // be received. + void Resume(); + + private: + // Cancels the source, after which this class will no longer receive Mach + // messages. Calling this more than once is a no-op. + void Cancel(); + + // The dispatch queue used to service the source_. + dispatch_queue_t queue_; + + // A MACH_RECV dispatch source. + dispatch_source_t source_; + + // Semaphore used to wait on the |source_|'s cancellation in the destructor. + dispatch_semaphore_t source_canceled_; + + DISALLOW_COPY_AND_ASSIGN(DispatchSourceMach); +}; + +} // namespace sandbox + +#endif // SANDBOX_MAC_DISPATCH_SOURCE_MACH_H_ |