Go to main content
Index
Numbers and Symbols
- 32-bit and 64-bit systems
64-Bit Considerations for rpcgen
- 64-bit system
64-Bit Considerations for rpcgen
- _1 suffix
Server Side of the Simplified Interface
RPC Version of printmsg.c
A
- access control
- authentication
Authentication Server
- add.x source file
Compile-Time ANSI C-compliant Code
MT-Safe Server Stub
Compile-Time C-style Mode
rpcgen Template Selection Flags
- adding
- address registrations
Address Lookup Services and RPC
- ADDPROG program
Add Two Numbers Program (rpcgen)
- addresses
- information reporting for
Reporting RPC Information
- look-up services
Registering Addresses in RPC
Address Lookup Services and RPC
- management functions
Address Management Functions
- name-to-address translation routines
Name-to-Address Translation in TI-RPC
- network
System Registration Overview
- overview
System Registration Overview
- pass server's address to client
Client Side of the Expert-Level Interface
- pass user's bind address
Server Side of the Expert-Level Interface
- passing arguments as
Server Side of the Simplified Interface
RPC Version of printmsg.c
RPC Version of printmsg.c
- transport (netbuf)
Address Lookup Services and RPC
- universal
System Registration Overview
rpcbind Operation
Name-to-Address Translation in TI-RPC
- unregistering
PMAPPROC_UNSET Procedure
- ah_cred field
Client Authentication Handle
- ah_key field
AUTH_DES Authentication
- ah_verf field
Client Authentication Handle
- ANSI C standards
- rpcgen tool
Compile-Time ANSI C-compliant Code
rpcgen Compile-Time Flags
Software Environment Features
- applications
- porting from TS-RPC to TI-RPC
Porting an Application
- arguments (remote procedures)
- pass arbitrary data types
xdr_reference Syntax Use
Passing Arbitrary Data Types
- pass open TLI file descriptors
Server Side of the Expert-Level Interface
Client Side of the Expert-Level Interface
- pass server's address to client
Client Side of the Expert-Level Interface
- pass user's bind address
Server Side of the Expert-Level Interface
- passing by address
Server Side of the Simplified Interface
RPC Version of printmsg.c
RPC Version of printmsg.c
- passing by value
Compile-Time C-style Mode
- void
RPCL C-style Mode
RPCL Programs
- arrays
- converting to XDR format
Memory Allocation With XDR
Memory Allocation With XDR
xdr_vector Syntax Use
- declarations
- RPC language
RPCL Variable-Length Array Declarations
RPCL Fixed-Length Array Declarations
- XDR language
Syntax Notes About XDR
Declaration of Counted Array and Variable-Length Array
Fixed-Length Array
- XDR code examples
Fixed-Length Arrays
Array Example #3
Byte Arrays
- asynchronous mode
poll on the Server
Side
- AUTH_BADCRED error
NFS Mount Example
- AUTH_DES authentication
Diffie-Hellman Encryption
AUTH_DES Authentication
AUTH_DES Authentication
- common key
Diffie-Hellman Encryption
Diffie-Hellman Encryption
- conversation key
Diffie-Hellman Encryption
AUTH_DES Authentication Verifiers
AUTH_DES Authentication Verifiers
- credentials
AUTH_DES Authentication
- Diffie-Hellman encryption
Diffie-Hellman Encryption
Diffie-Hellman Encryption
AUTH_DES Authentication
- errors
Nicknames and Clock Synchronization
- handle
AUTH_DES Authentication
AUTH_DES Authentication
- nicknames
Nicknames and Clock Synchronization
Nicknames and Clock Synchronization
- protocol in XDR language
Diffie-Hellman Encryption
DES Authentication Protocol (in XDR language)
- server
AUTH_DES Server
AUTH_DES Authentication
- time synchronization
Nicknames and Clock Synchronization
Nicknames and Clock Synchronization
AUTH_DES Authentication
- verifiers
AUTH_DES Authentication Verifiers
AUTH_DES Authentication Verifiers
- AUTH_KERB authentication
AUTH_KERB Authentication- credentials
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- encryption
AUTH_KERB Authentication
AUTH_KERB Authentication
- errors
NFS Mount Example
NFS Mount Example
- NFS
NFS Mount Example
AUTH_KERB Authentication
- nicknames
NFS Mount Example
AUTH_KERB Authentication
- protocol in XDR language
KERB Authentication Protocol
- time synchronization
AUTH_KERB Authentication
- verifiers
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- AUTH_NONE authentication
AUTH_NONE Authentication
- AUTH_REJECTEDVERF error
NFS Mount Example
- AUTH_SHORT verifier
AUTH_SHORT Verifier
AUTH_SHORT Verifier
- AUTH_SYS authentication
AUTH_SHORT Verifier
AUTH_SYS Authentication
- AUTH_TIMEEXPIRE error
NFS Mount Example
- AUTH_TOOWEAK error
NFS Mount Example
- AUTH_UNIX authentication
AUTH_SHORT Verifier
- authentication
AUTH_KERB Authentication- access control
Authentication Server
- allocating authentication numbers
Authentication Protocols
- AUTH_DES
Diffie-Hellman Encryption
AUTH_DES Server
AUTH_DES Authentication
- AUTH_KERB
AUTH_KERB Authentication
AUTH_KERB Authentication
- AUTH_NONE
AUTH_NONE Authentication
- AUTH_SHORT verifier
AUTH_SHORT Verifier
AUTH_SHORT Verifier
- AUTH_SYS
AUTH_SHORT Verifier
AUTH_SYS Authentication
- AUTH_UNIX
AUTH_SHORT Verifier
AUTH_SYS Authentication
- calls
Authentication Functions
- credentials
- AUTH_DES
AUTH_DES Authentication
- AUTH_KERB
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- window (lifetime of)
AUTH_DES Authentication Verifiers
AUTH_KERB Authentication
AUTH_DES Authentication
- destroying instance
Authentication Methods Supported by Oracle RPC
- errors
- AUTH_DES
Nicknames and Clock Synchronization
- AUTH_KERB
NFS Mount Example
NFS Mount Example
- handles
AUTH_DES Authentication
AUTH_DES Authentication
RPC Client Handle Structure
- low-level data structures and
RPC Client Handle Structure
- nicknames
- AUTH_DES
Nicknames and Clock Synchronization
Nicknames and Clock Synchronization
- AUTH_KERB
NFS Mount Example
AUTH_KERB Authentication
- overview
Authentication Protocols
- protocol
Authentication Protocols
- registering authentication numbers
Authentication Protocols
- RPC protocol
Program and Procedure Numbers
Program and Procedure Numbers
- rpcgen tool
Client Authentication
- servers
AUTH_DES Server
AUTH_DES Authentication
Authentication Server
Authentication Methods Supported by Oracle RPC
Authentication Methods Supported by Oracle RPC
- service
Authentication Using RPCSEC_GSS
- service-dispatch routine
Authentication Methods Supported by Oracle RPC
- time synchronization
- AUTH_DES authentication
Nicknames and Clock Synchronization
AUTH_DES Authentication Verifiers
AUTH_DES Authentication
- AUTH_KERB authentication
AUTH_KERB Authentication
- verifiers
- AUTH_DES
AUTH_DES Authentication Verifiers
AUTH_DES Authentication Verifiers
- AUTH_KERB
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- AUTH_SYS
AUTH_SHORT Verifier
AUTH_SHORT Verifier
B
- batched
Batched Code Example
Batching Call Messages
Batched Server
- bcast.c program
Broadcast RPC
- binding
- dynamic
portmap Protocol
- TI-RPC
Binding and Rendezvous Independence
- Booleans
- RPC language
RPCL Booleans
- XDR language
Boolean Representation
- bottom-level interface routines (RPC)
Bottom-Level Interface
- broadcast RPC
- calls
Broadcasting in RPC
- overview
Broadcast RPC
- routines
Collect Broadcast Replies
- rpc_broadcast() function
Broadcast RPC
RPC Routines – Simplified Level
- server response
Collect Broadcast Replies
Server Response to Broadcast Calls
- buffer size
- specify send and receive
Server Side of the Expert-Level Interface
Client Side of the Expert-Level Interface
- byte arrays
- XDR
Byte Arrays
C
- _clnt.c suffix
Client Program to Call printmsg.c
- C
- Newstyle mode
RPCL C-style Mode
- rpcgen tool
RPCL C-style Mode
Compile-Time ANSI C-compliant Code
- ANSI C compliance
Compile-Time ANSI C-compliant Code
rpcgen Compile-Time Flags
Software Environment Features
- C-style mode
Compile-Time C-style Mode
rpcgen Compile-Time Flags
Software Environment Features
- preprocessing directives
Command-Line Define Statements
cpp Directive
Preprocessing Directives
- C-style mode
- rpcgen tool
RPCL C-style Mode
Compile-Time C-style Mode
rpcgen Compile-Time Flags
Software Environment Features
- caching
- server
Server Caching
- call semantics
- TI-RPC
Transports and Semantics
Call Semantics in TI-RPC
- callback procedures
Using Transient RPC Program Numbers- RPCSEC_GSS
Cookies and Callbacks in RPC
- transient RPC program numbers and
Using Transient RPC Program Numbers
Using Transient RPC Program Numbers
- uses
Using Transient RPC Program Numbers
- CBC (cipher block chaining) mode
AUTH_KERB Authentication
- cipher block chaining (CBC) mode
AUTH_KERB Authentication
- circuit-oriented transports
- when to use
Transport Selection in TI-RPC
- circuit_v transport type
nettype Parameters in TI-RPC
- cl_auth field
RPC Client Handle Structure
- client handles
- clnt_create() function
RPC Routines – Top Level
- clnt_dg_create() function
RPC Routines – Bottom Level
- clnt_tli_create() function
RPC Routines – Expert Level
- clnt_tp_create() function
RPC Routines – Intermediate Level
- creating
- bottom-level interface
Client Side of the Bottom-Level Interface
- expert-level interface
Client for RPC Lower Level
Client Side of the Expert-Level Interface
- intermediate level interface
Client for Time Service, Intermediate Level
Client Side of the Intermediate-Level Interface
- top-level interface
Client for Trivial Date Service
Top-Level Interface
Client Program to Call printmsg.c
Client Program to Call printmsg.c
Top-Level Routines
- destroying
- expert-level interface
Client for RPC Lower Level
- top-level interface
Client for Trivial Date Service
Client Program to Call printmsg.c
- low-level data structures for
Client Authentication Handle
Low-Level Data Structures
- client programs
- remote copy
Remote Copy (Two-Way XDR Routine)
- rpcgen tool
- ANSI C-compliance
Compile-Time ANSI C-compliant Code
- complex data structure passing
Client-side Implementation of rls.c
Server dir_proc.c Example
- debugging
Debugging Applications
Debugging Applications
- directory listing service
Client-side Implementation of rls.c
Server dir_proc.c Example
- message printing code example
Client Program to Call printmsg.c
RPC Version of printmsg.c
- MT-safe
MT-Safe Program: add.x
Software Environment Features
- overview
RPC Version of printmsg.c
rpcgen Tutorial
- simplified interface
rusers Program Using Simplified Interface
- client stub routines
- rpcgen tool
- C-style mode
Default Mode Version of add.x
- MT Auto mode
Compile-Time MT Auto Mode
- MT-safe
MT-Safe Client Stub
MT-Safe Program: msg.x
- MT-unsafe
Client Stub (MT Unsafe)
MT-Safe Client Stub
- naming
Client Program to Call printmsg.c
- output
What Is rpcgen?
- preprocessing directive
rpcgen Preprocessing Directives
- using
Client Program to Call printmsg.c
- client templates
- rpcgen tool
Default Mode Version of add.x
Compile-Time Client and Server Templates
rpcgen Compile-Time Flags
Software Environment Features
- client time-out periods
- clnt_create_timed()
RPC Routines – Top Level
- creation of timed clients
Client for Time Service, Intermediate Level
Client for Trivial Date Service
- rpcgen tool
Time-out Changes
- clients
- batched
Batched Code Example
Batching RPC Clients
- multiple versions
Multiple Client Versions
- multithreaded
MT Client Overview- MT-safe
Programmer's Interface to RPC
MT-Safe Program: add.x
Compile-Time MT-Safe Code
- user mode
MT User Mode: rpc_test.h
MT User Mode
- transaction IDs and
Transports and Semantics
- TS-RPC and TI-RPC
Comparison Examples
- clnt_create routine
- code example
Client Program to Call printmsg.c
- clnt_perror routine
Debugging Applications
- clnt_sperror routine
Debugging Applications
- comments
- XDR language
Lexical Notes About XDR Specification
- compatibility
- library functions
Other Functions
Function Compatibility Lists
- compiling
- rpcgen tool
Compile-Time C-style Mode
Software Environment Features
- complex data structures
- packing with xdr_inline
Compile-Time xdr_inline Count
rpcgen Compile-Time Flags
- rpcgen tool
Client-side Implementation of rls.c
Passing Complex Data Structures
- compound data type filters
- XDR
Constructed Data Type Filters
xdr_vector Syntax Use
- connection-oriented endpoints
Server Transport Handle
- connection-oriented transports
- client handle creation for
RPC Routines – Bottom Level
- nettype parameters for
nettype Parameters in TI-RPC
- port monitors and
Using Port Monitors
- remote copy code example
Connection-Oriented Transports
- server handle creation for
RPC Routines – Bottom Level
- connectionless transports
- client handle creation for
RPC Routines – Bottom Level
- nettype parameters for
nettype Parameters in TI-RPC
- server handle creation for
RPC Routines – Bottom Level
- UDP
rpcbind Operation
- constants
- RPC language
RPCL Constants
- XDR language
Syntax Notes About XDR
Lexical Notes About XDR Specification
Constant Type
- constructed data type filters
- XDR
Constructed Data Type Filters
xdr_vector Syntax Use
- conversation key
- AUTH_DES authentication
Diffie-Hellman Encryption
AUTH_DES Authentication Verifiers
AUTH_DES Authentication Verifiers
- converting
- addresses
Porting Issues
Name-to-Address Translation in TI-RPC
- from XDR format
XDR Library
XDR Library
Memory Allocation With XDR
Memory Allocation With XDR
Server for Trivial Date Service
Passing Arbitrary Data Types
- local procedures to remote
Client Program to Call printmsg.c
Converting Local Procedures to Remote
Procedures
- to XDR format
XDR Library
XDR Library
Reader Example (Initial)
Memory Allocation With XDR
Memory Allocation With XDR
xdr_reference Syntax Use
Passing Arbitrary Data Types
Client-side Implementation of rls.c
Passing Complex Data Structures
- copying remote
Connection-Oriented Transports
- cpp directive
- rpcgen tool
cpp Directive
- crashes
- server
Nicknames and Clock Synchronization
Transports and Semantics
- credentials
- AUTH_DES
AUTH_DES Authentication
- AUTH_KERB
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- window (lifetime of)
AUTH_DES Authentication Verifiers
AUTH_KERB Authentication
AUTH_DES Authentication
D
- daemons
- inetd
Using inetd
- kerbd
NFS Mount Example
- kerbd
AUTH_KERB Authentication
- rpcbind
rpcbind Protocol
Registering Addresses in RPC
- data representation
- TI-RPC
Data Representation in TI-RPC
- data structures
- converting to XDR format
Reader Example (XDR Modified)
xdr_reference Syntax Use
- low-level
Low-Level Data Structures
- MT-safe
MT User Mode
- packing with xdr_inline
Compile-Time xdr_inline Count
rpcgen Compile-Time Flags
- recursive
Optional-Data Type
Nonrecursive Stack in XDR
Advanced XDR Topics
- rpcgen tool
Client-side Implementation of rls.c
Passing Complex Data Structures
- data types
- pass arbitrary
xdr_reference Syntax Use
Passing Arbitrary Data Types
- datagram transports
- broadcast RPC and
Broadcast RPC
- when to use
Transport Selection in TI-RPC
- datagram_n transport type
nettype Parameters in TI-RPC
- datagram_v transport type
nettype Parameters in TI-RPC
- date service
- intermediate level client for
Client for Time Service, Intermediate Level
Client Side of the Intermediate-Level Interface
- intermediate level server for
Server Side of the Intermediate-Level Interface
- top-level client for trivial
Client for Trivial Date Service
time_prot.h Header File
- top-level server for
Server for Trivial Date Service
Client for Trivial Date Service
- debugging
- raw mode
Simple Program Using Raw RPC
- rpcgen tool
Debugging Applications
Command-Line Define Statements
- client programs
Debugging Applications
- declarations
- RPC language
RPCL Voids
RPCL Declarations
- XDR language
Optional-Data Type
XDR Data Type Declarations
- defaults
- maximum number of threads
rpc_control Library Routines
- single-threaded mode
MT Server Overview
- define statements, command line, rpcgen tool
Command-Line Define Statements
- deleting
- associations
RPC Routines – Expert Level
- mappings
RPC Routines – Expert Level
- DES encryption
AUTH_DES Authentication Verifiers
AUTH_DES Authentication
- deserializing
XDR Library
- destroying
- client authentication handles
Authentication Methods Supported by Oracle RPC
- client handles
Client for RPC Lower Level
Client for Trivial Date Service
Client Program to Call printmsg.c
- server handles
Creating and Destroying Services
- XDR streams
Nonfilter Primitives
- Diffie-Hellman encryption
Diffie-Hellman Encryption
Diffie-Hellman Encryption
AUTH_DES Authentication Verifiers
AUTH_DES Authentication
- dir.x program
Directory Listing Program and Support Routines
(rpcgen)
RPC Protocol Description File: dir.x
Passing Complex Data Structures
- dir_proc.c routine
RPC Protocol Description File: dir.x
- directories
- remote directory listing service
Directory Listing Program and Support Routines
(rpcgen)
Client-side Implementation of rls.c
Passing Complex Data Structures
- discriminated unions
- declarations
- RPC language
RPCL Unions
RPCL Unions
- XDR language
Syntax Notes About XDR
Discriminated Union
RPCL Unions
RPCL Unions
- XDR code samples
Discriminated Unions
- dispatch tables
- rpcgen tool
Using a Dispatch Table
Dispatch Tables
- dynamic binding
portmap Protocol
- dynamic program numbers
RPC Program Number Assignment
Using Transient RPC Program Numbers
E
- /etc/gss/mech
gsscred Table
- /etc/gss/qop
gsscred Table
- /etc/inet/inetd.conf file
Using inetd
- /etc/netconfig
Differences Between TI-RPC and TS-RPC
Network Types/Transport Selection
Network Selection in TI-RPC
- /etc/rpc
TI-RPC Program, Version, and Procedure Numbers
- ECB (electronic code book) mode
AUTH_KERB Authentication
AUTH_KERB Authentication
- electronic code book (ECB) mode
AUTH_KERB Authentication
- enabling server caching
Server Caching
- encryption
- AUTH_DES authentication (Diffie-Hellman)
Diffie-Hellman Encryption
- AUTH_DES authentication (Diffie-Hellman)
Diffie-Hellman Encryption
AUTH_DES Authentication Verifiers
AUTH_DES Authentication
- AUTH_KERB authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- privacy service
Authentication Using RPCSEC_GSS
- endpoints
- connection-oriented
Server Transport Handle
- enumeration filters
- XDR primitives
Enumeration Filters
Enumeration Filters
- enumerations
- RPC language
RPCL Enumerations
RPCL Enumerations
RPC Protocol Description File: dir.x
- XDR language
Enumeration Representation
- errors
- authentication
- AUTH_DES
Nicknames and Clock Synchronization
- AUTH_KERB
NFS Mount Example
NFS Mount Example
- client handle creation
Client for Trivial Date Service
- multiple client version
Multiple Client Versions
- RPC
Program and Procedure Numbers
Debugging Applications
Debugging Applications
Client Program to Call printmsg.c
- expert-level interface routines (RPC)
- client
Client for RPC Lower Level
- network selection
Server for RPC Lower Level
- overview
Expert-Level Interface
- server
Server for RPC Lower Level
F
- file data structure
- XDR language
XDR Data Description
- file descriptors, pass open TLI
Server Side of the Expert-Level Interface
Client Side of the Expert-Level Interface
- filters (XDR)
- arrays
Fixed-Length Arrays
Array Example #3
Byte Arrays
- constructed (compound) data type
Constructed Data Type Filters
xdr_vector Syntax Use
- enumeration
Enumeration Filters
Enumeration Filters
- floating point
Floating-Point Filters
- number
Number Filters
Number Filters
Passing Arbitrary Data Types
- opaque data
xdr_netobj Routine
Opaque Data
- strings
String Type Definition in RPC
String Type Definition in RPC
xdr_vector Syntax Use
- unions
Discriminated Unions
- fixed-length arrays
- declarations
- RPC language
RPCL Fixed-Length Array Declarations
RPCL Fixed-Length Array Declarations
- XDR language
Fixed-Length Array
- XDR code sample
Fixed-Length Arrays
- fixed-length opaque data
- XDR language
Fixed-Length Opaque Data
- floating point
- XDR language
Floating Point Representation
- floating point filters
- XDR primitives
Floating-Point Filters
- free routine
Client-side Implementation of rls.c
H
- handles
- authentication
AUTH_DES Authentication
AUTH_DES Authentication
RPC Client Handle Structure
- header files
- rpcgen tool
rpcgen Preprocessing Directives
Client Program to Call printmsg.c
I
- .i suffix
Dispatch Tables
- I/O streams
- XDR
Standard I/O Streams
- identifiers
- XDR language
Lexical Notes About XDR Specification
- identifying
- remote procedures
Program Number Registration
Program and Procedure Numbers
Transports and Semantics
TI-RPC Program, Version, and Procedure Numbers
TI-RPC Program, Version, and Procedure Numbers
- index table
- rpcgen tool
rpcgen Preprocessing Directives
- inetd port monitor
Using Port Monitors- rpcgen tool
Port Monitor Support
Port Monitor Support
- inetd port monitor
Using inetd- rpcgen tool
Client Program to Call printmsg.c
- information reporting
- addresses
Reporting RPC Information
- remote host status
MT Client Overview
- RPC
Reporting RPC Information
- server callbacks
Using Transient RPC Program Numbers
Using Transient RPC Program Numbers
- integers
- XDR language
Reader Example (XDR Modified)
Reader Example (Initial)
- integrity service
Authentication Using RPCSEC_GSS
- intermediate level interface routines (RPC)
- efficiency and
Intermediate-Level Routines
- overview
Intermediate-Level Interface
- IXDR_GET_LONG() function
64-Bit Considerations for rpcgen
- IXDR_PUT_LONG() function
64-Bit Considerations for rpcgen
K
- kerbd daemon
NFS Mount Example
- kerbd daemon
AUTH_KERB Authentication
- keywords
- RPC language
RPC Protocol Description File: dir.x
- XDR language
Syntax Notes About XDR
- KGETKCRED procedure
NFS Mount Example
AUTH_KERB Authentication
- KGETUCRED procedure
NFS Mount Example
NFS Mount Example
AUTH_KERB Authentication
- KSETKCRED procedure
NFS Mount Example
AUTH_KERB Authentication
L
- lib library
Client-side Implementation of rls.c
- libc library
Differences Between TI-RPC and TS-RPC
Porting Issues
- libnsl library
Differences Between TI-RPC and TS-RPC
Porting Issues
RPC Protocol Description File: dir.x
Client Program to Call printmsg.c
- libraries
- lib
Client-side Implementation of rls.c
- libc
Differences Between TI-RPC and TS-RPC
Porting Issues
- libnsl
Differences Between TI-RPC and TS-RPC
Porting Issues
RPC Protocol Description File: dir.x
Client Program to Call printmsg.c
- librpcsvc
Simplified Interface
- lthread
Two Client Threads
Using Different Client Handles (Real Time)
- RPC functions
Other Functions
Function Compatibility Lists
- rpcgen tool
- libnsl
Differences Between TI-RPC and TS-RPC
RPC Protocol Description File: dir.x
Client Program to Call printmsg.c
- porting issues
Porting Issues
- selecting TI-RPC or TS-RPC library
Compile-Time TI-RPC or TS-RPC Library
Selection
rpcgen Compile-Time Flags
Software Environment Features
- thread
Two Client Threads
Using Different Client Handles (Real Time)
- XDR
XDR Library
XDR Library
- librpcsvc library
Simplified Interface
- limits
- broadcast request size
Broadcast RPC
- maximum number of threads
rpc_control Library Routines
- linked lists
- XDR
Optional-Data Type
Nonrecursive Stack in XDR
Advanced XDR Topics
- listen port monitor
- rpcgen tool
Port Monitor Support
Port Monitor Support
Client Program to Call printmsg.c
- using
Using Port Monitors
- listen port monitor
- using
Using the Listener
- listing
- portmap mappings
PMAPPROC_DUMP Procedure
- remote directory listing service
Directory Listing Program and Support Routines
(rpcgen)
Client-side Implementation of rls.c
Passing Complex Data Structures
- rpcbind mappings
TI-RPC Program, Version, and Procedure Numbers
- live code examples
- add two numbers program
Add Two Numbers Program (rpcgen)
- batched code
Batched Code Example
- directory listing program
Directory Listing Program and Support Routines
(rpcgen)
Directory Listing Program and Support Routines
(rpcgen)
- print message program
Print Message Program With Remote Version
- spray packets program
Spray Packets Program (rpcgen)
- time server program
Time Server Program (rpcgen)
- local procedures
- converting to remote
Client Program to Call printmsg.c
Converting Local Procedures to Remote
Procedures
- locks
- mutex, multithreaded mode and
MT Server Overview
- low-level data structures
Low-Level Data Structures
- lthread library
Two Client Threads
Using Different Client Handles (Real Time)
M
- main server function
Port Monitor Support
- makefile templates
- rpcgen tool
rpcgen Template Selection Flags
Software Environment Features
- mapping between RPC and network address
RPC Routines – Expert Level
- maximums
- broadcast request size
Broadcast RPC
- number of threads
rpc_control Library Routines
- mechanism, security
GSS-API and RPCSEC_GSS Security Layers
- memory
- allocating with XDR
Memory Allocation With XDR
Memory Allocation With XDR
- releasing
- clnt_destroy routine
Client Program to Call printmsg.c
- free routine
Client-side Implementation of rls.c
- limitations
Standard Interfaces
- xdr_free()
MT-Safe Server Stub
- XDR_FREE operation
Constructed Data Type Filters
- xdr_free routine
Client-side Implementation of rls.c
- requirements for XDR routines
Memory Requirements for XDR Routines
- streams in XDR
Memory Streams
- XDR primitive requirements
Constructed Data Type Filters
- msg.h header file
Client Program to Call printmsg.c
- msg.x program
Compile-Time MT-Safe Code
- msg_clnt.c routine
Client Program to Call printmsg.c
- msg_svc.c program
Client Program to Call printmsg.c
- msg_svc.c routine
Client Program to Call printmsg.c
- MT Auto mode
- code examples
rpc_control Library Routines
- described
MT Auto Mode
- overview
MT Server Overview
- rpcgen tool
Compile-Time MT Auto Mode
rpcgen Compile-Time Flags
Software Environment Features
- service transport handle
Sharing the Service Transport Handle
- MT user mode
MT User Mode
Sharing the Service Transport Handle
MT Server Overview
- MT-safe code
- clients
Programmer's Interface to RPC
MT-Safe Program: add.x
Compile-Time MT-Safe Code
Software Environment Features
- rpcgen tool
Compile-Time MT-Safe Code
rpcgen Compile-Time Flags
Software Environment Features
- servers
MT Server Overview
Programmer's Interface to RPC
MT-Safe Client: add.x
MT-Safe Server Stub
Client Stub (MT Unsafe)
Software Environment Features
What Is rpcgen?
- multiple client versions
Multiple Client Versions
- multiple server versions
Multiple Server Versions
- multithreaded RPC program
- library
Two Client Threads
Using Different Client Handles (Real Time)
- maximum number of threads
rpc_control Library Routines
- multithreaded RPC programming
- clients
- MT-safe
Programmer's Interface to RPC
MT-Safe Program: add.x
Compile-Time MT-Safe Code
Software Environment Features
- overview
MT Client Overview
- user mode
MT User Mode: rpc_test.h
MT User Mode
- performance enhancement
Client for MT User Mode
rpc_control Library Routines
- rpcgen tool
MT Auto Mode: time.x
Compile-Time MT-Safe Code
rpcgen Compile-Time Flags
Software Environment Features
- servers
- Auto mode
MT Auto Mode
Sharing the Service Transport Handle
MT Server Overview
Compile-Time MT Auto Mode
rpcgen Compile-Time Flags
Software Environment Features
- MT-safe
MT Server Overview
Programmer's Interface to RPC
MT-Safe Client: add.x
MT-Safe Server Stub
Client Stub (MT Unsafe)
Software Environment Features
What Is rpcgen?
- overview
MT Server Overview
- timing diagram
MT Server Overview
- user mode
Client for MT User Mode
MT User Mode
Sharing the Service Transport Handle
MT Server Overview
- supported
Multithreaded RPC Programming
- multithreaded user mode
MT User Mode
Sharing the Service Transport Handle
MT Server Overview
- mutex locks
- multithreaded mode
MT Server Overview
N
- name-to-address translation
Porting Issues
Name-to-Address Translation in TI-RPC
- naming
- client stub programs by rpcgen
Client Program to Call printmsg.c
Client Program to Call printmsg.c
- netnames
AUTH_DES Authentication
AUTH_DES Authentication
- programs by version number
Multiple Server Versions
- remote procedure calls by rpcgen
RPC Version of printmsg.c
- server programs by rpcgen
Client Program to Call printmsg.c
- standard for
AUTH_DES Authentication
- template files for rpcgen
rpcgen Template Selection Flags
- netconfig database
Differences Between TI-RPC and TS-RPC
Network Types/Transport Selection
- netconfig database
Network Selection in TI-RPC
- netnames
AUTH_DES Authentication
AUTH_DES Authentication
- NETPATH environment variable
Client for Trivial Date Service
Network Selection in TI-RPC
- NETPATH environment variable
Network Types/Transport Selection
- network names See
netnames
- network pipes
Reader Example (Initial)
- network selection
- RPC
Network Selection in TI-RPC
- rpcgen tool
Network Types/Transport Selection
- Newstyle (C-style) mode
- rpcgen tool
Compile-Time C-style Mode
rpcgen Compile-Time Flags
Software Environment Features
- NFS
- Kerberos authentication
NFS Mount Example
AUTH_KERB Authentication
- NFSPROC_GETATTR procedure
NFS Mount Example
- NFSPROC_STATVFS procedure
NFS Mount Example
- nicknames
- AUTH_DES
Nicknames and Clock Synchronization
Nicknames and Clock Synchronization
- AUTH_KERB
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
- NULL
- arguments
Server Side of the Simplified Interface
- pointers
Pointer Semantics
- strings
RPCL Strings
- transport type
nettype Parameters in TI-RPC
- number filters, XDR
Number Filters
Number Filters
Passing Arbitrary Data Types
- number of users
- on a network
Authentication Server
- on a remote host
Simplified Interface
O
- ONC+ overview
Integrated View of ONC+ Based Applications
- opaque data
- declarations in RPC
RPCL Opaque Data
- declarations in XDR
Variable-Length Opaque Encoding
Fixed-Length Opaque Data
- XDR code examples
xdr_netobj Routine
Opaque Data
- open TLI file descriptors
- passing
Server Side of the Expert-Level Interface
Client Side of the Expert-Level Interface
- optional-data unions
- XDR language
Optional-Data Type
P
- ping program
ping Service Using RPC Language
Example Service Described in the RPC Language
- pipes on networks
Reader Example (Initial)
- PMAPPROC_CALLIT procedure
PMAPPROC_CALLIT Procedure
- PMAPPROC_DUMP procedure
PMAPPROC_DUMP Procedure
- PMAPPROC_GETPORT procedure
PMAPPROC_GETPORT Procedure
- PMAPPROC_NULL procedure
PMAPPROC_NULL Procedure
- PMAPPROC_SET procedure
PMAPPROC_SET Procedure
- PMAPPROC_UNSET procedure
PMAPPROC_UNSET Procedure
- pointers
- remote procedures
RPC Version of printmsg.c
RPC Version of printmsg.c
- RPC language
RPCL Pointer Declarations
RPCL Pointer Declarations
- XDR code examples
Pointer Semantics
Pointers in RPC
- poll routine
poll on the Server
Side
- port monitors
- administrative commands
- pmadm
Using the Listener
- sacadm
Using the Listener
- rpcgen tool
Port Monitor Support
Port Monitor Support
Client Program to Call printmsg.c
- using
Using Port Monitors
- port numbers
- getting for registered services
portmap Utility
- TCP/IP protocol
portmap Operation
rpcbind Operation
- UDP/IP protocol
portmap Operation
rpcbind Operation
- porting TS-RPC to TI-RPC
- applications
Porting an Application
- benefits
Benefits of Porting
- code comparison examples
Comparison Examples
- differences between TI-RPC and TS-RPC
Comparison Examples
Differences Between TI-RPC and TS-RPC
- function compatibility lists
Other Functions
Function Compatibility Lists
- libc library
Porting Issues
- libnsl library
Porting Issues
- name-to-address mapping
Porting Issues
- old interfaces
Porting Issues
- overview
Porting From TS-RPC to TI-RPC
- preprocessing directives
- rpcgen tool
Command-Line Define Statements
cpp Directive
Preprocessing Directives
- printing
- message to system console
Print Message Program With Remote Version
Client Program to Call printmsg.c
Converting Local Procedures to Remote
Procedures
- printmsg.c program
- remote version
Client Program to Call printmsg.c
Single Process Version of printmesg.c
- single process version
Print Message Program With Remote Version
Single Process Version of printmesg.c
Converting Local Procedures to Remote
Procedures
- privacy
- service
Authentication Using RPCSEC_GSS
- procedure numbers
- error conditions
Program and Procedure Numbers
- procedure-lists
- RPC language
RPC Language Definitions
- procedures
- registering as RPC programs
Hand-Coded Registration Routine
RPC Routines – Simplified Level
- RPC language
RPC Language Definitions
- program declarations
- RPC language
RPCL Programs
RPCL Programs
- program definitions
- RPC language
RPC Language Definitions
- program numbers
- assigning
RPC Program Number Assignment
Program Number Assignment
- error conditions
Program and Procedure Numbers
- procedure numbers and
Program and Procedure Numbers
- transient (dynamically assigned)
RPC Program Number Assignment
Using Transient RPC Program Numbers
- PROGVERS program name
Multiple Server Versions
- PROGVERS_ORIG program name
Multiple Server Versions
- protocols
- AUTH_DES
DES Authentication Protocol (in XDR language)
- AUTH_DES
Diffie-Hellman Encryption
- specifying in RPC language
Single Process Version of printmesg.c
Q
- quadruple-precision floating point
- XDR language
Quadruple-Precision Floating Point
R
- /rpcsvc
Program Number Registration
- raw RPC
- testing programs using low-level
Simple Program Using Raw RPC
- READDIR procedure
Directory Listing Program and Support Routines
(rpcgen)
Client-side Implementation of rls.c
Passing Complex Data Structures
- record streams
- XDR
Record-Marking Standard
Record-Marking Standard
Record TCP/IP Streams
Memory Streams
- record-marking standard
Record-Marking Standard
Record-Marking Standard
- recursive data structures
Optional-Data Type
Nonrecursive Stack in XDR
Advanced XDR Topics
- registering
- authentication numbers
Authentication Protocols
- hand-coded registration routine
Hand-Coded Registration Routine
- procedures as RPC programs
Hand-Coded Registration Routine
Server Side of the Simplified Interface
RPC Routines – Simplified Level
- program version numbers
Multiple Server Versions
- services
Registering and Unregistering Services
- remote directory listing service
Client-side Implementation of rls.c
Passing Complex Data Structures
- remote procedures
- converting local procedures
Client Program to Call printmsg.c
Converting Local Procedures to Remote
Procedures
- identifying
Program Number Registration
Program and Procedure Numbers
Transports and Semantics
TI-RPC Program, Version, and Procedure Numbers
TI-RPC Program, Version, and Procedure Numbers
- Remote Time Protocol
Compile-Time MT Auto Mode
rpcgen Preprocessing Directives
- rendezvousing
- TI-RPC
Binding and Rendezvous Independence
- rls.c routine
Client-side Implementation of rls.c
- RPC (remote procedure call)
- address look-up services
Registering Addresses in RPC
Address Lookup Services and RPC
RPC Routines – Expert Level
- address reporting
Reporting RPC Information
- address translation
Porting Issues
Name-to-Address Translation in TI-RPC
- asynchronous mode
poll on the Server
Side
- batched
Batched Code Example
Batching Call Messages
Batched Server
Batching RPC Clients
- errors
Program and Procedure Numbers
Debugging Applications
Debugging Applications
Client Program to Call printmsg.c
- failure of
Client Program to Call printmsg.c
- identifying remote procedures
Program Number Registration
Program and Procedure Numbers
Transports and Semantics
TI-RPC Program, Version, and Procedure Numbers
TI-RPC Program, Version, and Procedure Numbers
- information reporting
Using Transient RPC Program Numbers
Using Transient RPC Program Numbers
Reporting RPC Information
- interface routines
- bottom-level interface
Bottom-Level Interface
- caching servers
Server Caching
- expert-level
Server for RPC Lower Level
Expert-Level Interface
- intermediate level
Intermediate-Level Interface
Intermediate-Level Routines
- low-level data structures
Low-Level Data Structures
- overview
Overview of TI-RPC Interface Routines
- simplified
xdr_reference Syntax Use
Simplified Interface
- standard
Standard Interfaces
- top-level
Top-Level Interface
Client Program to Call printmsg.c
Client Program to Call printmsg.c
- top-level interface
Top-Level Routines
- language reference
RPC Language Reference
- multiple client versions
Multiple Client Versions
- multiple server versions
Multiple Server Versions
- name-to-address translation
Porting Issues
Registering Addresses in RPC
Name-to-Address Translation in TI-RPC
- network selection
Network Selection in TI-RPC
- poll routine
poll on the Server
Side
- record-marking standard
Record-Marking Standard
Record-Marking Standard
- standards
Record-Marking Standard
Record-Marking Standard
How RPC Works
- transient RPC program numbers
RPC Program Number Assignment
Using Transient RPC Program Numbers
- transport selection
Transport Selection in TI-RPC
- RPC language (RPCL)
- arrays
RPCL Variable-Length Array Declarations
RPCL Fixed-Length Array Declarations
- Booleans
RPCL Booleans
- C
What Is rpcgen?
- C-style mode and
RPCL C-style Mode
- constants
RPCL Constants
- declarations
RPCL Variable-Length Array Declarations
RPCL Declarations
- definitions
RPC Language Definitions
- discriminated unions
RPCL Unions
RPCL Unions
RPC Protocol Description File: dir.x
- enumerations
RPCL Enumerations
RPCL Enumerations
RPC Protocol Description File: dir.x
- example protocol described in
Single Process Version of printmesg.c
- fixed-length arrays
RPCL Fixed-Length Array Declarations
RPCL Fixed-Length Array Declarations
- keywords
RPC Protocol Description File: dir.x
- language reference
What Is rpcgen?
- Newstyle (C-style) mode
Compile-Time C-style Mode
- opaque data
RPCL Opaque Data
- overview
RPC Language Reference
- pointers
RPCL Pointer Declarations
RPCL Pointer Declarations
- portmap protocol specification
Typical Portmap Sequence (For TCP/IP Only)
- program declarations
RPCL Programs
RPCL Programs
- reference
What Is rpcgen?
- simple declarations
RPCL Simple Declarations
- special cases
RPCL Voids
RPCL Special Cases
- specification
RPCL Voids
RPC Language Specification
- strings
RPCL Strings
Single Process Version of printmesg.c
- structures
RPCL Structures
RPC Protocol Description File: dir.x
- syntax
RPC Language Definitions
RPCL Syntax
- type definitions
RPCL Type Definitions
- unions
RPCL Unions
RPCL Unions
RPC Protocol Description File: dir.x
- variable-length arrays
RPCL Variable-Length Array Declarations
- voids
RPCL Voids
- XDR language
RPC Language Reference
RPCL Syntax
RPC Language Specification
- RPC_AUTHERROR error
Nicknames and Clock Synchronization
- RPC_CLNT preprocessing directive
rpcgen Preprocessing Directives
- rpc_createerr global variable
Client for Trivial Date Service
- rpc_gss_principal_t structure
Principal Names
- rpc_gss_principal_t structure
Generating Client Principal Names
- RPC_HDR preprocessing directive
rpcgen Preprocessing Directives
- RPC_SVC preprocessing directive
rpcgen Preprocessing Directives
- RPC_TBL preprocessing directive
rpcgen Preprocessing Directives
- RPC_XDR preprocessing directive
rpcgen Preprocessing Directives
- rpcbind daemon
- mapping numbers to addresses
rpcbind Protocol
- registering addresses with
Registering Addresses in RPC
- time service
AUTH_DES Authentication Verifiers
- RPCBPROC_CALLIT procedure
Registering Addresses in RPC
- RPCBPROC_GETTIME procedure
AUTH_DES Authentication Verifiers
- rpcgen tool
- failure of remote procedure calls
Client Program to Call printmsg.c
- rpcgen tool
- 64-bit and
64-Bit Considerations for rpcgen
- advantages
What Is rpcgen?
- arguments
RPCL C-style Mode
xdr_reference Syntax Use
Passing Arbitrary Data Types
Server Side of the Simplified Interface
Compile-Time C-style Mode
RPC Version of printmsg.c
RPC Version of printmsg.c
- authentication
AUTH_KERB Authentication
AUTH_DES Authentication
Client Authentication
RPC Programming Techniques
- batched code example
Batched Code Example
- broadcast call server response
Server Response to Broadcast Calls
- C and
Compile-Time ANSI C-compliant Code- ANSI C compliance
Compile-Time ANSI C-compliant Code
rpcgen Compile-Time Flags
Software Environment Features
- C-style mode
RPCL C-style Mode
Compile-Time C-style Mode
rpcgen Compile-Time Flags
Software Environment Features
- preprocessing directives
Command-Line Define Statements
cpp Directive
Preprocessing Directives
- compilation modes
Compile-Time C-style Mode
Software Environment Features
- complex data structure passing
Client-side Implementation of rls.c
Passing Complex Data Structures
- converting local procedures to remote
Client Program to Call printmsg.c
Converting Local Procedures to Remote
Procedures
- cpp directive
cpp Directive
- debugging
Debugging Applications
Debugging Applications
Debugging Applications
Command-Line Define Statements
RPC Programming Techniques
- defaults
- argument passing mode
C-style Mode Client Stub for add.x
Compile-Time C-style Mode
- C preprocessor
cpp Directive
- client time-out period
Time-out Changes
- compilation mode
Software Environment Features
- library selection
Compile-Time TI-RPC or TS-RPC Library
Selection
- MT-safe
Compile-Time MT-Safe Code
Software Environment Features
- output
What Is rpcgen?
- server exit interval
Port Monitor Support
- define statements on command line
Command-Line Define Statements
- directory listing program
Directory Listing Program and Support Routines
(rpcgen)
Client-side Implementation of rls.c
Passing Complex Data Structures
- directory support routines
Directory Listing Program and Support Routines
(rpcgen)
- dispatch tables
Using a Dispatch Table
Dispatch Tables
- flags
- –A (MT Auto mode)
Compile-Time MT Auto Mode
rpcgen Compile-Time Flags
- –a (templates)
rpcgen Template Selection Flags
rpcgen Compile-Time Flags
- –b (TS-RPC library)
Compile-Time TI-RPC or TS-RPC Library
Selection
rpcgen Compile-Time Flags
- –i (xdr_inline() count)
Compile-Time xdr_inline Count
- listed
Compile-Time Flags
- –M (MT-safe code)
Compile-Time MT-Safe Code
rpcgen Compile-Time Flags
- –N (C-style mode)
Compile-Time C-style Mode
rpcgen Compile-Time Flags
- –Sc (templates)
rpcgen Template Selection Flags
rpcgen Compile-Time Flags
- –Sm (templates)
rpcgen Template Selection Flags
rpcgen Compile-Time Flags
- –Ss (templates)
rpcgen Template Selection Flags
rpcgen Compile-Time Flags
- guide
rpcgen Programming Guide
- hand-coding and
Hand-Coded Registration Routine
- libraries
- libnsl
Differences Between TI-RPC and TS-RPC
Porting Issues
RPC Protocol Description File: dir.x
Client Program to Call printmsg.c
- selecting TI-RPC or TS-RPC library
Compile-Time TI-RPC or TS-RPC Library
Selection
rpcgen Compile-Time Flags
Software Environment Features
- live code examples
Add Two Numbers Program (rpcgen)
- MT (multithread) Auto mode
MT Auto Mode
Compile-Time MT Auto Mode
rpcgen Compile-Time Flags
Software Environment Features
- MT (multithread)-safe code
Compile-Time MT-Safe Code
rpcgen Compile-Time Flags
Software Environment Features
- naming remote procedure calls
RPC Version of printmsg.c
- network types/transport selection
Network Types/Transport Selection
- Newstyle (C-style) mode
Compile-Time C-style Mode
rpcgen Compile-Time Flags
Software Environment Features
- optional output
What Is rpcgen?
- pointers
RPC Version of printmsg.c
RPC Version of printmsg.c
- port monitor support
Port Monitor Support
Port Monitor Support
Client Program to Call printmsg.c
- preprocessing directives
Command-Line Define Statements
RPC Programming Techniques
cpp Directive
Preprocessing Directives
- print message program
Print Message Program With Remote Version
Client Program to Call printmsg.c
Converting Local Procedures to Remote
Procedures
- programming techniques
Debugging Applications
rpcgen Programming
Techniques
- socket functions
Compile-Time TI-RPC or TS-RPC Library
Selection
- spray packets program
Spray Packets Program (rpcgen)
- templates
Default Mode Version of add.x
Compile-Time Client and Server Templates
rpcgen Compile-Time Flags
Software Environment Features
- TI-RPC and TS-RPC
Differences Between TI-RPC and TS-RPC
- TI-RPC and TS-RPC library selection
Compile-Time TI-RPC or TS-RPC Library
Selection
rpcgen Compile-Time Flags
Software Environment Features
- time server program
Time Server Program (rpcgen)
Compile-Time MT Auto Mode
rpcgen Preprocessing Directives
- time-out changes
Time-out Changes
- tutorial
rpcgen Compile-Time Flags
rpcgen Tutorial
- variable declarations and
RPCL Fixed-Length Array Declarations
- XDR routine generation
What Is XDR?
rpcgen Preprocessing Directives
Client-side Implementation of rls.c
Passing Complex Data Structures
- xdr_inline() count
Compile-Time xdr_inline Count
- xdr_inline count
rpcgen Compile-Time Flags
- RPCPROGVERSMISMATCH error
Multiple Client Versions
- RPCSEC_GSS security flavor
- /etc/gss/mech
gsscred Table
- /etc/gss/qop
gsscred Table
- integrity service
Authentication Using RPCSEC_GSS
- rstat program
- multithreaded
MT Client Overview
S
- _svc.c suffix
Client Program to Call printmsg.c
- _svc suffix
Compile-Time ANSI C-compliant Code
- SAC
- sacadm command
Using the Listener
- sacadm command
Using the Listener
- SAF
- administrative interface
- pmadm command
Using the Listener
- sacadm command
Using the Listener
- security
- mechanism
GSS-API and RPCSEC_GSS Security Layers
- service
Authentication Using RPCSEC_GSS
Authentication Using RPCSEC_GSS
- semantics
- TI-RPC call
Transports and Semantics
Call Semantics in TI-RPC
- serializing
XDR Library
XDR Library
Reader Example (Initial)
Memory Allocation With XDR
Memory Allocation With XDR
xdr_reference Syntax Use
Passing Arbitrary Data Types
Client-side Implementation of rls.c
Passing Complex Data Structures
- server handles
- creating
Creating and Destroying Services- connectionless transports
RPC Routines – Bottom Level
- expert-level interface
Server for RPC Lower Level
Server Side of the Expert-Level Interface
- intermediate level interface
Server Side of the Intermediate-Level Interface
- svc_create()
RPC Routines – Top Level
- top-level interface
Server for Trivial Date Service
Client for Trivial Date Service
Top-Level Routines
- transports, for
RPC Routines – Intermediate Level
- destroying
Creating and Destroying Services
- low-level data structures
Client Authentication Handle
- server programs
- remote copy
Remote Copy Client Routines
- rpcgen tool
Client Program to Call printmsg.c- broadcast call response
Server Response to Broadcast Calls
RPC Programming Techniques
- C-style mode
Default Mode Client
- client authentication
Authentication Methods Supported by Oracle RPC
Authentication Methods Supported by Oracle RPC
Client Authentication
RPC Programming Techniques
- complex data structure passing
RPC Protocol Description File: dir.x
- debugging
Debugging Applications
Debugging Applications
- directory listing service
Directory Listing Program and Support Routines
(rpcgen)
RPC Protocol Description File: dir.x
- MT Auto mode
Compile-Time MT Auto Mode
- MT-safe
MT-Safe Client: add.x
Software Environment Features
What Is rpcgen?
- network type/transport selection
Network Types/Transport Selection
- overview
Client Program to Call printmsg.c
rpcgen Tutorial
- simplified interface
- rpc_reg()
Server Side of the Simplified Interface
- transient RPC program
Using Transient RPC Program Numbers
- server stub routines
- rpcgen tool
- ANSI C-compliant
Compile-Time ANSI C-compliant Code
- MT Auto mode
Compile-Time MT Auto Mode
- MT-safe
MT-Safe Server Stub
Client Stub (MT Unsafe)
What Is rpcgen?
- naming
Client Program to Call printmsg.c
- output
What Is rpcgen?
- preprocessing directive
rpcgen Preprocessing Directives
- tutorial
rpcgen Tutorial
- server templates
- rpcgen tool
Default Mode Client
Compile-Time Client and Server Templates
rpcgen Compile-Time Flags
Software Environment Features
- server transport handle
Client Authentication Handle
- servers
- authentication
AUTH_DES Server
AUTH_DES Authentication
Authentication Server
Authentication Methods Supported by Oracle RPC
Authentication Methods Supported by Oracle RPC
- batched
Batched Code Example
Batched Client
- caching
Server Caching
- crashes
Nicknames and Clock Synchronization
Transports and Semantics
- dispatch tables
Using a Dispatch Table
Dispatch Tables
RPC Programming Techniques
- exit interval, rpcgen tool
Port Monitor Support
Port Monitor Support
- multiple versions
Multiple Server Versions
- multithreaded
- Auto mode
MT Auto Mode
Sharing the Service Transport Handle
MT Server Overview
Compile-Time MT Auto Mode
rpcgen Compile-Time Flags
Software Environment Features
- MT-safe
MT Server Overview
Programmer's Interface to RPC
MT-Safe Client: add.x
MT-Safe Server Stub
Client Stub (MT Unsafe)
Software Environment Features
What Is rpcgen?
- overview
MT Server Overview
- supported
Multithreaded RPC Programming
- user mode
Client for MT User Mode
MT User Mode
Sharing the Service Transport Handle
MT Server Overview
- poll routine
poll on the Server
Side
- port monitors and
Using Port Monitors
- transaction IDs and
Transports and Semantics
- service transport handle (SVCXPRT)
Sharing the Service Transport Handle
- service-dispatch routine
- authentication
Authentication Methods Supported by Oracle RPC
- services
- encryption
Authentication Using RPCSEC_GSS
- integrity
Authentication Using RPCSEC_GSS
- privacy
Authentication Using RPCSEC_GSS
- simple declarations
- RPC language
RPCL Simple Declarations
- simplified interface routines (RPC)
- hand-coded registration routine
Hand-Coded Registration Routine
- MT-safe
Programmer's Interface to RPC
- overview
Simplified TI-RPC Interface Routines
- server
Server Side of the Simplified Interface
- XDR conversion
xdr_reference Syntax Use
- XDR convert
Passing Arbitrary Data Types
- XDR format
xdr_reference Syntax Use
- single-threaded mode
- as default
MT Server Overview
- poll routine and
poll on the Server
Side
- spray.x (spray packets) program
Spray Packets Program (rpcgen)
- standard interface routines (RPC)
Standard Interfaces- bottom-level interface
Bottom-Level Interface
- expert-level routines
Server for RPC Lower Level
Expert-Level Interface
- intermediate level routines
Intermediate-Level Interface
Intermediate-Level Routines
- low-level data structures
Low-Level Data Structures
- MT safety of
Programmer's Interface to RPC
- overview
Standard Interface Routines
- top-level interface
Top-Level Routines
- top-level routines
Server for Trivial Date Service
Top-Level Interface
Client Program to Call printmsg.c
Client Program to Call printmsg.c
- standards
- ANSI C standard, rpcgen tool
Compile-Time ANSI C-compliant Code
rpcgen Compile-Time Flags
Software Environment Features
- naming standard
AUTH_DES Authentication
- record-marking standard
Record-Marking Standard
Record-Marking Standard
- RPC
Record-Marking Standard
Record-Marking Standard
How RPC Works
- XDR canonical standard
XDR Canonical Standard
XDR Canonical Standard
- string declarations
- RPC language
RPCL Strings
Single Process Version of printmesg.c
- XDR language
Declaration of Counted Byte Strings
Counted Byte Strings
- string representation
- XDR routines
String Type Definition in RPC
xdr_vector Syntax Use
- structure declarations
- RPC language
RPCL Structures
RPC Protocol Description File: dir.x
- XDR language
Syntax Notes About XDR
Structure Components
- SVCXPRT service transport handle
Sharing the Service Transport Handle
Using Port Monitors
- syntax
- RPC language
RPC Language Definitions
RPCL Syntax
- XDR language
Syntax Notes About XDR
Syntax Notes About XDR
T
- TCP (Transport Control Protocol)
- nettype parameter for
nettype Parameters in TI-RPC
- porting TCP applications to TI-RPC
Porting an Application
- portmap port number
portmap Operation
- portmap sequence
Typical Portmap Sequence (For TCP/IP Only)
portmap Protocol
- RPC protocol
Transports and Semantics
- server crashes and
Transports and Semantics
- transport type
nettype Parameters in TI-RPC
- TCP/IP streams
- XDR
Record-Marking Standard
Record-Marking Standard
Record TCP/IP Streams
Memory Streams
- templates
- rpcgen tool
Default Mode Version of add.x
Compile-Time Client and Server Templates
rpcgen Compile-Time Flags
Software Environment Features
- test
- programs using low-level raw RPC
Simple Program Using Raw RPC
- thread.h file
MT User Mode
- thread library
Two Client Threads
Using Different Client Handles (Real Time)
- TI-RPC (transport-independent remote procedure call)
- transient RPC program numbers
RPC Program Number Assignment
- TI-RPC (transport-independent remote procedure call)
- library selection
- rpcgen tool
Software Environment Features
- raw, test low-level programs
Simple Program Using Raw RPC
- TI-RPC (transport-independent remote procedure call)
- address look-up services
Registering Addresses in RPC
Address Lookup Services and RPC
RPC Routines – Expert Level
- address reporting
Reporting RPC Information
- address translation
Porting Issues
Registering Addresses in RPC
Name-to-Address Translation in TI-RPC
- call semantics
Call Semantics in TI-RPC
- data representation
Data Representation in TI-RPC
- identifying remote procedures
Program Number Registration
Program and Procedure Numbers
Transports and Semantics
TI-RPC Program, Version, and Procedure Numbers
TI-RPC Program, Version, and Procedure Numbers
- information reporting
Using Transient RPC Program Numbers
Using Transient RPC Program Numbers
Reporting RPC Information
- interface routines
- bottom-level
Bottom-Level Interface
- caching servers
Server Caching
- expert-level
Expert-Level Interface
- intermediate level
Intermediate-Level Interface
Intermediate-Level Routines
- low-level data structures
Low-Level Data Structures
- MT-safe
Programmer's Interface to RPC
- overview
Overview of TI-RPC Interface Routines
- simplified
xdr_reference Syntax Use
Simplified Interface
- standard
Standard Interfaces
Standard Interface Routines
- top-level
Top-Level Interface
Client Program to Call printmsg.c
Client Program to Call printmsg.c
Top-Level Routines
- library selection, rpcgen tool
Compile-Time TI-RPC or TS-RPC Library
Selection
rpcgen Compile-Time Flags
- name-to-address translation
Porting Issues
Registering Addresses in RPC
Name-to-Address Translation in TI-RPC
- network selection
Network Selection in TI-RPC
- protocol
- authentication
Program and Procedure Numbers
Program and Procedure Numbers
- binding and rendezvous independence
Binding and Rendezvous Independence
- call semantics
Call Semantics in TI-RPC
- identification procedures
Program Number Registration
- identifying procedures
Transports and Semantics
TI-RPC Program, Version, and Procedure Numbers
TI-RPC Program, Version, and Procedure Numbers
- identifying remote procedures
Program and Procedure Numbers
- in XDR language
RPC Message Protocol
- overview
Protocol Overview
Transport Protocol
- record specification
Record-Marking Standard
- record-marking standard
Record-Marking Standard
Record-Marking Standard
- server crashes and
Transports and Semantics
- transport protocols and semantics and
Transports and Semantics
- version number
Program and Procedure Numbers
- transient RPC program numbers
Using Transient RPC Program Numbers
- transport selection
Transport Selection in TI-RPC
- time
- obtaining current
AUTH_DES Authentication Verifiers
- ping program
ping Service Using RPC Language
Example Service Described in the RPC Language
- time server program
Time Server Program (rpcgen)
Compile-Time MT Auto Mode
rpcgen Preprocessing Directives
- time service
- intermediate level client for
Client for Time Service, Intermediate Level
Client Side of the Intermediate-Level Interface
- intermediate level server for
Server Side of the Intermediate-Level Interface
- rpcbind routine
AUTH_DES Authentication Verifiers
- top-level client for
Client for Trivial Date Service
time_prot.h Header File
- top-level server for
Server for Trivial Date Service
- toplevel server for
Client for Trivial Date Service
- time synchronization
- AUTH_DES authentication
Nicknames and Clock Synchronization
Nicknames and Clock Synchronization
AUTH_DES Authentication
- AUTH_KERB authentication
AUTH_KERB Authentication
- time-out periods
- rpcgen tool
Time-out Changes
RPC Programming Techniques
- time.x program
Time Server Program (rpcgen)
MT Auto Mode: time.x
rpcgen Preprocessing Directives
- timed client creation
RPC Routines – Intermediate Level
RPC Routines – Top Level
- intermediate level interface
Client for Time Service, Intermediate Level
- top-level interface
Client for Trivial Date Service
- TLI file descriptors
- passing open
Server Side of the Expert-Level Interface
Client Side of the Expert-Level Interface
- top-level interface routines (RPC)
Client Program to Call printmsg.c- client
Client for Trivial Date Service
Top-Level Interface
Client Program to Call printmsg.c
Client Program to Call printmsg.c
- overview
Top-Level Routines
- server
Server for Trivial Date Service
Client for Trivial Date Service
- TI-RPC
Top-Level Interface
- transaction IDs
Transports and Semantics
TI-RPC Program, Version, and Procedure Numbers
TI-RPC Program, Version, and Procedure Numbers
- transient program numbers
RPC Program Number Assignment
Using Transient RPC Program Numbers
- transport handles
- server
Client Authentication Handle
- SVCXPRT service
Sharing the Service Transport Handle
Using Port Monitors
- transport protocols
- RPC protocol
Transports and Semantics
- transport selection
- RPC
Transport Selection in TI-RPC
- rpcgen tool
Network Types/Transport Selection
- transport types
- interfaces
Top-Level Interface
- rpcgen tool
Network Types/Transport Selection
- transport-level interface file descriptors
- passing open
Server Side of the Expert-Level Interface
Client Side of the Expert-Level Interface
- trees as recursive data structures
Optional-Data Type
- TS-RPC (transport-specific remote procedure call)
- library selection, rpcgen tool
rpcgen Compile-Time Flags
- tutorials
- rpcgen tool
cpp Directive
rpcgen Tutorial
- type definitions
- RPC language
RPCL Type Definitions
- XDR language
Syntax Notes About XDR
Typedef and Data
Typedef and Data
U
- /usr/include/rpcsvc
Program Number Registration
- /usr/share/lib directory
Client-side Implementation of rls.c
- UDP (user datagram protocol)
- broadcast RPC and
Broadcast RPC
- client creating routines for
Client for RPC Lower Level
- nettype parameter for
nettype Parameters in TI-RPC
- porting UDP applications to TI-RPC
Porting an Application
- portmap port number
portmap Operation
- RCP protocol
Transports and Semantics
- server creation routines for
Server for RPC Lower Level
- transport type
nettype Parameters in TI-RPC
- unions
- declarations
- RPC language
RPCL Unions
RPCL Unions
RPC Protocol Description File: dir.x
- XDR language
Syntax Notes About XDR
Optional-Data Type
Discriminated Union
- XDR code samples
Discriminated Unions
- universal addresses
System Registration Overview
rpcbind Operation
Name-to-Address Translation in TI-RPC
- unregistering services
Registering and Unregistering Services
- unsigned integers
- XDR language
Unsigned Integer
- User MT mode
MT User Mode
Sharing the Service Transport Handle
MT Server Overview
- users
- number on a network
Authentication Server
Simplified Interface
- passing bind address of
Server Side of the Expert-Level Interface
V
- variable declarations
RPCL Fixed-Length Array Declarations
- variable-length array declarations
- RPC language
RPCL Variable-Length Array Declarations
- XDR language
Variable-Length Array
- variable-length opaque data
- XDR language
Variable-Length Opaque Encoding
Variable-Length Opaque Data
- verifiers
- AUTH_DES
AUTH_DES Authentication Verifiers
AUTH_DES Authentication Verifiers
- AUTH_KERB
NFS Mount Example
AUTH_KERB Authentication
AUTH_KERB Authentication
AUTH_KERB Authentication
- AUTH_SYS
AUTH_SHORT Verifier
AUTH_SHORT Verifier
- version numbers
- assigning
Multiple Server Versions
- error conditions
Program and Procedure Numbers
- message protocol
Program and Procedure Numbers
- multiple client versions
Multiple Client Versions
- multiple server versions
Multiple Server Versions
- registration of
Multiple Server Versions
- version-lists
- RPC language
RPC Language Definitions
- versions
- library functions
Other Functions
- library functions compatibility
Function Compatibility Lists
- RPC language
RPC Language Definitions
- visible transport type
nettype Parameters in TI-RPC
nettype Parameters in TI-RPC
- void arguments
RPCL C-style Mode
RPCL Programs
- void declarations
- RPC language
RPCL Voids
- XDR language
Void Type
W
- window of credentials
- AUTH_DES authentication
AUTH_DES Authentication
- AUTH_KERB authentication
AUTH_KERB Authentication
- window verifiers
AUTH_DES Authentication Verifiers
X
- .x suffix
RPC Protocol Description File: dir.x
- XDR (external data representation)
- block size
Basic Block Size
- canonical standard
XDR Canonical Standard
- convert from (deserialize)
XDR Library
- converting from (deserialize)
XDR Library
Memory Allocation With XDR
Memory Allocation With XDR
Passing Arbitrary Data Types
- converting to (serialize)
XDR Library
XDR Library
Memory Allocation With XDR
Memory Allocation With XDR
Passing Arbitrary Data Types
Client-side Implementation of rls.c
Passing Complex Data Structures
- cost of conversion
XDR Canonical Standard
- direction determination for operations
Operation Directions
- file data structure in
XDR Data Description
- graphic box notation
Graphic Box Notation
- library
XDR Library
XDR Library
- linked lists
Optional-Data Type
Advanced XDR Topics
- optimizing routines
Operation Directions
- primitive routines
XDR Library
Passing Arbitrary Data Types
- arrays
Array Example #3
- byte arrays
Byte Arrays
- discriminated unions
Discriminated Unions
- nonfilter
Nonfilter Primitives
- opaque data
xdr_netobj Routine
Opaque Data
- pointers
Pointer Semantics
Pointers in RPC
- strings
String Type Definition in RPC
- unions
Discriminated Unions
- rpcgen tool
rpcgen Preprocessing Directives
Client-side Implementation of rls.c
Passing Complex Data Structures
- streams
- accessing
Stream Access
- creation by RPC system
XDR Library
- implementing new instances
XDR Stream Implementation
- implementing new instances of
XDR Stream Interface Example
- interface
XDR Stream Interface Example
XDR Stream Implementation
- memory
Memory Streams
- nonfilter primitives
Nonfilter Primitives
- record (TCP/IP)
Record-Marking Standard
Record-Marking Standard
Record TCP/IP Streams
Memory Streams
- standard I/O
Standard I/O Streams
- with memory allocation
Memory Allocation With XDR
Memory Allocation With XDR
- XDR language
- authentication protocol
Diffie-Hellman Encryption
- arrays
Syntax Notes About XDR
Declaration of Counted Array and Variable-Length Array
Fixed-Length Array
- AUTH_DES authentication protocol
DES Authentication Protocol (in XDR language)
- Booleans
Boolean Representation
- comments
Lexical Notes About XDR Specification
- constants
Syntax Notes About XDR
Lexical Notes About XDR Specification
Constant Type
- counted byte strings
Declaration of Counted Byte Strings
Counted Byte Strings
- declarations
Optional-Data Type
XDR Data Type Declarations
- discriminated unions
Syntax Notes About XDR
Optional-Data Type
Discriminated Union
- enumerations
Enumeration Representation
- fixed-length arrays
Fixed-Length Array
- fixed-length opaque data
Fixed-Length Opaque Data
- floating point
Floating Point Representation
- identifiers
Lexical Notes About XDR Specification
- keywords
Syntax Notes About XDR
- opaque data
Variable-Length Opaque Encoding
Fixed-Length Opaque Data
- optional-data unions
Optional-Data Type
- overview
XDR Protocol Introduction
- quadruple-precision floating point
Quadruple-Precision Floating Point
- RPC language
RPC Language Specification
- RPC language and
RPC Language Reference
- RPC message protocol
RPC Message Protocol
- specification for
Notational Conventions of XDR
- strings
Declaration of Counted Byte Strings
Counted Byte Strings
- structures
Syntax Notes About XDR
Structure Components
- syntax
Syntax Notes About XDR
Syntax Notes About XDR
- type definitions
Syntax Notes About XDR
Typedef and Data
Typedef and Data
- unions
Syntax Notes About XDR
Optional-Data Type
Discriminated Union
- unsigned integers
Unsigned Integer
- variable-length arrays
Variable-Length Array
- variable-length opaque data
Variable-Length Opaque Encoding
Variable-Length Opaque Data
- voids
Void Type
- xdr_ prefix
RPC Protocol Description File: dir.x
- xdr_array() routine
Array Example #3
xdr_varintarr Syntax Use
- xdr_bytes() routine
Byte Arrays
- XDR_DECODE operation
Constructed Data Type Filters
- XDR_ENCODE operation
Constructed Data Type Filters
- XDR_FREE operation
Constructed Data Type Filters
- xdr_inline count
Compile-Time xdr_inline Count
rpcgen Compile-Time Flags
- xdr_type (object) notation
AUTH_KERB Authentication
- xdrs-x_op field
Operation Directions