 
            Attention is currently required from: iedemam. neels has posted comments on this change. ( https://gerrit.osmocom.org/c/osmo-bsc/+/28165 )
Change subject: stats: new trackers for lchan life duration (v2) ......................................................................
Patch Set 4:
(1 comment)
Patchset:
PS4: I don't see any stats reporting in this patch anymore. This is only about VTY output? The commit log says "stats".
IMHO it would be better to fix the performance problem in osmo_time_cc. The way this patch avoids performance issues is to reduce the timer callback to 1/s, the time_cc patch called timers 10/s * nr of active lchans, by granularity configuration.
Of course we can reconfigure osmo_time_cc to trigger timers only once per second. It may be necessary to separate the granularity from the update timer period, then we can get milliseconds precision while updating that value less often.
Another fix is to have only one single timer callback that updates all active osmo_time_cc. Like that we can have active lchan tracking in millisecond precision for *any* number of lchans with only a single timer in select() for all of them. This would reduce the select() load by a factor that is the number of active lchans, in production environments this is more than factor 10 (as this patch does).
osmo_time_cc made problems because it is fairly new code that tries to solve a pretty complex problem in a generic way, and I built some problems into it. IMHO it is worth it to make that work, so that iedemam's patch will perform well.
On the other hand I feel like i have caused substantial work with my review on this topic, and i am ok with an implementation that goes in the wrong direction from my point of view, if it does the right thing in everyone else's opinion.