Chromium Code Reviews| Index: ipc/mach_port_mac.h |
| diff --git a/ipc/mach_port_mac.h b/ipc/mach_port_mac.h |
| index 0193f9dadd91f76ac796e0a8c86b49afe1f01ba2..78a955b40fc5993e55e8f3c5d1608d2d8c6ceaf5 100644 |
| --- a/ipc/mach_port_mac.h |
| +++ b/ipc/mach_port_mac.h |
| @@ -7,24 +7,53 @@ |
| #include <mach/mach.h> |
| +#include "base/macros.h" |
| #include "ipc/ipc_export.h" |
| #include "ipc/ipc_message_macros.h" |
| namespace IPC { |
| -// MachPortMac is a wrapper around an OSX mach_port_t that can be transported |
| -// across Chrome IPC channels that support attachment brokering. The mach_port_t |
| +// MachPortMac is a wrapper around an OSX Mach port that can be transported |
| +// across Chrome IPC channels that support attachment brokering. The Mach port |
| // will be duplicated into the destination process by the attachment broker. |
| +// For now, this class only supports Mach ports with a send right. If needed, |
|
Tom Sepez
2015/10/06 16:09:09
Nit: Forgive my limited understanding, but I thoug
erikchen
2015/10/06 20:40:43
I do mean what you wrote, and I updated my comment
|
| +// attachment brokering can be trivially extended to support Mach ports with |
| +// other rights. |
| class IPC_EXPORT MachPortMac { |
| public: |
| MachPortMac() : mach_port_(MACH_PORT_NULL) {} |
| - explicit MachPortMac(const mach_port_t& mach_port) : mach_port_(mach_port) {} |
| + |
| + // This constructor increments the ref count of |mach_port|. |
| + explicit MachPortMac(const mach_port_t& mach_port); |
|
Tom Sepez
2015/10/06 16:09:09
nit: is it really const if its being modified?
erikchen
2015/10/06 20:40:42
mach_port_t is typedefed to int - I changed the pa
|
| mach_port_t get_mach_port() const { return mach_port_; } |
| + |
| + // This method should only be used by ipc/ translation code. |
| void set_mach_port(mach_port_t mach_port) { mach_port_ = mach_port; } |
|
Tom Sepez
2015/10/06 16:09:09
nit: do you want to pass by const reference here?
erikchen
2015/10/06 20:40:43
Nah, I got rid of the other const ref as well.
|
| private: |
| + // The ownership semantics of |mach_port_| are a little confusing, and cannot |
|
Tom Sepez
2015/10/06 16:09:09
nit: s/are a little confusing, and//.
erikchen
2015/10/06 20:40:43
Done.
|
| + // be easily expressed with a C++ scoped object. This is partly due to the |
| + // mechanism by which Mach ports are brokered, and partly due to the |
| + // architecture of Chrome IPC. |
| + // |
| + // From the sender process's perspective, this class is just a wrapper. It |
|
Tom Sepez
2015/10/06 16:09:09
nit: what are the other perspectives? hmm. I get
erikchen
2015/10/06 20:40:43
Right - I removed the word "perspective" from the
|
| + // calls Send(new Message(MachPortMac(mach_port))) and continues on its merry |
| + // way. Behind the scenes, this class increments the ref count on |mach_port_| |
| + // to ensure that the object stays alive. |
|
Tom Sepez
2015/10/06 16:09:09
nit: which object is that? I'm confused.
erikchen
2015/10/06 20:40:43
I got rid of this comment.
|
| + // |
| + // The broker process receives a reference to the name of this Mach port. It |
|
Tom Sepez
2015/10/06 16:09:09
nit: when does this happen? first time we mention
erikchen
2015/10/06 20:40:42
I updated the comments to add slightly more detail
|
| + // copies the right into the destination process, and then decrements the ref |
|
Tom Sepez
2015/10/06 16:09:09
nit: send right
erikchen
2015/10/06 20:40:43
I updated the top level class comment to use "send
|
| + // count in the original process. Note that a different process is |
|
Tom Sepez
2015/10/06 16:09:09
nit: why is the note important? The OS takes care
erikchen
2015/10/06 20:40:42
A different process is decrementing the ref count,
|
| + // decrementing the ref count! |
| + // |
| + // From the receiver process's perspective, a Mach port was magically inserted |
| + // into its name space. The attachment broker is responsible for coupling the |
| + // Mach port with Chrome IPC in the form of a MessageAttachment. When the |
| + // client code receives a callback with the parameter MachPortMac, it then |
| + // assumes ownership of the Mach port. |
| mach_port_t mach_port_; |
| + DISALLOW_COPY_AND_ASSIGN(MachPortMac); |
| }; |
| template <> |