Sophie

Sophie

distrib > Mandriva > 8.2 > i586 > media > contrib > by-pkgid > 211238da6d926d1ca4390483bb29f586 > files > 65

coda-doc-5.2.0-4mdk.noarch.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<HTML>
<HEAD>
 <META NAME="GENERATOR" CONTENT="SGML-Tools 1.0.9">
 <TITLE> RPC2 User Guide and Reference Manual</TITLE>
 <LINK HREF="rpc2_manual-1.html" REL=next>


</HEAD>
<BODY>
<A HREF="rpc2_manual-1.html">Next</A>
Previous
Contents
<HR>
<H1> RPC2 User Guide and Reference Manual</H1>

<H2>M. Satyanarayanan (Editor)
  Richard Draves, James Kistler, Anders Klemets, Qi Lu, Lily Mummert,   David Nichols, Larry Raper, Gowthami Rajendran, Jonathan Rosenberg,   Ellen Siegel</H2>
Thanks This work has been supported by the Defense Advanced Research Projects
Agency (Avionics Lab, Wright Research and Development Center, Aeronautical
Systems Division (AFSC), U.S. Air Force, Wright-Patterson AFB, Ohio,
45433-6543 under Contract F33615-90-C-1465, ARPA Order No. 7597), the
National Science Foundation (CCR-8657907), and the IBM Corporation (Andrew
Project, Faculty Development Grant, Research Initiation Grant), and
Digital Equipment Corporation (External Research Project).  The views and
conclusion expressed in this paper are those of the authors, and should
not be interpreted as those of DARPA, NSF, IBM, DEC or Carnegie Mellon
University.  
<P><HR>
<EM>  This manual describes the programming interface and internal design of
  <EM>RPC2</EM>, a highly portable and extensible remote procedure call
  package for Unix. RPC2 runs on top of the IP/UDP protocol, and provides
  support for streaming file transfer, parallel RPC calls, and IP-level
  multicast.  The manual also describes two other packages used by RPC2:
  <EM>RP2Gen</EM>, a stub generator, and <EM>LWP</EM>, a coroutine-based
  lightweight process package.  All the software described in this manual
  runs at user-level on the Unix 4.3BSD interface; no kernel modifications
  are necessary.  The software has been ported to a variety of machine
  architectures (such as IBM-RT, MIPS, Sun2, Sun3, Sparc, and i386) and to
  variants of the Unix operating system (such as Mach, SunOS and AIX).</EM>
<HR>
<P>
<H2><A NAME="toc1">1.</A> <A HREF="rpc2_manual-1.html">Preface                                                </A></H2>

<P>
<H2><A NAME="toc2">2.</A> <A HREF="rpc2_manual-2.html">Overview and Examples</A></H2>

<UL>
<LI><A HREF="rpc2_manual-2.html#ss2.1">2.1 Components</A>
<LI><A HREF="rpc2_manual-2.html#ss2.2">2.2 Client-Server Model and Binding</A>
<LI><A HREF="rpc2_manual-2.html#ss2.3">2.3 How RPC2 uses LWPs</A>
<LI><A HREF="rpc2_manual-2.html#ss2.4">2.4 Side Effects</A>
<LI><A HREF="rpc2_manual-2.html#ss2.5">2.5 Security</A>
<LI><A HREF="rpc2_manual-2.html#ss2.6">2.6 Examples</A>
</UL>
<P>
<H2><A NAME="toc3">3.</A> <A HREF="rpc2_manual-3.html">The RP2Gen Stub Generator</A></H2>

<UL>
<LI><A HREF="rpc2_manual-3.html#ss3.1">3.1 Introduction</A>
<LI><A HREF="rpc2_manual-3.html#ss3.2">3.2 Usage</A>
<LI><A HREF="rpc2_manual-3.html#ss3.3">3.3 Format of the Description File</A>
<LI><A HREF="rpc2_manual-3.html#ss3.4">3.4 Command Line Parameters</A>
<LI><A HREF="rpc2_manual-3.html#ss3.5">3.5 The C Interface</A>
<LI><A HREF="rpc2_manual-3.html#ss3.6">3.6 External Data Representations</A>
</UL>
<P>
<H2><A NAME="toc4">4.</A> <A HREF="rpc2_manual-4.html">RPC2 Runtime System</A></H2>

<UL>
<LI><A HREF="rpc2_manual-4.html#ss4.1">4.1 Client-related Calls</A>
<LI><A HREF="rpc2_manual-4.html#ss4.2">4.2 Server-related RPC Calls</A>
<LI><A HREF="rpc2_manual-4.html#ss4.3">4.3 Miscellaneous Calls</A>
</UL>
<P>
<H2><A NAME="toc5">5.</A> <A HREF="rpc2_manual-5.html">SFTP: A Side Effect for Bulk Data Transfer</A></H2>

<UL>
<LI><A HREF="rpc2_manual-5.html#ss5.1">5.1 General Usage</A>
<LI><A HREF="rpc2_manual-5.html#ss5.2">5.2 An Example</A>
</UL>
<P>
<H2><A NAME="toc6">6.</A> <A HREF="rpc2_manual-6.html">MultiRPC</A></H2>

<UL>
<LI><A HREF="rpc2_manual-6.html#ss6.1">6.1 Design Issues</A>
<LI><A HREF="rpc2_manual-6.html#ss6.2">6.2 Examples</A>
<LI><A HREF="rpc2_manual-6.html#ss6.3">6.3 C Interface Specification</A>
<LI><A HREF="rpc2_manual-6.html#ss6.4">6.4 Runtime Calls</A>
</UL>
<P>
<H2><A NAME="toc7">7.</A> <A HREF="rpc2_manual-7.html">Multicast </A></H2>

