xref: /aosp_15_r20/external/libwebsockets/lib/system/metrics/private-lib-system-metrics.h (revision 1c60b9aca93fdbc9b5f19b2d2194c91294b22281)
1*1c60b9acSAndroid Build Coastguard Worker /*
2*1c60b9acSAndroid Build Coastguard Worker  * lws System Metrics
3*1c60b9acSAndroid Build Coastguard Worker  *
4*1c60b9acSAndroid Build Coastguard Worker  * Copyright (C) 2021 Andy Green <[email protected]>
5*1c60b9acSAndroid Build Coastguard Worker  *
6*1c60b9acSAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a copy
7*1c60b9acSAndroid Build Coastguard Worker  * of this software and associated documentation files (the "Software"), to
8*1c60b9acSAndroid Build Coastguard Worker  * deal in the Software without restriction, including without limitation the
9*1c60b9acSAndroid Build Coastguard Worker  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*1c60b9acSAndroid Build Coastguard Worker  * sell copies of the Software, and to permit persons to whom the Software is
11*1c60b9acSAndroid Build Coastguard Worker  * furnished to do so, subject to the following conditions:
12*1c60b9acSAndroid Build Coastguard Worker  *
13*1c60b9acSAndroid Build Coastguard Worker  * The above copyright notice and this permission notice shall be included in
14*1c60b9acSAndroid Build Coastguard Worker  * all copies or substantial portions of the Software.
15*1c60b9acSAndroid Build Coastguard Worker  *
16*1c60b9acSAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*1c60b9acSAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*1c60b9acSAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*1c60b9acSAndroid Build Coastguard Worker  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*1c60b9acSAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*1c60b9acSAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22*1c60b9acSAndroid Build Coastguard Worker  * IN THE SOFTWARE.
23*1c60b9acSAndroid Build Coastguard Worker  */
24*1c60b9acSAndroid Build Coastguard Worker 
25*1c60b9acSAndroid Build Coastguard Worker /*
26*1c60b9acSAndroid Build Coastguard Worker  * Const struct that describes a policy for processing raw metrics to turn them
27*1c60b9acSAndroid Build Coastguard Worker  * into events.
28*1c60b9acSAndroid Build Coastguard Worker  *
29*1c60b9acSAndroid Build Coastguard Worker  * Typically although we want to monitor every event, the data produced can be
30*1c60b9acSAndroid Build Coastguard Worker  * too large, and many events that are "normal" just need to be counted as such;
31*1c60b9acSAndroid Build Coastguard Worker  * outliers or change-to-continuous outliers may deserve closer recording as
32*1c60b9acSAndroid Build Coastguard Worker  * events in their own right.
33*1c60b9acSAndroid Build Coastguard Worker  *
34*1c60b9acSAndroid Build Coastguard Worker  * Mean computation must "decay" as it ages, we do this by halving the sum and
35*1c60b9acSAndroid Build Coastguard Worker  * count after .us_decay_unit us.
36*1c60b9acSAndroid Build Coastguard Worker  *
37*1c60b9acSAndroid Build Coastguard Worker  * We don't acknowledge outliers until there are at least .min_contributors
38*1c60b9acSAndroid Build Coastguard Worker  * in the current mean (which is subject to decaying)
39*1c60b9acSAndroid Build Coastguard Worker  *
40*1c60b9acSAndroid Build Coastguard Worker  * We decide something is an outlier event if it deviates from the mean by
41*1c60b9acSAndroid Build Coastguard Worker  * .pc_outlier_deviation %.
42*1c60b9acSAndroid Build Coastguard Worker  */
43*1c60b9acSAndroid Build Coastguard Worker 
44*1c60b9acSAndroid Build Coastguard Worker /*
45*1c60b9acSAndroid Build Coastguard Worker  * The dynamic counterpart for each static metric policy, this is on heap
46*1c60b9acSAndroid Build Coastguard Worker  * one per const lws_metric_policy_t.  It's listed in context->owner_mtr_dynpol
47*1c60b9acSAndroid Build Coastguard Worker  */
48*1c60b9acSAndroid Build Coastguard Worker 
49*1c60b9acSAndroid Build Coastguard Worker typedef struct lws_metric_policy_dyn {
50*1c60b9acSAndroid Build Coastguard Worker 	const lws_metric_policy_t	*policy;
51*1c60b9acSAndroid Build Coastguard Worker 	/**< the static part of the policy we belong to... can be NULL if no
52*1c60b9acSAndroid Build Coastguard Worker 	 * policy matches or the policy was invalidated */
53*1c60b9acSAndroid Build Coastguard Worker 
54*1c60b9acSAndroid Build Coastguard Worker 	lws_dll2_owner_t		owner;
55*1c60b9acSAndroid Build Coastguard Worker 	/**< list of metrics that are using this policy */
56*1c60b9acSAndroid Build Coastguard Worker 
57*1c60b9acSAndroid Build Coastguard Worker 	lws_dll2_t			list;
58*1c60b9acSAndroid Build Coastguard Worker 	/**< context owns us */
59*1c60b9acSAndroid Build Coastguard Worker 
60*1c60b9acSAndroid Build Coastguard Worker 	lws_sorted_usec_list_t		sul;
61*1c60b9acSAndroid Build Coastguard Worker 	/**< schedule periodic reports for metrics using this policy */
62*1c60b9acSAndroid Build Coastguard Worker } lws_metric_policy_dyn_t;
63*1c60b9acSAndroid Build Coastguard Worker 
64*1c60b9acSAndroid Build Coastguard Worker /*
65*1c60b9acSAndroid Build Coastguard Worker  * A metrics private part, encapsulating the public part
66*1c60b9acSAndroid Build Coastguard Worker  */
67*1c60b9acSAndroid Build Coastguard Worker 
68*1c60b9acSAndroid Build Coastguard Worker typedef struct lws_metric {
69*1c60b9acSAndroid Build Coastguard Worker 
70*1c60b9acSAndroid Build Coastguard Worker 	lws_dll2_t			list;
71*1c60b9acSAndroid Build Coastguard Worker 	/**< owned by either 1) ctx.lws_metric_policy_dyn_t.owner, or
72*1c60b9acSAndroid Build Coastguard Worker 	 * 2) ctx.owner_mtr_no_pol */
73*1c60b9acSAndroid Build Coastguard Worker 
74*1c60b9acSAndroid Build Coastguard Worker 	struct lws_context		*ctx;
75*1c60b9acSAndroid Build Coastguard Worker 
76*1c60b9acSAndroid Build Coastguard Worker 	/* public part overallocated */
77*1c60b9acSAndroid Build Coastguard Worker } lws_metric_t;
78*1c60b9acSAndroid Build Coastguard Worker 
79*1c60b9acSAndroid Build Coastguard Worker 
80*1c60b9acSAndroid Build Coastguard Worker #if defined(LWS_WITH_SYS_METRICS)
81*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv(_mt, _name) \
82*1c60b9acSAndroid Build Coastguard Worker 		lws_metrics_hist_bump_(lws_metrics_priv_to_pub(_mt), _name)
83*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_wsi(_wsi, _hist, _name) \
84*1c60b9acSAndroid Build Coastguard Worker 		lws_metrics_hist_bump_(lws_metrics_priv_to_pub(_wsi->a.context->_hist), _name)
85*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_ss(_ss, _hist, _name) \
86*1c60b9acSAndroid Build Coastguard Worker 		lws_metrics_hist_bump_(lws_metrics_priv_to_pub(_ss->context->_hist), _name)
87*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_priv_to_pub(_x) ((lws_metric_pub_t *)&(_x)[1])
88*1c60b9acSAndroid Build Coastguard Worker #else
89*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv(_mt, _name)
90*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_wsi(_wsi, _hist, _name)
91*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_hist_bump_priv_ss(_ss, _hist, _name)
92*1c60b9acSAndroid Build Coastguard Worker #define lws_metrics_priv_to_pub(_x) ((lws_metric_pub_t *)NULL)
93*1c60b9acSAndroid Build Coastguard Worker #endif
94*1c60b9acSAndroid Build Coastguard Worker 
95*1c60b9acSAndroid Build Coastguard Worker #if defined(LWS_WITH_SECURE_STREAMS_PROXY_API)
96*1c60b9acSAndroid Build Coastguard Worker /*
97*1c60b9acSAndroid Build Coastguard Worker  * sspc-specific version that also appends the tag value to the lifecycle tag
98*1c60b9acSAndroid Build Coastguard Worker  * used for logging the sspc identity
99*1c60b9acSAndroid Build Coastguard Worker  */
100*1c60b9acSAndroid Build Coastguard Worker int
101*1c60b9acSAndroid Build Coastguard Worker lws_metrics_tag_sspc_add(struct lws_sspc_handle *ss, const char *name, const char *val);
102*1c60b9acSAndroid Build Coastguard Worker #endif
103*1c60b9acSAndroid Build Coastguard Worker 
104*1c60b9acSAndroid Build Coastguard Worker int
105*1c60b9acSAndroid Build Coastguard Worker lws_metrics_register_policy(struct lws_context *ctx,
106*1c60b9acSAndroid Build Coastguard Worker 			    const lws_metric_policy_t *head);
107*1c60b9acSAndroid Build Coastguard Worker 
108*1c60b9acSAndroid Build Coastguard Worker void
109*1c60b9acSAndroid Build Coastguard Worker lws_metrics_destroy(struct lws_context *ctx);
110*1c60b9acSAndroid Build Coastguard Worker 
111*1c60b9acSAndroid Build Coastguard Worker void
112*1c60b9acSAndroid Build Coastguard Worker lws_metric_event(lws_metric_t *mt, char go_nogo, u_mt_t val);
113*1c60b9acSAndroid Build Coastguard Worker 
114*1c60b9acSAndroid Build Coastguard Worker lws_metric_t *
115*1c60b9acSAndroid Build Coastguard Worker lws_metric_create(struct lws_context *ctx, uint8_t flags, const char *name);
116*1c60b9acSAndroid Build Coastguard Worker 
117*1c60b9acSAndroid Build Coastguard Worker int
118*1c60b9acSAndroid Build Coastguard Worker lws_metric_destroy(lws_metric_t **mt, int keep);
119*1c60b9acSAndroid Build Coastguard Worker 
120*1c60b9acSAndroid Build Coastguard Worker void
121*1c60b9acSAndroid Build Coastguard Worker lws_metric_policy_dyn_destroy(lws_metric_policy_dyn_t *dm, int keep);
122*1c60b9acSAndroid Build Coastguard Worker 
123*1c60b9acSAndroid Build Coastguard Worker void
124*1c60b9acSAndroid Build Coastguard Worker lws_metric_rebind_policies(struct lws_context *ctx);
125