1*0f4c859eSApple OSS Distributions<h2>device_open</h2> 2*0f4c859eSApple OSS Distributions<hr> 3*0f4c859eSApple OSS Distributions<p> 4*0f4c859eSApple OSS Distributions<strong>Function</strong> - Establish a connection to a device. 5*0f4c859eSApple OSS Distributions<h3>SYNOPSIS</h3> 6*0f4c859eSApple OSS Distributions<pre> 7*0f4c859eSApple OSS Distributions<strong>#include<device/device.h></strong> 8*0f4c859eSApple OSS Distributions 9*0f4c859eSApple OSS Distributions<strong>kern_return_t device_open</strong> 10*0f4c859eSApple OSS Distributions <strong>(mach_port_t</strong> <var>master_port</var>, 11*0f4c859eSApple OSS Distributions <strong>mach_port_t</strong> <var>ledger</var>, 12*0f4c859eSApple OSS Distributions <strong>dev_mode_t</strong> <var>mode</var>, 13*0f4c859eSApple OSS Distributions <strong>security_token_t</strong> <var>security_id</var>, 14*0f4c859eSApple OSS Distributions <strong>dev_name_t</strong> <var>name</var>, 15*0f4c859eSApple OSS Distributions <strong>mach_port_t</strong> <var>device</var><strong>);</strong> 16*0f4c859eSApple OSS Distributions 17*0f4c859eSApple OSS Distributions 18*0f4c859eSApple OSS Distributions<strong>#include<device/device_request.h></strong> 19*0f4c859eSApple OSS Distributions 20*0f4c859eSApple OSS Distributions<strong>kern_return_t device_open_request</strong> 21*0f4c859eSApple OSS Distributions <strong>(mach_port_t</strong> <var>master_port</var>, 22*0f4c859eSApple OSS Distributions <strong>mach_port_t</strong> <var>reply_port</var>, 23*0f4c859eSApple OSS Distributions <strong>mach_port_t</strong> <var>ledger</var>, 24*0f4c859eSApple OSS Distributions <strong>dev_mode_t</strong> <var>mode</var>, 25*0f4c859eSApple OSS Distributions <strong>security_token_t</strong> <var>security_id</var>, 26*0f4c859eSApple OSS Distributions <strong>dev_name_t</strong> <var>name</var><strong>);</strong> 27*0f4c859eSApple OSS Distributions 28*0f4c859eSApple OSS Distributions 29*0f4c859eSApple OSS Distributions<strong>kern_return_t ds_device_open_reply</strong> 30*0f4c859eSApple OSS Distributions <strong>(mach_port_t</strong> <var>reply_port</var>, 31*0f4c859eSApple OSS Distributions <strong>kern_return_t</strong> <var>return_code</var>, 32*0f4c859eSApple OSS Distributions <strong>mach_port_t</strong> <var>device</var><strong>);</strong> 33*0f4c859eSApple OSS Distributions</pre> 34*0f4c859eSApple OSS Distributions<h3>PARAMETERS</h3> 35*0f4c859eSApple OSS Distributions<dl> 36*0f4c859eSApple OSS Distributions<p> 37*0f4c859eSApple OSS Distributions<dt> <var>master_port</var> 38*0f4c859eSApple OSS Distributions<dd> 39*0f4c859eSApple OSS Distributions[in device-master send right] 40*0f4c859eSApple OSS DistributionsThe master device port. This port is 41*0f4c859eSApple OSS Distributionsprovided to the bootstrap task. 42*0f4c859eSApple OSS Distributions<p> 43*0f4c859eSApple OSS Distributions<dt> <var>reply_port</var> 44*0f4c859eSApple OSS Distributions<dd> 45*0f4c859eSApple OSS Distributions[in reply receive (to be converted to send-once) right] 46*0f4c859eSApple OSS DistributionsThe port to 47*0f4c859eSApple OSS Distributionswhich a reply is to be sent when the device is open. 48*0f4c859eSApple OSS Distributions<p> 49*0f4c859eSApple OSS Distributions<dt> <var>ledger</var> 50*0f4c859eSApple OSS Distributions<dd> 51*0f4c859eSApple OSS Distributions[pointer to a ledger send right] 52*0f4c859eSApple OSS DistributionsResource ledger from which the device will draw its resources. 53*0f4c859eSApple OSS Distributions<p> 54*0f4c859eSApple OSS Distributions<dt> <var>mode</var> 55*0f4c859eSApple OSS Distributions<dd> 56*0f4c859eSApple OSS Distributions[in scalar] 57*0f4c859eSApple OSS DistributionsOpening mode. This is the bit-wise <strong>OR</strong> of the following 58*0f4c859eSApple OSS Distributionsvalues: 59*0f4c859eSApple OSS Distributions<dl> 60*0f4c859eSApple OSS Distributions<p> 61*0f4c859eSApple OSS Distributions<dt> <strong>D_READ</strong> 62*0f4c859eSApple OSS Distributions<dd> 63*0f4c859eSApple OSS DistributionsRead access 64*0f4c859eSApple OSS Distributions<p> 65*0f4c859eSApple OSS Distributions<dt> <strong>D_WRITE</strong> 66*0f4c859eSApple OSS Distributions<dd> 67*0f4c859eSApple OSS DistributionsWrite access 68*0f4c859eSApple OSS Distributions<p> 69*0f4c859eSApple OSS Distributions<dt> <strong>D_NODELAY</strong> 70*0f4c859eSApple OSS Distributions<dd> 71*0f4c859eSApple OSS DistributionsDo not delay on open 72*0f4c859eSApple OSS Distributions</dl> 73*0f4c859eSApple OSS Distributions<p> 74*0f4c859eSApple OSS Distributions<dt> <var>security_id</var> 75*0f4c859eSApple OSS Distributions<dd> 76*0f4c859eSApple OSS Distributions[in scalar] 77*0f4c859eSApple OSS DistributionsThe security ID that tasks attempting to use this device port 78*0f4c859eSApple OSS Distributionsmust have. A zero value indicates all identities. 79*0f4c859eSApple OSS Distributions<p> 80*0f4c859eSApple OSS Distributions<dt> <var>name</var> 81*0f4c859eSApple OSS Distributions<dd> 82*0f4c859eSApple OSS Distributions[pointer to in array of <var>char</var>] 83*0f4c859eSApple OSS DistributionsName of the device to open. 84*0f4c859eSApple OSS Distributions<p> 85*0f4c859eSApple OSS Distributions<dt> <var>return_code</var> 86*0f4c859eSApple OSS Distributions<dd> 87*0f4c859eSApple OSS Distributions[in scalar] 88*0f4c859eSApple OSS DistributionsStatus of the open. 89*0f4c859eSApple OSS Distributions<p> 90*0f4c859eSApple OSS Distributions<dt> <var>device</var> 91*0f4c859eSApple OSS Distributions<dd> 92*0f4c859eSApple OSS Distributions[out device send right, in for asynchronous form] 93*0f4c859eSApple OSS DistributionsThe returned device 94*0f4c859eSApple OSS Distributionsport. 95*0f4c859eSApple OSS Distributions</dl> 96*0f4c859eSApple OSS Distributions<h3>DESCRIPTION</h3> 97*0f4c859eSApple OSS Distributions<p> 98*0f4c859eSApple OSS DistributionsThe <strong>device_open</strong> function opens a device object. The 99*0f4c859eSApple OSS Distributionsopen operation of the 100*0f4c859eSApple OSS Distributionsdevice is invoked, if the device is not already open. The open 101*0f4c859eSApple OSS Distributionscount for the device 102*0f4c859eSApple OSS Distributionsis incremented. Each open for a device returns a port, the allowed 103*0f4c859eSApple OSS Distributionsoperations upon which being governed by <var>mode</var>. The port is not 104*0f4c859eSApple OSS Distributionsdistinct. 105*0f4c859eSApple OSS Distributions<h3>RETURN VALUES</h3> 106*0f4c859eSApple OSS Distributions<p> 107*0f4c859eSApple OSS DistributionsOnly generic errors apply. 108*0f4c859eSApple OSS Distributions<h3>RELATED INFORMATION</h3> 109*0f4c859eSApple OSS Distributions<p> 110*0f4c859eSApple OSS DistributionsFunctions: 111*0f4c859eSApple OSS Distributions<a href="device_close.html"><strong>device_close</strong></a>, 112*0f4c859eSApple OSS Distributions<a href="device_reply_server.html"><strong>device_reply_server</strong></a>. 113