parser: some more const-correctness for the other functions in msg_parser.[c,h]
[sip-router] / sctp_stats.h
1 /* 
2  * $Id$
3  * 
4  * Copyright (C) 2009 iptelorg GmbH
5  *
6  * Permission to use, copy, modify, and distribute this software for any
7  * purpose with or without fee is hereby granted, provided that the above
8  * copyright notice and this permission notice appear in all copies.
9  *
10  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17  */
18 /*
19  * sctp_stats.h - sctp statistics macros
20  */
21 /*
22  * History:
23  * --------
24  *  2009-04-28  initial version (andrei)
25 */
26
27 #ifndef __sctp_stats_h
28 #define __sctp_stats_h
29
30
31 /* enable sctp stats by default */
32 #ifndef NO_SCTP_STATS
33 #define USE_SCTP_STATS
34 #endif
35
36 #ifndef USE_SCTP_STATS
37
38 #define INIT_SCTP_STATS() 0 /* success */
39 #define DESTROY_SCTP_STATS()
40
41 #define SCTP_STATS_ESTABLISHED()
42 #define SCTP_STATS_CONNECT_FAILED()
43 #define SCTP_STATS_LOCAL_REJECT()
44 #define SCTP_STATS_REMOTE_SHUTDOWN()
45 #define SCTP_STATS_ASSOC_SHUTDOWN()
46 #define SCTP_STATS_COMM_LOST()
47 #define SCTP_STATS_SENDQ_FULL()
48 #define SCTP_STATS_SEND_FAILED()
49 #define SCTP_STATS_SEND_FORCE_RETRY()
50
51 #else /* USE_SCTP_STATS */
52
53 #include "counters.h"
54
55 struct sctp_counters_h {
56         counter_handle_t established;
57         counter_handle_t connect_failed;
58         counter_handle_t local_reject;
59         counter_handle_t remote_shutdown;
60         counter_handle_t assoc_shutdown;
61         counter_handle_t comm_lost;
62         counter_handle_t sendq_full;
63         counter_handle_t send_failed;
64         counter_handle_t send_force_retry;
65 };
66
67 extern struct sctp_counters_h sctp_cnts_h;
68
69 int sctp_stats_init();
70 void sctp_stats_destroy();
71
72 #define INIT_SCTP_STATS() sctp_stats_init() /* success */
73
74 #define DESTROY_SCTP_STATS() sctp_stats_destroy()
75
76
77 /** called each time a new sctp assoc. is established.
78  * sctp notification: SCTP_COMM_UP.
79  */
80 #define SCTP_STATS_ESTABLISHED() \
81         counter_inc(sctp_cnts_h.established)
82
83 /** called each time a new outgoing connection/assoc open fails.
84  *  sctp notification: SCTP_CANT_STR_ASSOC
85  */
86 #define SCTP_STATS_CONNECT_FAILED() \
87         counter_inc(sctp_cnts_h.connect_failed)
88
89 /** called each time a new incoming connection is rejected.  */
90 #define SCTP_STATS_LOCAL_REJECT() \
91         counter_inc(sctp_cnts_h.local_reject)
92
93
94 /** called each time a connection is closed by the peer.
95   * sctp notification: SCTP_SHUTDOWN_EVENT
96   */
97 #define SCTP_STATS_REMOTE_SHUTDOWN() \
98         counter_inc(sctp_cnts_h.remote_shutdown)
99
100
101 /** called each time a connection is shutdown.
102   * sctp notification: SCTP_SHUTDOWN_COMP
103   */
104 #define SCTP_STATS_ASSOC_SHUTDOWN() \
105         counter_inc(sctp_cnts_h.assoc_shutdown)
106
107
108 /** called each time an established connection is closed due to some error.
109   * sctp notification: SCTP_COMM_LOST
110   */
111 #define SCTP_STATS_COMM_LOST() \
112         counter_inc(sctp_cnts_h.comm_lost)
113
114
115 /** called each time a send fails due to the buffering capacity being exceeded.
116   * (send fails due to full kernel buffers)
117   */
118 #define SCTP_STATS_SENDQ_FULL() \
119         counter_inc(sctp_cnts_h.sendq_full)
120
121
122 /** called each time a send fails.
123   * (send fails for any reason except buffers full)
124   * sctp notification: SCTP_SEND_FAILED
125   */
126 #define SCTP_STATS_SEND_FAILED() \
127         counter_inc(sctp_cnts_h.send_failed)
128
129 /** called each time a failed send is force-retried.
130   * (possible only if sctp_send_retries is != 0)
131   */
132 #define SCTP_STATS_SEND_FORCE_RETRY() \
133         counter_inc(sctp_cnts_h.send_force_retry)
134
135 #endif /* USE_SCTP_STATS */
136
137 #endif /*__sctp_stats_h*/
138
139 /* vi: set ts=4 sw=4 tw=79:ai:cindent: */