1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
|
/*
* This file is part of the PCEPlib, a PCEP protocol library.
*
* Copyright (C) 2020 Volta Networks https://voltanet.io/
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* Author : Brady Johnson <brady@voltanet.io>
*
*/
/*
* Definitions of PCEP Counters.
*/
#ifndef PCEP_UTILS_INCLUDE_PCEP_UTILS_COUNTERS_H_
#define PCEP_UTILS_INCLUDE_PCEP_UTILS_COUNTERS_H_
#include <stdbool.h>
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/*
* Example Counter group with sub-groups and counters
*
* pcep_counters {
* counters_group_rx {
* message_open;
* message_keepalive;
* message_pcreq;
* }
* counters_group_tx {
* message_open;
* message_keepalive;
* message_pcreq;
* }
* counters_group_events {
* pcc_connect;
* pce_connect;
* pcc_disconnect;
* pce_disconnect;
* }
* }
*
* To create the above structure of groups, sub-groups, and counters, do the
* following:
*
* struct counters_subgroup *rx_subgroup = create_counters_subgroup("rx
* counters", 3); struct counters_subgroup *tx_subgroup =
* create_counters_subgroup("tx counters", 3); struct counters_subgroup
* *events_subgroup = create_counters_subgroup("events counters", 4);
*
* Use message_id: PCEP_TYPE_OPEN=1
* create_subgroup_counter(rx_subgroup, 1, "Message Open");
* create_subgroup_counter(rx_subgroup, 2, "Message KeepAlive");
* create_subgroup_counter(rx_subgroup, 3, "Message PcReq");
*
* create_subgroup_counter(tx_subgroup, 1, "Message Open");
* create_subgroup_counter(tx_subgroup, 2, "Message KeepAlive");
* create_subgroup_counter(tx_subgroup, 3, "Message PcReq");
*
* create_subgroup_counter(events_subgroup, 1, "PCC Connect");
* create_subgroup_counter(events_subgroup, 2, "PCE Connect");
* create_subgroup_counter(events_subgroup, 3, "PCC Disconnect");
* create_subgroup_counter(events_subgroup, 4, "PCE Disconnect");
*
* struct counters_group *cntrs_group = create_counters_group("PCEP Counters",
* 3); add_counters_subgroup(cntrs_group, rx_subgroup);
* add_counters_subgroup(cntrs_group, tx_subgroup);
* add_counters_subgroup(cntrs_group, events_subgroup);
*/
#define MAX_COUNTER_STR_LENGTH 128
#define MAX_COUNTER_GROUPS 500
#define MAX_COUNTERS 500
struct counter {
uint16_t counter_id;
char counter_name[MAX_COUNTER_STR_LENGTH];
uint32_t counter_value;
};
struct counters_subgroup {
char counters_subgroup_name[MAX_COUNTER_STR_LENGTH];
uint16_t subgroup_id;
uint16_t num_counters;
uint16_t max_counters;
/* Array of (struct counter *) allocated when the subgroup is created.
* The array is indexed by the struct counter->counter_id */
struct counter **counters;
};
struct counters_group {
char counters_group_name[MAX_COUNTER_STR_LENGTH];
uint16_t num_subgroups;
uint16_t max_subgroups;
time_t start_time;
/* Array of (struct counters_subgroup *) allocated when the group is
* created. The subgroup is indexed by the (struct counters_subgroup
* *)->subgroup_id */
struct counters_subgroup **subgroups;
};
/*
* Create a counters group with the given group_name and number of subgroups.
* Subgroup_ids are 0-based, so take that into account when setting
* max_subgroups. Return true on success or false if group_name is NULL or
* max_subgroups >= MAX_COUNTER_GROUPS.
*/
struct counters_group *create_counters_group(const char *group_name,
uint16_t max_subgroups);
/*
* Create a counters subgroup with the given subgroup_name, subgroup_id and
* number of counters. The subgroup_id is 0-based. counter_ids are 0-based, so
* take that into account when setting max_counters. Return true on success or
* false if subgroup_name is NULL, subgroup_id >= MAX_COUNTER_GROUPS, or
* max_counters >= MAX_COUNTERS.
*/
struct counters_subgroup *create_counters_subgroup(const char *subgroup_name,
uint16_t subgroup_id,
uint16_t max_counters);
/*
* Add a counter_subgroup to a counter_group.
* Return true on success or false if group is NULL or if subgroup is NULL.
*/
bool add_counters_subgroup(struct counters_group *group,
struct counters_subgroup *subgroup);
/*
* Clone a subgroup and set a new name and subgroup_id for the new subgroup.
* This is useful for RX and TX counters: just create the RX counters and clone
* it for the TX counters.
*/
struct counters_subgroup *
clone_counters_subgroup(struct counters_subgroup *subgroup,
const char *subgroup_name, uint16_t subgroup_id);
/*
* Create a counter in a subgroup with the given counter_id and counter_name.
* The counter_id is 0-based.
* Return true on success or false if subgroup is NULL, counter_id >=
* MAX_COUNTERS, or if counter_name is NULL.
*/
bool create_subgroup_counter(struct counters_subgroup *subgroup,
uint32_t counter_id, const char *counter_name);
/*
* Delete the counters_group and recursively delete all subgroups and their
* counters. Return true on success or false if group is NULL.
*/
bool delete_counters_group(struct counters_group *group);
/*
* Delete the counters_subgroup and all its counters counters.
* Return true on success or false if subgroup is NULL.
*/
bool delete_counters_subgroup(struct counters_subgroup *subgroup);
/*
* Reset all the counters in all sub-groups contained in this group.
* Return true on success or false if group is NULL.
*/
bool reset_group_counters(struct counters_group *group);
/*
* Reset all the counters in this subgroup.
* Return true on success or false if subgroup is NULL.
*/
bool reset_subgroup_counters(struct counters_subgroup *subgroup);
/*
* Increment a counter given a counter_group, subgroup_id, and counter_id.
* Return true on success or false if group is NULL, subgroup_id >=
* MAX_COUNTER_GROUPS, or counter_id >= MAX_COUNTERS.
*/
bool increment_counter(struct counters_group *group, uint16_t subgroup_id,
uint16_t counter_id);
/*
* Increment a counter given the counter_subgroup and counter_id.
* Return true on success or false if subgroup is NULL or counter_id >=
* MAX_COUNTERS.
*/
bool increment_subgroup_counter(struct counters_subgroup *subgroup,
uint16_t counter_id);
/*
* Dump the counter_group info and all its counter_subgroups.
* Return true on success or false if group is NULL.
*/
bool dump_counters_group_to_log(struct counters_group *group);
/*
* Dump all the counters in a counter_subgroup.
* Return true on success or false if subgroup is NULL.
*/
bool dump_counters_subgroup_to_log(struct counters_subgroup *subgroup);
/*
* Search for a counters_subgroup by subgroup_id in a counters_group
* and return it, if found, else return NULL.
*/
struct counters_subgroup *find_subgroup(const struct counters_group *group,
uint16_t subgroup_id);
/*
* Given a counters_subgroup, return the sum of all the counters.
*/
uint32_t subgroup_counters_total(struct counters_subgroup *subgroup);
#ifdef __cplusplus
}
#endif
#endif /* PCEP_UTILS_INCLUDE_PCEP_UTILS_COUNTERS_H_ */
|