summaryrefslogtreecommitdiffstats
path: root/NetworkIOMeter.c
Commit message (Collapse)AuthorAgeFilesLines
* 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