1 .\" $NetBSD: rpcgen.1,v 1.21 2008/01/19 14:22:05 hubertf Exp $
2 .\" from: @(#)rpcgen.new.1 1.1 90/11/09 TIRPC 1.0; from 40.10 of 10/10/89
3 .\" Copyright (c) 1988,1990 Sun Microsystems, Inc. - All Rights Reserved.
9 .Nd Remote Procedure Call (RPC) protocol compiler
18 .Op Fl D Ar name Op =value
50 is a tool that generates C code to implement an
55 is a language similar to C known as
57 Language (Remote Procedure Call Language).
59 is normally used as in the first synopsis where
60 it takes an input file and generates up to four output files.
67 will generate a header file in
74 and client-side stubs in
79 it will also generate the
86 it will also generate sample code which would illustrate how to use the
87 remote procedures on the client side.
88 This code would be created in
93 it will also generate a sample server code which would illustrate how to write
94 the remote procedures.
95 This code would be created in
98 The server created can be started both by the port monitors
104 When it is started by a port monitor,
105 it creates servers only for the transport for which
106 the file descriptor 0 was passed.
107 The name of the transport must be specified
108 by setting up the environmental variable
110 When the server generated by
113 it creates server handles for all the transports
116 environment variable,
118 it creates server handles for all the visible transports from
123 the transports are chosen at run time and not at compile time.
124 When the server is self-started,
125 it backgrounds itself by default.
126 A special define symbol
128 can be used to run the server process in foreground.
130 The second synopsis provides special features which allow
131 for the creation of more sophisticated
134 These features include support for user provided
141 dispatch table contain:
143 .Bl -inset -offset indent -compact
145 pointers to the service routine corresponding to that procedure,
147 a pointer to the input and output arguments,
149 the size of these routines
152 A server can use the dispatch table to check authorization
153 and then to execute the service routine;
154 a client library may use it to deal with the details of storage
159 The other three synopses shown above are used when
160 one does not want to generate all the output files,
161 but only a particular one.
162 Some examples of their usage is described in the
170 it creates servers for that particular class of transports.
175 it creates a server for the transport specified by
181 accepts the standard input.
185 is run on the input file before it is actually interpreted by
187 For each type of output file,
189 defines a special preprocessor symbol for use by the
192 .Bl -tag -width RPC_CLNT
194 defined when compiling into header files
196 defined when compiling into
200 defined when compiling into server-side stubs
202 defined when compiling into client-side stubs
204 defined when compiling into
209 Any line beginning with
211 is passed directly into the output file,
215 For every data type referred to in
218 assumes that there exists a
219 routine with the string
221 prepended to the name of the data type.
222 If this routine does not exist in the
224 library, it must be provided.
225 Providing an undefined data type
226 allows customization of
230 .Bl -tag -width indent
232 Generate all the files including sample code for client and server side.
238 Compile stubs in "backwards compatible" mode, disabling support for
239 transport-independent RPC.
242 should always be specified when generating files for
244 since there is no transport-independent RPC support in
254 This option also generates code that could be compiled with the
256 .It Fl D Ar name Ns Op Ar =value
261 directive in the source.
267 This option may be specified more than once.
269 Compile into C data-definitions (a header file).
272 option can be used in conjunction to produce a
273 header file which supports
277 Size to decide when to start generating inline code.
278 The default size is 3.
282 in the server side stubs.
283 Servers generated using this flag can either be standalone or
286 If a server is started as standalone, then it places itself
287 in the background, unless
289 is defined, or the server is compiled without
292 By default, services created using
295 after servicing a request before exiting.
296 That interval can be changed using the
299 To create a server that exits immediately upon servicing a request,
302 To create a server that never exits, the appropriate argument is
305 When monitoring for a server,
306 some port monitors, like the
311 spawn a new process in response to a service request.
312 If it is known that a server will be used with such a monitor, the
313 server should exit immediately on completion.
319 Compile into client-side stubs.
322 Compile stubs meant for use in programs started by
325 Server errors will be sent to syslog instead of stderr.
327 Compile into server-side stubs,
328 but do not generate a
331 This option is useful for doing callback-routines
332 and for users who need to write their own
334 routine to do initialization.
336 Generate thread-safe stubs.
337 This alters the calling pattern of client and
338 server stubs so that storage for results is allocated by the caller.
340 that all components for a particular service (stubs, client and service
341 wrappers, etc.) must be built either with or without the
347 This allows procedures to have multiple arguments.
348 It also uses the style of parameter passing that closely resembles C.
349 So, when passing an argument to a remote procedure you do not have
350 to pass a pointer to the argument but the argument itself.
351 This behaviour is different from the oldstyle
355 The newstyle is not the default case because of backward compatibility.
357 Compile into server-side stubs for the transport
360 There should be an entry for
364 This option may be specified more than once,
365 so as to compile a server that serves multiple transports.
367 Specify the name of the output file.
368 If none is specified,
369 standard output is used
376 Specify the transport for the server-side stubs.
380 This option can be repeated in order to support more than one transport.
382 Compile into server-side stubs for all the
383 transports belonging to the class
385 The supported classes are
397 for the meanings associated with these classes.
400 currently supports only the
405 This option may be specified more than once.
407 the transports are chosen at run time and not at compile time.
409 Generate sample code to show the use of remote procedure and how to bind
410 to the server before calling the client side stubs generated by
413 Generate skeleton code for the remote procedures on the server side.
415 to fill in the actual code for the remote procedures.
417 .\" Generate a sample Makefile that can be used to compile the application.
423 Generate the code to support
427 Display the version number.
429 Specify the directory where
431 looks for the C pre-processor.
442 are used exclusively to generate a particular type of file,
447 are global and can be used with the other options.
451 environment variable is set, its value is used as the pathname of the
452 C preprocessor to be run on the input file.
456 Language does not support nesting of structures.
458 structures can be declared at the top-level,
459 and their name used inside other structures in
460 order to achieve the same effect.
462 Name clashes can occur when using program definitions,
463 since the apparent scoping does not really apply.
464 Most of these can be avoided by giving
465 unique names for programs,
467 procedures and types.
469 The server code generated with
471 option refers to the transport indicated by
473 and hence is very site specific.
477 .Bd -literal -offset indent
481 generates the five files:
489 The following example sends the C data-definitions (header file)
492 .Bd -literal -offset indent
496 To send the test version of the
498 server side stubs for
499 all the transport belonging to the class
501 to standard output, use:
503 .Bd -literal -offset indent
504 $ rpcgen -s datagram_n -DTEST prot.x
507 To create the server side stubs for the transport indicated by
512 .Bd -literal -offset indent
513 $ rpcgen -n tcp -o prot_svc.c prot.x
521 option was first implemented in RedHat Linux, and was reimplemented by