summaryrefslogtreecommitdiffstats
path: root/NetworkIOMeter.c
Commit message (Collapse)AuthorAgeFilesLines
* Update includes based on IWYUBenny Baumann2023-12-261-3/+2
|
* Fix code styleBenny Baumann2023-12-261-13/+12
|
* Add includes for config.h as per the discussion in PR #1337Daniel Lange2023-12-261-0/+2
| | | | | | Many thanks to @Explorer09 Kang-Che Sung (宋岡哲). Also add a #error stanza to XUtils.h in case somebody forgets the beautiful mess GNU forces on us.
* Change NetworkIOMeter value unit from KiB/s to bytes/secondExplorer092023-11-241-4/+2
| | | | | | Improve precisions when drawing in bar meter mode. Signed-off-by: Kang-Che Sung <explorer09@gmail.com>
* Cache NetworkIOMeter values in 'double' typeExplorer092023-11-241-4/+4
| | | | Signed-off-by: Kang-Che Sung <explorer09@gmail.com>
* NetworkIOMeter: Cache the formatted "KiB/s" number stringsExplorer092023-11-241-8/+7
| | | | | | | | In NetworkIOMeter, the number strings of bytes per second are formatted with Meter_humanUnit(). As the numbers are only updated every 500 ms, it is good to cache the formatted strings. This saves code size. Signed-off-by: Kang-Che Sung <explorer09@gmail.com>
* Always update 'values' member of NetworkIOMeterExplorer092023-11-241-51/+58
| | | | | | | | | | | Always update the `values` member during the call of NetworkIOMeter_updateValues(). This makes the values of every instance of NetworkIOMeter consistent. The user might see non-zero bars (or graph) during the "stale" status of the meter after this commit. The side effect is not a bug. Signed-off-by: Kang-Che Sung <explorer09@gmail.com>
* NetworkIOMeter: correct format string and code commentsExplorer092023-11-241-3/+3
|
* Merge branch 'style-header-consistency' of https://github.com/BenBE/htop ↵Nathan Scott2023-10-101-0/+7
|\ | | | | | | into BenBE-style-header-consistency
| * Add missing copyright/file headersBenny Baumann2023-05-251-0/+7
| |
* | Rename ProcessList to ProcessTable throughoutNathan Scott2023-08-311-1/+1
|/ | | | | | | | | | | | Following up with some discusson from a few months back, where it was proposed that ProcessTable is a better name. This data structure is definitely not a list ... if it was one-dimensional it'd be a set, but in practice it has much more in common with a two-dimensional table. The Process table is a familiar operating system concept for many people too so it resonates a little in that way as well.
* Introduce Machine class for host-specific info (split from ProcessList)Nathan Scott2023-05-081-3/+3
| | | | | | | | | | | First stage in sanitizing the process list structure so that htop can support other types of lists too (cgroups, filesystems, ...), in the not-too-distant future. This introduces struct Machine for system-wide information while keeping process-list information in ProcessList (now much less). Next step is to propogate this separation into each platform, to match these core changes.
* NetworkIOMeter: show packet rate in meter modeChristian Hesse2022-12-061-1/+2
| | | | Currently we have byte rate only.
* NetworkIOMeter: convert to packets per secondChristian Hesse2022-12-061-3/+5
| | | | We should normalize the packets as well...
* NetworkIOMeter: swap calculation for more precisionChristian Hesse2022-12-061-2/+2
| | | | Convert to per second first, divide for kilo after.
* IOMeters: rework initial displayChristian Göttsche2021-12-081-11/+32
| | | | | | | | | Show a non highlighted string at the start of htop, not the failure text. Also the original fix only handled the text mode, not the bar mode. Improves: 2977414d ("Discard stale information from DiskIO and NetworkIO meters") Related: #860
* Discard stale information from DiskIO and NetworkIO metersBenny Baumann2021-10-301-0/+6
| | | | | | | This ensures the initial read of the data is not misinterpreted as arbitrarily large values. Also this forces the maximum update interval between two subsequent reads to within 30s. Fixes #860
* cleaned up includes with iwyumayurdahibhate2021-05-101-2/+3
|
* Use RichString_appendnAscii where possibleChristian Göttsche2021-04-261-2/+3
| | | | | | | | | | `RichString_appendnAscii()` avoids a `strlen(3)` call over ` RichString_appendAscii()`. Use the former where the length is available from a previous checked `snprintf(3)` call. Keep `RichString_appendAscii()` when passing a string literal and rely on compilers to optimize the `strlen(3)` call away.
* Request the realtime and monotonic clock times once per sampleNathan Scott2021-04-051-2/+2
| | | | | | | | | | | | | | | | Refactor the sample time code to make one call to gettimeofday (aka the realtime clock in clock_gettime, when available) and one to the monotonic clock. Stores each in more appropriately named ProcessList fields for ready access when needed. Every platform gets the opportunity to provide their own clock code, and the existing Mac OS X specific code is moved below darwin instead of in Compat. A couple of leftover time(2) calls are converted to use these ProcessList fields as well, instead of yet again sampling the system clock. Related to https://github.com/htop-dev/htop/pull/574
* Merging all the points related to calculating time in one placeSohaib2021-04-051-5/+3
| | | | | | | | | | | | | | The end goal is to consolidate all the points in htop that can only work in live-only mode today, so that will be able to inject PCP archive mode and have a chance at it working. The biggest problem we've got at this moment is all the places that are independently asking the kernel to 'give me the time right now'. Each of those needs to be audited and ultimately changed to allow platforms to manage their own idea of time. So, all the calls to gettimeofday(2) and time(2) are potential problems. Ultimately I want to get these down to just one or two. Related to https://github.com/htop-dev/htop/pull/574
* Save text buffer in MeterChristian Göttsche2021-03-041-3/+3
|
* Switch NetworkIO Meter to using uint32_t and uint64_tNathan Scott2021-03-021-21/+21
| | | | From review via @BenBE, this is now a whole lot cleaner.
* Fix integer sizing issues in the NetworkIO MeterNathan Scott2021-03-011-29/+35
| | | | | | | | | On Linux kernels the size of the values exported for network device bytes and packets has used a 64 bit integer for quite some time (2.6+ IIRC). Make the procfs value extraction use correct types and change internal types used to rate convert these counters (within the NetworkIO Meter) 64 bit integers, where appropriate.
* Implement bar and graph mode for NetworkIOMeter (#408)Michael F. Schönitzer2021-02-281-2/+8
|
* Split RichString_(append|appendn|write) into wide and asciiChristian Göttsche2020-12-081-8/+8
| | | | | | | | RichString_writeFrom takes a top spot during performance analysis due to the calls to mbstowcs() and iswprint(). Most of the time we know in advance that we are only going to print regular ASCII characters.
* Use size_t as len type for Meter_UpdateValuesChristian Göttsche2020-12-061-1/+1
| | | | Most of the time the parameter is passed to snprintf type functions
* Reduce scope of cached valuesBenny Baumann2020-11-221-4/+6
|
* IWYU update (Linux)Christian Göttsche2020-11-191-0/+1
|
* Handle data wraparounds in IO MetersChristian Göttsche2020-11-021-6/+22
| | | | | | | If the current data is smaller than the previous one, either by a retrieve error or a device removal or a original data wraparound, sanitize the value to zero. Fixes: #299
* Improve handling of no data in Disk and Network IO MetersChristian Göttsche2020-10-261-3/+13
|
* Increase print buffer in NetworkIOMeter_displayChristian Göttsche2020-10-201-1/+1
| | | | | In case the packet values wrap-around or have other weird values, the current buffer might be to small
* Make all required includes explicitBenny Baumann2020-10-181-0/+7
| | | | Information as seen by IWYU 0.12 + clang 9 on Linux
* Add NetworkIOMeterChristian Göttsche2020-10-161-0/+89

© 2014-2024 Faster IT GmbH | imprint | privacy policy