xref: /freebsd/share/examples/mdoc/example.9 (revision 4928135658a9d0eaee37003df6137ab363fcb0b4)
1.\" Copyright (c) [year] [your name]
2.\"
3.\" Redistribution and use in source and binary forms, with or without
4.\" modification, are permitted provided that the following conditions
5.\" are met:
6.\" 1. Redistributions of source code must retain the above copyright
7.\"    notice, this list of conditions and the following disclaimer.
8.\" 2. Redistributions in binary form must reproduce the above copyright
9.\"    notice, this list of conditions and the following disclaimer in the
10.\"    documentation and/or other materials provided with the distribution.
11.\"
12.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
13.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
14.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
15.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
16.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
17.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
18.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
19.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
20.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
21.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
22.\" SUCH DAMAGE.
23.\"
24.\" $FreeBSD$
25.\"
26.\" Note: The date here should be updated whenever a non-trivial
27.\" change is made to the manual page.
28.Dd September 27, 2006
29.Dt EXAMPLE 9
30.Os
31.Sh NAME
32.Nm example
33.Nd "example kernel interface manual page"
34.Sh SYNOPSIS
35.In sys/example.h
36.Ft int
37.Fn example "char *ptr" "int mode"
38.Sh DESCRIPTION
39This is an example manual page for the
40.Fn example
41kernel function.
42It is intended that this example can be used as a template
43when writing a new manual page.
44.Pp
45The
46.Fn example
47function takes two arguments:
48.Fa ptr
49and
50.Fa mode .
51The argument
52.Fa mode
53may have one of the following values:
54.Bl -tag -width ".Dv EXAMPLE_ONE"
55.It Dv EXAMPLE_ONE
56First example of a defined variable.
57.Dv EXAMPLE_ONE
58is described below.
59.It Dv EXAMPLE_TWO
60Second example.
61.El
62.Pp
63The above values are defined in
64.In example.h
65as follows:
66.Bd -literal
67#define EXAMPLE_ONE  1
68#define EXAMPLE_TWO  2
69.Ed
70.Sh IMPLEMENTATION NOTES
71The
72.Fn example
73function is not actually implemented.
74.Sh LOCKING
75The
76.Va example_lock
77lock must be held before
78.Fn example
79is called.
80.Pp
81Since
82.Va example_lock
83is a
84.Xr mutex 9 ,
85no sleepable locks (i.e.,
86.Xr sx 9
87locks) can be acquired in
88.Fn example .
89.Sh RETURN VALUES
90The
91.Fn example
92function returns the value 0 if successful;
93otherwise one of the values listed in the
94.Sx ERRORS
95section is returned, to indicate the error.
96.Sh EXAMPLES
97.Bd -literal
98	int error;
99
100	mtx_lock(&example_lock);
101	if ((error = example(NULL, EXAMPLE_ONE)) != 0) {
102		mtx_unlock(&example_lock);
103		return (error);
104	}
105	mtx_unlock(&example_lock);
106.Ed
107.Sh COMPATIBILITY
108The
109.Fn example
110function has no known compatibility issues.
111.Sh ERRORS
112.\" Delete any errno's that are not returned by your
113.\" function or system call and then tailor the
114.\" remaining text as needed.
115The
116.Fn example
117function will fail if:
118.Bl -tag -width Er
119.It Bq Er EPERM
120Operation not permitted.
121.It Bq Er ENOENT
122No such file or directory.
123.It Bq Er ESRCH
124No such process.
125.It Bq Er EINTR
126Interrupted system call.
127.It Bq Er EIO
128Input/output error.
129.It Bq Er ENXIO
130Device not configured.
131.It Bq Er E2BIG
132Argument list too long.
133.It Bq Er ENOEXEC
134Exec format error.
135.It Bq Er EBADF
136Bad file descriptor.
137.It Bq Er ECHILD
138No child processes.
139.It Bq Er EDEADLK
140Resource deadlock avoided.
141.It Bq Er ENOMEM
142Cannot allocate memory.
143.It Bq Er EACCES
144Permission denied.
145.It Bq Er EFAULT
146Bad address.
147.It Bq Er ENOTBLK
148Block device required.
149.It Bq Er EBUSY
150Device busy.
151.It Bq Er EEXIST
152File exists.
153.It Bq Er EXDEV
154Cross-device link.
155.It Bq Er ENODEV
156Operation not supported by device.
157.It Bq Er ENOTDIR
158Not a directory.
159.It Bq Er EISDIR
160Is a directory.
161.It Bq Er EINVAL
162Invalid argument.
163.It Bq Er ENFILE
164Too many open files in system.
165.It Bq Er EMFILE
166Too many open files.
167.It Bq Er ENOTTY
168Inappropriate ioctl for device.
169.It Bq Er ETXTBSY
170Text file busy.
171.It Bq Er EFBIG
172File too large.
173.It Bq Er ENOSPC
174No space left on device.
175.It Bq Er ESPIPE
176Illegal seek.
177.It Bq Er EROFS
178Read-only file system.
179.It Bq Er EMLINK
180Too many links.
181.It Bq Er EPIPE
182Broken pipe.
183.It Bq Er EDOM
184Numerical argument out of domain.
185.It Bq Er ERANGE
186Result too large.
187.It Bq Er EAGAIN
188Resource temporarily unavailable.
189.It Bq Er EWOULDBLOCK
190Operation would block.
191.It Bq Er EINPROGRESS
192Operation now in progress.
193.It Bq Er EALREADY
194Operation already in progress.
195.It Bq Er ENOTSOCK
196Socket operation on non-socket.
197.It Bq Er EDESTADDRREQ
198Destination address required.
199.It Bq Er EMSGSIZE
200Message too long.
201.It Bq Er EPROTOTYPE
202Protocol wrong type for socket.
203.It Bq Er ENOPROTOOPT
204Protocol not available.
205.It Bq Er EPROTONOSUPPORT
206Protocol not supported.
207.It Bq Er ESOCKTNOSUPPORT
208Socket type not supported.
209.It Bq Er EOPNOTSUPP
210Operation not supported.
211.It Bq Er EPFNOSUPPORT
212Protocol family not supported.
213.It Bq Er EAFNOSUPPORT
214Address family not supported by protocol family.
215.It Bq Er EADDRINUSE
216Address already in use.
217.It Bq Er EADDRNOTAVAIL
218Cannot assign requested address.
219.It Bq Er ENETDOWN
220Network is down.
221.It Bq Er ENETUNREACH
222Network is unreachable.
223.It Bq Er ENETRESET
224Network dropped connection on reset.
225.It Bq Er ECONNABORTED
226Software causes connection abort.
227.It Bq Er ENOBUFS
228No buffer space available.
229.It Bq Er EISCONN
230Socket is already connected.
231.It Bq Er ENOTCONN
232Socket is not connected.
233.It Bq Er ESHUTDOWN
234Cannot send after socket shutdown.
235.It Bq Er ETOOMANYREFS
236Too many references: cannot splice.
237.It Bq Er ETIMEDOUT
238Operation timed out.
239.It Bq Er ECONNREFUSED
240Connection refused.
241.It Bq Er ELOOP
242Too many levels of symbolic links.
243.It Bq Er ENAMETOOLONG
244File name too long.
245.It Bq Er EHOSTDOWN
246Host is down.
247.It Bq Er EHOSTUNREACH
248No route to host.
249.It Bq Er ENOTEMPTY
250Directory not empty.
251.It Bq Er EPROCLIM
252Too many processes.
253.It Bq Er EUSERS
254Too many users.
255.It Bq Er EDQUOT
256Disc quota exceeded.
257.It Bq Er ESTALE
258Stale NFS file handle.
259.It Bq Er EREMOTE
260Too many levels of remote in path.
261.It Bq Er EBADRPC
262RPC struct is bad.
263.It Bq Er ERPCMISMATCH
264RPC version wrong.
265.It Bq Er EPROGUNAVAIL
266RPC program not available.
267.It Bq Er EPROGMISMATCH
268Program version wrong.
269.It Bq Er EPROCUNAVAIL
270Bad procedure for program.
271.It Bq Er ENOLCK
272No locks available.
273.It Bq Er ENOSYS
274Function not implemented.
275.It Bq Er EFTYPE
276Inappropriate file type or format.
277.It Bq Er EAUTH
278Authentication error.
279.It Bq Er ENEEDAUTH
280Need authenticator.
281.It Bq Er EIDRM
282Identifier removed.
283.It Bq Er ENOMSG
284No message of desired type.
285.It Bq Er EOVERFLOW
286Value too large to be stored in data type.
287.It Bq Er ECANCELED
288Operation canceled.
289.It Bq Er EILSEQ
290Illegal byte sequence.
291.It Bq Er ENOATTR
292Attribute not found.
293.It Bq Er EDOOFUS
294Programming error.
295.El
296.Sh SEE ALSO
297.Xr example 1 ,
298.Xr example 3 ,
299.Xr example 4 ,
300.Xr mdoc 7 ,
301.Xr mutex 9
302.Rs
303.%A "A. B. Author"
304.%T "Example RFC Title"
305.%O RFC0000
306.Re
307.Rs
308.%A "A. B. Author"
309.%B "Example Book Title"
310.%O ISBN-0-000-00000-0
311.Re
312.Rs
313.%A "A. B. Author"
314.%D "January 1997"
315.%J "Example Journal Name"
316.%T "Example Article Title"
317.Re
318.Sh HISTORY
319The
320.Nm
321manual page example first appeared in
322.Fx 6.0 .
323.Pp
324Some other common
325.Sx HISTORY
326section examples are:
327.Pp
328The
329.Nm
330manual page example first appeared in
331.Bx 4.4 .
332.Pp
333The
334.Nm
335manual page example first appeared in
336.At v6 .
337.Sh AUTHORS
338This
339manual page was written by
340.An Giorgos Keramidas Aq Mt keramida@FreeBSD.org .
341.Sh BUGS
342The actual code for this function is vaporware.
343