summaryrefslogtreecommitdiff
path: root/TODO-vmon.txt
diff options
context:
space:
mode:
authorVito Caputo <vcaputo@pengaru.com>2025-01-12 13:23:45 -0800
committerVito Caputo <vcaputo@pengaru.com>2025-01-12 13:23:45 -0800
commit3a29d7bc88ab258e1a864f1932ba08380199125c (patch)
tree29fc70284af353c10b8827ea713a2b6d0ba3d00a /TODO-vmon.txt
parent8bc0ad2e099b348db6a1e100ea774545d6087c1b (diff)
TODO: introduce TODO-vmon.txtHEADmaster
This is an early stab at writing down some vmon-specific TODO items along with some cash bounties for any frends/users interested in hacking on this stuff for some cash on the side. I may work on these myself, anyone interested in doing these things and expecting to get paid _must_ email me first to avoid racing with me or others working on the same thing. Also I am fairly opinionated in how these things should be done, so we'll have to discuss the details or be prepared for disappointment.
Diffstat (limited to 'TODO-vmon.txt')
-rw-r--r--TODO-vmon.txt126
1 files changed, 126 insertions, 0 deletions
diff --git a/TODO-vmon.txt b/TODO-vmon.txt
new file mode 100644
index 0000000..b3fc1bb
--- /dev/null
+++ b/TODO-vmon.txt
@@ -0,0 +1,126 @@
+vmon is being used internally at my $dayjob, as such I can justify paying some
+bounties to anyone willing to work on these items for some cash.
+
+Payment is predicated on successful merging of the work, which means it must
+get through review by yours truly. We're not rewriting everything, we're not
+changing languages, we're making minimal changes to deliver what's asked.
+
+Before beginning any work listed here, please email <vcaputo@pengaru.com> to
+verify nobody else has started work on the same item, as well as to clarify
+what your intentions are and discuss any implementation details. Dollar
+amounts listed below are estimates, we will arrive at a firmer number in
+email. If you don't communicate with me before working on these things, be
+prepared for disappointment.
+
+There is no commitment being made here to merge anything you deliver, but
+should the work get merged, you will be paid.
+
+--------------------------------------------------------------------------------
+
+- vmon needs a generalized mechanism for runtime-defined static rows introduced
+ into the charts. Stuff like WiFi signal:noise levels, or
+ hwmon/thermal_zone_device temperature values vs. related throttles to plot
+ temperature in red with the related throttling action in cyan.
+
+ I'm leaning towards there being a CLI argument for introducing
+ a static row, with a syntax like:
+
+ --source "TYPE:label" "[TYPE-specific-args...]"
+
+ where the "--source source-args" position in argv influences its relative
+ order within the chart when appropriate, but --source+TYPE branches into
+ TYPE-specific cli handling of the rest which may or may not expect more
+ explicit positional/layout information regarding where to put this source in
+ the charts.
+
+ Beyond that, what happens in the TYPE-specific-args is entirely polymorphic
+ in the sense that the TYPE-specific code does whatever's needed there.
+
+ The first source to add should be some generic static single row wiring up
+ two sampled sources like /sys/ nodes producing a single stringified integer
+ when each read from. Targeting temperature values... with a float multiplier
+ to scale what's read into the row's height linearly, like a %age.
+
+ e.g. --source "therm:radio0" "/sys/class/thermal_zone_device10/temp,min,max;/sys/class/cooling_device/throttle,min,max"
+
+ where "therm" maps to a "therm" handler that knows how to parse and apply:
+ "/sys/class/thermal_zone_device10/temp,min,max;/sys/class/cooling_device/throttle,min,max"
+
+ the "radio0" part after therm: would be what gets drawn over the row as a
+ label, the "therm" handler just needs to do the sampling and draw the meters
+ for the row.
+
+ this must be done in a generalized manner where "therm" can be
+ easily replaced with "bar" for plugging in a new "bar" handler,
+ as there will be additional static rows to add - like the
+ aforementioned signal:noise row.
+
+ Proposed bounty upon successful merge upstream: $400
+
+
+- Processes should have a memory row accompanying the user+sys cpu row. It's
+ only appropriate per-process, as threads share their process' address space.
+
+ It's unclear to me how to determine the scale to use for the memory rows, if
+ it should be a %age of the total system physical memory, or something else.
+ Maybe it would be better as a relative growth/shrinkage plot where the red
+ indicates %age RSS increased from the bottom up (inverted vs. cpu) and cyan
+ %age RSS decreased from top down (also inverted vs. cpu)
+
+ If the relative movement approach is used, it'd have to rely on a numberic
+ overlay to capture the current absolute RSS value.
+
+ This would be desirable to capture in the snowflakes when a process exits,
+ alongside the cpu utilization graphs.
+
+ A significant part of the work required to add memory rows to just the
+ processes will likely be breaking the assumption that it's a single row of
+ pixels per thread and process, uniformly. Instead it'll be double height for
+ only the processes.
+
+ libvmon doesn't currently collect memory stats, so this will require libvmon
+ work adding that without introducing a bunch of undue overhead, in addition
+ to likely invasive changes to charts.c/vcr.c to deal with existing
+ assumptions surrounding the per-process/per-thread row height being a uniform
+ thing... since processes would now have another row for memory, while threads
+ would continue containing only cpu.
+
+ Proposed bounty upon successful merge upstream: $1000
+
+
+- A CLI flag for turning vmon into a subreaper would be handy. It's fairly
+ trivial but does mean vmon would have to become more robust in its child
+ reaping to not accumulate zombies. This is regarding the
+ PR_SET_CHILD_SUBREAPER prctl... when you run a command under vmon in an
+ strace-like fashion, being a subreaper would capture orphaned descendents
+ like daemons so they don't leave vmon's scope upon becoming orphans inherited
+ by some ancestor subreaper, likely pid1.
+
+ Proposed bounty upon successful merge upstream: $100
+
+
+- charts.c should do the non-zero level detection in the integer domain, to
+ ensure no floating point precision/rounding errors can result in 0-height
+ bars in the graph for non-zero but well below 1 pixel when scaled levels.
+
+ Proposed bounty upon successful merge upstream: $50
+
+
+- I've noticed that when testing vmon in embedded devices experiencing large
+ scheduling delays, enough that the Adherence row becomes solid red, vmon
+ still tends to produce an inconsistent duration in the bar graph. So
+ there's still some work to be done here in terms of not losing/adding time
+ in the long run when Adherence consistently slips.
+
+ The cases where I've observed this use 8000 width graphs with 1Hz sample
+ rates, combined with a heavly loaded system suffering from memory pressure
+ thrashing and scheduler contention. The snapshots are being saved every 25
+ minutes, but the actual time passed in the graph's X axis varies as much as
+ several minutes. This almost certainly has to do with the Adherence
+ handling and sample repeating done to fill in the missed samples. It'd be
+ nice to firm this area up such that the X axis distance traveled accurately
+ reflects the time passed. It might require maintaining a cumulative
+ fractional error value across samples to compensate for, since cumulative
+ error is what's causing this.
+
+ Proposed bounty upon successful merge upstream: $100
© All Rights Reserved