1*19c3b8c2SApple OSS Distributions<h2>mach_msg_header</h2> 2*19c3b8c2SApple OSS Distributions<hr> 3*19c3b8c2SApple OSS Distributions<p> 4*19c3b8c2SApple OSS Distributions<strong>Structure</strong> - Specifies the content of an IPC message header. 5*19c3b8c2SApple OSS Distributions<h3>SYNOPSIS</h3> 6*19c3b8c2SApple OSS Distributions<pre> 7*19c3b8c2SApple OSS Distributions<strong>typedef struct</strong> 8*19c3b8c2SApple OSS Distributions<strong>{</strong> 9*19c3b8c2SApple OSS Distributions <strong>mach_msg_bits_t </strong> <var>msgh_bits</var><strong>;</strong> 10*19c3b8c2SApple OSS Distributions <strong>mach_msg_size_t</strong> <var>msgh_size</var><strong>;</strong> 11*19c3b8c2SApple OSS Distributions <strong>mach_port_t</strong> <var>msgh_remote_port</var><strong>;</strong> 12*19c3b8c2SApple OSS Distributions <strong>mach_port_t</strong> <var>msgh_local_port</var><strong>;</strong> 13*19c3b8c2SApple OSS Distributions <strong>mach_msg_size_t</strong> <var>msgh_reserved</var><strong>;</strong> 14*19c3b8c2SApple OSS Distributions <strong>mach_msg_id_t</strong> <var>msgh_id</var><strong>;</strong> 15*19c3b8c2SApple OSS Distributions<strong>} mach_msg_header_t;</strong> 16*19c3b8c2SApple OSS Distributions 17*19c3b8c2SApple OSS Distributions<strong>typedef struct</strong> 18*19c3b8c2SApple OSS Distributions<strong>{</strong> 19*19c3b8c2SApple OSS Distributions <strong>mach_msg_size_t</strong> <var>msgh_descriptor_count</var><strong>;</strong> 20*19c3b8c2SApple OSS Distributions<strong>} mach_msg_body_t;</strong> 21*19c3b8c2SApple OSS Distributions 22*19c3b8c2SApple OSS Distributions<strong>typedef struct</strong> 23*19c3b8c2SApple OSS Distributions<strong>{</strong> 24*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_type_t</strong> <var>msgh_trailer_type</var><strong>;</strong> 25*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_size_t</strong> <var>msgh_trailer_size</var><strong>;</strong> 26*19c3b8c2SApple OSS Distributions<strong>} mach_msg_trailer_t;</strong> 27*19c3b8c2SApple OSS Distributions 28*19c3b8c2SApple OSS Distributions<strong>typedef struct</strong> 29*19c3b8c2SApple OSS Distributions<strong>{</strong> 30*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_type_t</strong> <var>msgh_trailer_type</var><strong>;</strong> 31*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_size_t</strong> <var>msgh_trailer_size</var><strong>;</strong> 32*19c3b8c2SApple OSS Distributions <strong>mach_port_seqno_t</strong> <var>msgh_seqno</var><strong>;</strong> 33*19c3b8c2SApple OSS Distributions<strong>} mach_msg_seqno_trailer_t;</strong> 34*19c3b8c2SApple OSS Distributions 35*19c3b8c2SApple OSS Distributions<strong>typedef struct</strong> 36*19c3b8c2SApple OSS Distributions<strong>{</strong> 37*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_type_t</strong> <var>msgh_trailer_type</var><strong>;</strong> 38*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_size_t</strong> <var>msgh_trailer_size</var><strong>;</strong> 39*19c3b8c2SApple OSS Distributions <strong>mach_port_seqno_t</strong> <var>msgh_seqno</var><strong>;</strong> 40*19c3b8c2SApple OSS Distributions <strong>security_token_t</strong> <var>msgh_sender</var><strong>;</strong> 41*19c3b8c2SApple OSS Distributions<strong>} mach_msg_security_trailer_t;</strong> 42*19c3b8c2SApple OSS Distributions 43*19c3b8c2SApple OSS Distributions<strong>typedef struct</strong> 44*19c3b8c2SApple OSS Distributions<strong>{</strong> 45*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_type_t</strong> <var>msgh_trailer_type</var><strong>;</strong> 46*19c3b8c2SApple OSS Distributions <strong>mach_msg_trailer_size_t</strong> <var>msgh_trailer_size</var><strong>;</strong> 47*19c3b8c2SApple OSS Distributions <strong>mach_port_seqno_t</strong> <var>msgh_seqno</var><strong>;</strong> 48*19c3b8c2SApple OSS Distributions <strong>security_token_t</strong> <var>msgh_sender</var><strong>;</strong> 49*19c3b8c2SApple OSS Distributions <strong>unsigned int</strong> <var>dipc_sender_kmsg</var><strong>;</strong> 50*19c3b8c2SApple OSS Distributions<strong>} mach_msg_dipc_trailer_t;</strong> 51*19c3b8c2SApple OSS Distributions</pre> 52*19c3b8c2SApple OSS Distributions<h3>FIELDS</h3> 53*19c3b8c2SApple OSS Distributions<dl> 54*19c3b8c2SApple OSS Distributions<dt> <var>msgh_bits</var> 55*19c3b8c2SApple OSS Distributions<dd> 56*19c3b8c2SApple OSS DistributionsThis field specifies the following properties of the message: 57*19c3b8c2SApple OSS Distributions<dl> 58*19c3b8c2SApple OSS Distributions <p> 59*19c3b8c2SApple OSS Distributions<dt> <strong>MACH_MSGH_BITS_REMOTE_MASK</strong> 60*19c3b8c2SApple OSS Distributions<dd> 61*19c3b8c2SApple OSS DistributionsEncodes <var>mach_msg_type_name_t</var> values that specify the port 62*19c3b8c2SApple OSS Distributionsrights in the <var>msgh_remote_port</var> field. The value must specify 63*19c3b8c2SApple OSS Distributionsa send or send-once right for the destination of the message. 64*19c3b8c2SApple OSS Distributions <p> 65*19c3b8c2SApple OSS Distributions<dt> <strong>MACH_MSGH_BITS_LOCAL_MASK</strong> 66*19c3b8c2SApple OSS Distributions<dd> 67*19c3b8c2SApple OSS DistributionsEncodes <var>mach_msg_type_name_t</var> values that specify the port 68*19c3b8c2SApple OSS Distributionsrights in the <var>msgh_local_port</var> field. If the value doesn't 69*19c3b8c2SApple OSS Distributionsspecify a send or send-once right for the message's reply port, it 70*19c3b8c2SApple OSS Distributionsmust be zero and <var>msgh_local_port</var> must be <strong>MACH_PORT_NULL</strong>. 71*19c3b8c2SApple OSS Distributions <p> 72*19c3b8c2SApple OSS Distributions<dt> <strong>MACH_MSGH_BITS_COMPLEX</strong> 73*19c3b8c2SApple OSS Distributions<dd> 74*19c3b8c2SApple OSS DistributionsThe complex bit must be specified if the message body 75*19c3b8c2SApple OSS Distributionscontains additional port rights or out-of-line memory regions. 76*19c3b8c2SApple OSS Distributions <p> 77*19c3b8c2SApple OSS Distributions<dt> <strong>MACH_MSGH_BITS_REMOTE</strong>(<var>bits</var>) 78*19c3b8c2SApple OSS Distributions<dd> 79*19c3b8c2SApple OSS DistributionsThis macro returns the appropriate <var>mach_msg_type_name_t</var> 80*19c3b8c2SApple OSS Distributionsvalues, given a <var>msgh_bits</var> value. 81*19c3b8c2SApple OSS Distributions <p> 82*19c3b8c2SApple OSS Distributions<dt> <strong>MACH_MSGH_BITS_LOCAL</strong>(<var>bits</var>) 83*19c3b8c2SApple OSS Distributions<dd> 84*19c3b8c2SApple OSS DistributionsThis macro returns the appropriate <var>mach_msg_type_name_t</var> 85*19c3b8c2SApple OSS Distributionsvalues, given a <var>msgh_bits</var> value. 86*19c3b8c2SApple OSS Distributions <p> 87*19c3b8c2SApple OSS Distributions<dt> <strong>MACH_MSGH_BITS</strong>(<var>remote</var>, <var>local</var>) 88*19c3b8c2SApple OSS Distributions<dd> 89*19c3b8c2SApple OSS DistributionsThis macro constructs a value for <var>msgh_bits</var>, given two 90*19c3b8c2SApple OSS Distributions<var>mach_msg_type_name_t</var> values. 91*19c3b8c2SApple OSS Distributions</dl> 92*19c3b8c2SApple OSS Distributions<p> 93*19c3b8c2SApple OSS Distributions<dt> <var>msgh_size</var> 94*19c3b8c2SApple OSS Distributions<dd> 95*19c3b8c2SApple OSS DistributionsThis field is ignored on send (the size to send is specified by the 96*19c3b8c2SApple OSS Distributions<var>send_size</var> parameter to <strong>mach_msg</strong>); the field is set on 97*19c3b8c2SApple OSS Distributionsreceive to the sum of 98*19c3b8c2SApple OSS Distributionsthe message header and body sizes (in bytes). Note that this value may 99*19c3b8c2SApple OSS Distributionsbe different from the send size specified by the sender if the sender and 100*19c3b8c2SApple OSS Distributionsreceiver machines have differing sizes for port names, memory 101*19c3b8c2SApple OSS Distributionsaddresses or memory range sizes. 102*19c3b8c2SApple OSS Distributions <p> 103*19c3b8c2SApple OSS Distributions<dt> <var>msgh_remote_port</var> 104*19c3b8c2SApple OSS Distributions<dd> 105*19c3b8c2SApple OSS DistributionsWhen sending, specifies the destination port of the message. The field 106*19c3b8c2SApple OSS Distributionsmust carry a legitimate send or send-once right for a port. When 107*19c3b8c2SApple OSS Distributionsreceived, this field is swapped with <var>msgh_local_port</var>. 108*19c3b8c2SApple OSS Distributions <p> 109*19c3b8c2SApple OSS Distributions<dt> <var>msgh_local_port</var> 110*19c3b8c2SApple OSS Distributions<dd> 111*19c3b8c2SApple OSS DistributionsWhen sending, specifies an auxiliary port right, which is 112*19c3b8c2SApple OSS Distributionsconventionally used as a reply port by the recipient of the message. 113*19c3b8c2SApple OSS DistributionsThe field must 114*19c3b8c2SApple OSS Distributionscarry a send right, a send-once right, <strong>MACH_PORT_NULL</strong>, or 115*19c3b8c2SApple OSS Distributions<strong>MACH_PORT_DEAD</strong>. When received, this field is swapped with 116*19c3b8c2SApple OSS Distributions<var>msgh_remote_port</var>. 117*19c3b8c2SApple OSS Distributions <p> 118*19c3b8c2SApple OSS Distributions<dt> <var>msgh_id</var> 119*19c3b8c2SApple OSS Distributions<dd> 120*19c3b8c2SApple OSS DistributionsNot set or read by the <strong>mach_msg</strong> call. The conventional meaning is to 121*19c3b8c2SApple OSS Distributionsconvey an operation or function ID. 122*19c3b8c2SApple OSS Distributions <p> 123*19c3b8c2SApple OSS Distributions<dt> <var>msgh_descriptor_count</var> 124*19c3b8c2SApple OSS Distributions<dd> 125*19c3b8c2SApple OSS DistributionsThe number of descriptors of kernel processed data (port rights and 126*19c3b8c2SApple OSS Distributionsout-of-line data). 127*19c3b8c2SApple OSS Distributions <p> 128*19c3b8c2SApple OSS Distributions<dt> <var>msgh_trailer_type</var> 129*19c3b8c2SApple OSS Distributions<dd> 130*19c3b8c2SApple OSS DistributionsAn identifier of the trailer version. Different values indicate not 131*19c3b8c2SApple OSS Distributionsnecessarily compatible trailer formats. The current (and only) trailer format 132*19c3b8c2SApple OSS Distributionsis <strong>MACH_MSG_TRAILER_FORMAT_0</strong>. There is currently only one 133*19c3b8c2SApple OSS Distributionsattribute defined within this trailer type: the sender's identity. 134*19c3b8c2SApple OSS Distributions <p> 135*19c3b8c2SApple OSS Distributions<dt> <var>msgh_trailer_size</var> 136*19c3b8c2SApple OSS Distributions<dd> 137*19c3b8c2SApple OSS DistributionsThe length, in bytes, of the message trailer, including the trailer type 138*19c3b8c2SApple OSS Distributionsand length fields. 139*19c3b8c2SApple OSS Distributions <p> 140*19c3b8c2SApple OSS Distributions<dt> <var>msgh_seqno</var> 141*19c3b8c2SApple OSS Distributions<dd> 142*19c3b8c2SApple OSS DistributionsThe sequence number of this message relative to the port from which it 143*19c3b8c2SApple OSS Distributionsis received. 144*19c3b8c2SApple OSS Distributions <p> 145*19c3b8c2SApple OSS Distributions<dt> <var>msgh_sender</var> 146*19c3b8c2SApple OSS Distributions<dd> 147*19c3b8c2SApple OSS DistributionsThe security ID of the sender of the message. 148*19c3b8c2SApple OSS Distributions</dl> 149*19c3b8c2SApple OSS Distributions<h3>DESCRIPTION</h3> 150*19c3b8c2SApple OSS Distributions<p> 151*19c3b8c2SApple OSS DistributionsThe <strong>mach_msg_header</strong> structure defines the fixed size header of a Mach 152*19c3b8c2SApple OSS Distributionsmessage. The header is followed by a message body containing data and port 153*19c3b8c2SApple OSS Distributionsdescriptors and zero or more data bytes. 154*19c3b8c2SApple OSS Distributions<p> 155*19c3b8c2SApple OSS DistributionsIf the <strong>MACH_MSGH_BITS_COMPLEX</strong> flag in the <var>msgh_bits</var> field is not set, 156*19c3b8c2SApple OSS Distributionsthen this is a simple message described by <strong>mach_msg_header_t</strong>. 157*19c3b8c2SApple OSS DistributionsIn this case, the header is immediately followed by untyped data. 158*19c3b8c2SApple OSS Distributions<p> 159*19c3b8c2SApple OSS DistributionsIf the complex flag is set, then this is a "complex" message consisting of a 160*19c3b8c2SApple OSS Distributions<strong>mach_msg_header_t</strong> structure followed by a <strong>mach_msg_body_t</strong> structure 161*19c3b8c2SApple OSS Distributionscontaining a count followed by an array of descriptors specifying 162*19c3b8c2SApple OSS Distributionsthe disposition 163*19c3b8c2SApple OSS Distributions(processing) to be performed for the out-of-line memory regions and additional 164*19c3b8c2SApple OSS Distributionsport rights. 165*19c3b8c2SApple OSS Distributions<p> 166*19c3b8c2SApple OSS DistributionsFollowing the header (and any kernel processed descriptors), at natural 167*19c3b8c2SApple OSS Distributionsalignment can be additional (un-typed) data, up to the size of the message 168*19c3b8c2SApple OSS Distributions(<var>msgh_size</var>). This extra data typically carries information 169*19c3b8c2SApple OSS Distributionsused to decode the data stream and out-of-line data. 170*19c3b8c2SApple OSS Distributions<p> 171*19c3b8c2SApple OSS DistributionsAt the next natural boundary following the message data is the message trailer 172*19c3b8c2SApple OSS Distributions(<strong>mach_msg_trailer_t</strong>). This structure indicates the type and length of the 173*19c3b8c2SApple OSS Distributionstrailer. If the length is greater than sizeof (<strong>mach_msg_trailer_t</strong>), 174*19c3b8c2SApple OSS Distributionsadditional fields 175*19c3b8c2SApple OSS Distributionsfollow providing kernel-generated message attributes. 176*19c3b8c2SApple OSS Distributions<h3>RELATED INFORMATION</h3> 177*19c3b8c2SApple OSS Distributions<p> 178*19c3b8c2SApple OSS DistributionsFunctions: 179*19c3b8c2SApple OSS Distributions<a href="mach_msg.html"><strong>mach_msg</strong></a>. 180*19c3b8c2SApple OSS Distributions<p> 181*19c3b8c2SApple OSS DistributionsData Structures: 182*19c3b8c2SApple OSS Distributions<a href="mach_msg_descriptor.html"><strong>mach_msg_descriptor</strong></a>. 183*19c3b8c2SApple OSS Distributions 184