8322 nl: misleading-indentation
[unleashed/tickless.git] / usr / src / man / man9s / hook_t.9s
blob818603ba591580ef9b9e13cc6b24f2e6cea36d48
1 '\" te
2 .\"  Copyright (c) 2008 Sun Microsystems, Inc. All Rights Reserved
3 .\"  Copyright (c) 2012 Joyent, Inc. All Rights Reserved
4 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License").  You may not use this file except in compliance with the License.
5 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.  See the License for the specific language governing permissions and limitations under the License.
6 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE.  If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
7 .TH HOOK_T 9S "Mar 5, 2012"
8 .SH NAME
9 hook_t \- callback structure for subscribing to netinfo events
10 .SH SYNOPSIS
11 .LP
12 .nf
13 #include <sys/hook.h>
14 .fi
16 .SH INTERFACE LEVEL
17 .sp
18 .LP
19 Solaris DDI specific (Solaris DDI).
20 .SH DESCRIPTION
21 .sp
22 .LP
23 The \fBhook_t\fR data structure defines a callback that is to be inserted into
24 a networking event. This data structure must be allocated with a call to
25 \fBhook_alloc()\fR and released with a call to \fBhook_free()\fR.
26 .SH STRUCTURE MEMBERS
27 .sp
28 .in +2
29 .nf
30 hook_func_t  h_func;      /* callback function to invoke */
31 char         *h_name;     /* unique name given to the hook */
32 int          h_flags;
33 hook_hint_t  h_hint;      /* insertion hint type */
34 uintptr_t    h_hintvalue; /* used with h_hint */
35 void         *h_arg;      /* value to pass into h_func */
37 typedef int (*hook_func_t)(net_event_t token, hook_data_t info,
38               void *);
39 .fi
40 .in -2
42 .SS "CALLBACK RETURN VALUES"
43 .sp
44 .LP
45 The value returned by the \fBhook_func_t\fR function indicates whether or not
46 the packet should still be considered valid. If the callback function has
47 modified the packet in such a way that it should no longer be processed or
48 considered valid, e.g. called \fBfreemsg\fR(9F), then the callback should return
49 \fB1\fR. Otherwise it should return \fB0\fR.
50 .sp
52 .SS "HINT TYPES"
53 .sp
54 .LP
55 Hook hints are hints that are used at the time of insertion and are not rules
56 that enforce where a hook lives for its entire lifetime on an event. The valid
57 values for the \fBh_hint\fR field are:
58 .sp
59 .ne 2
60 .na
61 \fB\fBHH_NONE\fR\fR
62 .ad
63 .RS 13n
64 Insert the hook wherever convenient.
65 .RE
67 .sp
68 .ne 2
69 .na
70 \fB\fBHH_FIRST\fR\fR
71 .ad
72 .RS 13n
73 Place the hook first on the list of hooks.
74 .RE
76 .sp
77 .ne 2
78 .na
79 \fB\fBHH_LAST\fR\fR
80 .ad
81 .RS 13n
82 Place the hook last on the list of hooks.
83 .RE
85 .sp
86 .ne 2
87 .na
88 \fB\fBHH_BEFORE\fR\fR
89 .ad
90 .RS 13n
91 Place the hook before another hook on the list of hooks. The value in
92 \fBh_hintvalue\fR must be a pointer to the name of another hook.
93 .RE
95 .sp
96 .ne 2
97 .na
98 \fB\fBHH_AFTER\fR\fR
99 .ad
100 .RS 13n
101 Place the hook after another hook on the list of hooks. The value in
102 \fBh_hintvalue\fR must be a pointer to the name of another hook.
105 .SH ATTRIBUTES
108 See \fBattributes\fR(5) for descriptions of the following attributes:
113 box;
114 c | c
115 l | l .
116 ATTRIBUTE TYPE  ATTRIBUTE VALUE
118 Interface Stability     Committed
121 .SH SEE ALSO
124 \fBnetinfo\fR(9F)