<?xml version="1.0" encoding="ANSI_X3.4-1968" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=ANSI_X3.4-1968" /><title>fc_remote_port_add</title><meta name="generator" content="DocBook XSL Stylesheets V1.75.2" /><link rel="home" href="index.html" title="SCSI Interfaces Guide" /><link rel="up" href="ch03s02.html#Fibre_Channel_transport" title="Fibre Channel transport" /><link rel="prev" href="re107.html" title="fc_remove_host" /><link rel="next" href="re109.html" title="fc_remote_port_delete" /></head><body><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center"><span>fc_remote_port_add</span></th></tr><tr><td width="20%" align="left"><a accesskey="p" href="re107.html">Prev</a> </td><th width="60%" align="center">Fibre Channel transport</th><td width="20%" align="right"> <a accesskey="n" href="re109.html">Next</a></td></tr></table><hr /></div><div class="refentry" title="fc_remote_port_add"><a id="API-fc-remote-port-add"></a><div class="titlepage"></div><div class="refnamediv"><h2>Name</h2><p>fc_remote_port_add — notify fc transport of the existence of a remote FC port. </p></div><div class="refsynopsisdiv" title="Synopsis"><h2>Synopsis</h2><div class="funcsynopsis"><table border="0" summary="Function synopsis" cellspacing="0" cellpadding="0" class="funcprototype-table"><tr><td><code class="funcdef">struct fc_rport * <b class="fsfunc">fc_remote_port_add </b>(</code></td><td>struct Scsi_Host * <var class="pdparam">shost</var>, </td></tr><tr><td> </td><td>int <var class="pdparam">channel</var>, </td></tr><tr><td> </td><td>struct fc_rport_identifiers * <var class="pdparam">ids</var><code>)</code>;</td></tr></table><div class="funcprototype-spacer"> </div></div></div><div class="refsect1" title="Arguments"><a id="id2712348"></a><h2>Arguments</h2><div class="variablelist"><dl><dt><span class="term"><em class="parameter"><code>shost</code></em></span></dt><dd><p> scsi host the remote port is connected to. </p></dd><dt><span class="term"><em class="parameter"><code>channel</code></em></span></dt><dd><p> Channel on shost port connected to. </p></dd><dt><span class="term"><em class="parameter"><code>ids</code></em></span></dt><dd><p> The world wide names, fc address, and FC4 port roles for the remote port. </p></dd></dl></div></div><div class="refsect1" title="Description"><a id="id2712410"></a><h2>Description</h2><p> The LLDD calls this routine to notify the transport of the existence of a remote port. The LLDD provides the unique identifiers (wwpn,wwn) of the port, it's FC address (port_id), and the FC4 roles that are active for the port. </p><p> For ports that are FCP targets (aka scsi targets), the FC transport maintains consistent target id bindings on behalf of the LLDD. A consistent target id binding is an assignment of a target id to a remote port identifier, which persists while the scsi host is attached. The remote port can disappear, then later reappear, and it's target id assignment remains the same. This allows for shifts in FC addressing (if binding by wwpn or wwnn) with no apparent changes to the scsi subsystem which is based on scsi host number and target id values. Bindings are only valid during the attachment of the scsi host. If the host detaches, then later re-attaches, target id bindings may change. </p><p> This routine is responsible for returning a remote port structure. The routine will search the list of remote ports it maintains internally on behalf of consistent target id mappings. If found, the remote port structure will be reused. Otherwise, a new remote port structure will be allocated. </p><p> Whenever a remote port is allocated, a new fc_remote_port class device is created. </p><p> Should not be called from interrupt context. </p></div><div class="refsect1" title="Notes"><a id="id2647456"></a><h2>Notes</h2><p> This routine assumes no locks are held on entry. </p></div></div><div class="navfooter"><hr /><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="re107.html">Prev</a> </td><td width="20%" align="center"><a accesskey="u" href="ch03s02.html#Fibre_Channel_transport">Up</a></td><td width="40%" align="right"> <a accesskey="n" href="re109.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top"><span>fc_remove_host</span> </td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top"> <span>fc_remote_port_delete</span></td></tr></table></div></body></html>