<UL>
<LI><A HREF="rpc2_manual-7.html#ss7.1">7.1 General Usage</A>
<LI><A HREF="rpc2_manual-7.html#ss7.2">7.2 Runtime Calls</A>
</UL>
<P>
<H2><A NAME="toc8">8.</A> <A HREF="rpc2_manual-8.html">Chapter(The Basic LWP Package)</A></H2>

<UL>
<LI><A HREF="rpc2_manual-8.html#ss8.1">8.1 A word about initialization</A>
<LI><A HREF="rpc2_manual-8.html#ss8.2">8.2 A Simple Example</A>
<LI><A HREF="rpc2_manual-8.html#ss8.3">8.3 LWP Runtime Calls</A>
</UL>
<P>
<H2><A NAME="toc9">9.</A> <A HREF="rpc2_manual-9.html">The Lock Package</A></H2>

<UL>
<LI><A HREF="rpc2_manual-9.html#ss9.1">9.1 Key Design Choices</A>
<LI><A HREF="rpc2_manual-9.html#ss9.2">9.2 Lock Primitives</A>
</UL>
<P>
<H2><A NAME="toc10">10.</A> <A HREF="rpc2_manual-10.html">The IOMGR Package</A></H2>

<UL>
<LI><A HREF="rpc2_manual-10.html#ss10.1">10.1 Key Design Choices</A>
<LI><A HREF="rpc2_manual-10.html#ss10.2">10.2 A Simple Example</A>
<LI><A HREF="rpc2_manual-10.html#ss10.3">10.3 IOMGR Primitives</A>
</UL>
<P>
<H2><A NAME="toc11">11.</A> <A HREF="rpc2_manual-11.html">The Timer Package</A></H2>

<UL>
<LI><A HREF="rpc2_manual-11.html#ss11.1">11.1 A Simple Example</A>
</UL>
<P>
<H2><A NAME="toc12">12.</A> <A HREF="rpc2_manual-12.html">The Preemption Package </A></H2>

<UL>
<LI><A HREF="rpc2_manual-12.html#ss12.1">12.1 Key Design Choices</A>
<LI><A HREF="rpc2_manual-12.html#ss12.2">12.2 A Simple Example</A>
<LI><A HREF="rpc2_manual-12.html#ss12.3">12.3 Preemption Primitives</A>
</UL>
<P>
<H2><A NAME="toc13">13.</A> <A HREF="rpc2_manual-13.html">The Fast Time Package </A></H2>

<UL>
<LI><A HREF="rpc2_manual-13.html#ss13.1">13.1 Fast Time Primitives</A>
</UL>
<P>
<H2><A NAME="toc14">14.</A> <A HREF="rpc2_manual-14.html">RPC2 Internals</A></H2>

<UL>
<LI><A HREF="rpc2_manual-14.html#ss14.1">14.1 Background</A>
<LI><A HREF="rpc2_manual-14.html#ss14.2">14.2 The LWP package</A>
</UL>
<P>
<H2><A NAME="toc15">15.</A> <A HREF="rpc2_manual-15.html">Failure Detection</A></H2>

<UL>
<LI><A HREF="rpc2_manual-15.html#ss15.1">15.1 Retransmission Algorithm</A>
</UL>
<P>
<H2><A NAME="toc16">16.</A> <A HREF="rpc2_manual-16.html">SFTP Internals</A></H2>

<UL>
<LI><A HREF="rpc2_manual-16.html#ss16.1">16.1 Background</A>
<LI><A HREF="rpc2_manual-16.html#ss16.2">16.2 SFTP Code Structure</A>
<LI><A HREF="rpc2_manual-16.html#ss16.3">16.3 Packet formats</A>
<LI><A HREF="rpc2_manual-16.html#ss16.4">16.4 Adjusting the Retransmission Interval</A>
<LI><A HREF="rpc2_manual-16.html#ss16.5">16.5 Performance</A>
</UL>
<P>
<H2><A NAME="toc17">17.</A> <A HREF="rpc2_manual-17.html">Adding New Kinds of Side Effects</A></H2>

<UL>
<LI><A HREF="rpc2_manual-17.html#ss17.1">17.1 Usage Notes</A>
<LI><A HREF="rpc2_manual-17.html#ss17.2">17.2 Entry Point Templates</A>
</UL>
<P>
<H2><A NAME="toc18">18.</A> <A HREF="rpc2_manual-18.html">Implementation of MultiRPC</A></H2>

<UL>
<LI><A HREF="rpc2_manual-18.html#ss18.1">18.1 The Client Handler</A>
<LI><A HREF="rpc2_manual-18.html#ss18.2">18.2 Flow of Control in MultiRPC</A>
<LI><A HREF="rpc2_manual-18.html#ss18.3">18.3 MultiRPC Related Calls</A>
</UL>
<P>
<H2><A NAME="toc19">19.</A> <A HREF="rpc2_manual-19.html">Usage and Implementation Notes                 </A></H2>

<UL>
<LI><A HREF="rpc2_manual-19.html#ss19.1">19.1 Current Limitations</A>
<LI><A HREF="rpc2_manual-19.html#ss19.2">19.2 Where to Find Files at Carnegie Mellon</A>
<LI><A HREF="rpc2_manual-19.html#ss19.3">19.3 Debugging</A>
</UL>
<HR>
<A HREF="rpc2_manual-1.html">Next</A>
Previous
Contents
</BODY>
</HTML>