Changelog practices: Keep a Changelog. Versioning practices: Semantic Versioning.
- Rename wult/ndl report '--relocatable' option to to '--copy-raw'.
- Fix regression that broke filtering by C-state residency (e.g., '--include="CC6% > 0"').
- Add '--idle-governor' option.
- Revert the change in '1.12.28' that keeps POLL enabled. The same can be achieved using '--cstates-always-enable'.
- Rename '--governor' option to '--cpufreq-governor'.
- Fix ndl crash because of regression in v1.12.28 (silly mistake).
- Fix order of diff report created by exercise-sut.
- exercise-sut: do not disable POLL.
- Fix running commands on remote host, e.g. 'ndl scan -H '.
- Fix 'wult deploy' failing to deploy 'wult-freq-helper'.
- Add 'wult deploy --skip-bpf' option for skipping eBPF helpers deployment.
- Rename the "Wake Period" metric to "Launch Distance". This change includes renaming the '--wakeperiod (-w)' and '--wakeperiod-step' options to '--ldist (-l)' and '--ldist-step' accordingly. Note that the tool maintains compatability with results collected on older versions of the tool, however reports generated will represent data collected as "Wake Period" data as "Launch Distance" data.
- Fix 'ndl' tool failure on system where 'sch_etf' and 'sch_mqprio' kernel modules are not loaded.
- Fix 'wult' tool missing the CC7 C-state counter on some client CPUs.
- Add 'exercise-sut start --skip-io-dies' option support.
- Add C10 support for exercise-sut '--use-cstate-filters' option.
- Fix 'exercise-sut start --use-cstate-filters' failures on platforms that do not have C1 counter and use 'DerivedCC1%' instead.
- Fix 'pbe report' crash when one of the raw results has no statistics whatsoever.
- Fix 'pbe deploy' driver compilation issue with kernels older than v6.6.
- Add the '--stats' option to the 'pbe' tool so that users can customise which statistics are collected during 'pbe' data collection.
- Add the '--stats-intervals' option to the 'pbe' tool so that users can customise the statistics intervals which are used during 'pbe' data collection.
- Add the '--list-stats' option to the 'pbe' tool so that users can see which statistics are available and can be specified with the '--stats' options.
- Include report generaltion logs to pbe reports.
- New 'pbe start --lead-cpu' option.
- New wult/ndl deploy '--drivers-make-opts' option. Can be used to customize the drivers build options, like adding 'CC=clang'.
- New 'pbe' tool. Can be used to find the power break-even points of C-states on a system.
- Split manual pages and simplify the '--help' output.
- Require stats-collect v1.0.24 - there was a critival fix in turbostat statistics visualization code.
- No functional changes since 1.12.17, just updates to changed pepc project APIs.
- Fix 'wult deploy' crash, regression since v1.12.16.
- Rename 'freq-helper' to 'wult-freq-helper'.
- Fix 'freq-noise' helper deployment failure on some systems.
- Fix 'exercise-sut start --list-monikers' crashing.
- Add a link to report generation logs in HTML reports.
- Add new wult/ndl "start" option support: '--freq-noise'.
- Add '--use-cstate-filters' option to exercise-sut tool to filter datapoints with wult and ndl tools.
- Fix MC6 counter collection in the 'hrt' and 'tdt' drivers. It was collecting CC6 instead.
- The 'exercise-sut' tool now supports the '--stats' option for the standard workloads: wult, stats-collect, ndl.
- Minor adjustment to match new 'pepc' API. No functional changes.
- Fix 'wult scan' and 'ndl scan' - they sometimes did not show all the compatible PCIe devices.
- Add partial workaround for kernel tracing sub-system regression by using per-cpu 'trace_pipe' sysfs file instead of using the global one.
- Detect buggy kernels and print a helpful error messages suggesting to update the kernel to the latest stable version.
- Fix 'wult/ndl' not generating statistics tabs in HTML reports for some results with format version '1.2'.
- Fix failure when NIC is specified by MAC address.
- Fix exercise-sut skipping valid configurations.
- Fix ndl driver build for older kernels (~linux 5.15).
- ndl start: support 'local' and 'remote' values for the '--cpunum' option.
- ndl start: add '--trash-cpu-cache' option, helps ensuring NIC reads from memory, and not from a CPU cache.
- Improve exercise-sut package C-state handling.
- Accept '--state-reset' option alone for 'exercise-sut start' command.
- Fix 'exercise-sut' crashing with pepc version '1.4.32'.
- Fix 'wult/ndl report' crashing for results with format version '1.2'.
- Increment the format version of 'wult/ndl' results to '1.3'.
- ndl: disable DMA coalescing to avoid potential latency spikes
- Change the way that 'wult' and 'ndl' HTML reports are generated so that tabs will be included if any result contains data for them rather than only being included if all results have relevant data.
- Add 'stats-collect' logs to HTML reports.
- Add the version of 'wult/ndl' to HTML reports to indicate which version was used to generate the report.
- Disable self-tests in debian packaging for now.
- Workaround for a failure enabling 'bpf_trace_printk'.
- Improve 'wult' and 'exercise-sut' console output.
- Add report generation log to 'wult' and 'ndl' report directories.
- Get rid of TSC calibration logic in the 'tdt_bpf' method. Instead, use kprobes to retreive absolute TSC value from the kernel.
- Move 'stats-collect' to a separate git repository.
- Fix SVOS distro compilation issues.
- Fix turbostat tabs failing to generate because of two or more results do not have enough turbostat metrics in common.
- Add 'stats-collect report --reportids' option.
- Add 'pepc power info' output to 'pepc SysInfo' tabs in HTML reports.
- Changed 'wult' and 'stats-collect' to skip generating SysInfo diffs if the files are identical to speed up report generation.
- Changed the default value of 'stats-collect start --cpunum' to 'None'.
- Fix a regression introduced in v1.11.19, which caused 'stats-collect start --report' to crash.
- Fix 'stats-collect start --stats=none' crashing. Regression introduced in v1.11.11.
- Fix 'wult' report generation crashing if no statistics were collected. Regression introduced in v1.11.19.
- Fix stats-collect diffs only showing one result in 'Captured Output' tabs and intro tables when two results have the same report ID.
- Fix 'Measured CPU' tab generation crashing when the measured CPU of a result is not 0.
- Fix '--stats=ipmi' not resolving to 'ipmi-inband' and 'ipmi-oob' properly.
- Fix '--stats=ipmi-inband' or '--stats=ipmi-oob' sometimes resulting in the other 'ipmi' collection method being used.
- Add alerts to 'Captured Output' tabs and modify output files to make it clear to users when files have been trimmed.
- Add 'duration' to 'stats-collect' HTML report intro tables.
- Remove 'wult start --early-intr' option.
- Minor design improvements to HTML report tabs with alerts and file-previews.
- exercise-sut: change default behavior: when '--cstates' is not specify, assume "no C-states testing" instead of previous "test all C-state".
- Install manual pages when using 'pip install'.
- Improve 'hrt_bpf' and 'hrt_tdt' methods by using absolute hrtimers available in Linux kernel starting with version 6.4.
- Fix a bug where 'Captured Output' tabs do not load in 'stats-collect' reports. This bug was introduced in v1.11.15.
- Fix a bug where 'sysinfo' tabs in HTML reports do not generate diffs. This bug was introduced in v1.11.9.
- Fix 'sysinfo' tabs not loading in HTML reports when viewed locally.
- Get rid of incorrect 'WakeLatency' datapoints when measuring the 'POLL' state (hrt_bpf and tdt_bpf methods only).
- Statistics collectores deployment fixes.
- Fix incorrect 'wult calc' warning about non-numeric metrics.
- Fix regression in 'stc-agent' introduced in version 1.11.12.
- Fix 'stats-collect report' generating broken diffs when given results with duplicate report IDs.
- Teach the 'exercise-sut' tool display 'wult' progress bar.
- Allow empty moniker when generating reports with exercise-sut. Depends on pepc version 1.4.9.
- Fix Debian build dependency for pytests to run in build environment.
- Fix kernel error messages like "already have device 'wult_tdt' registered" by prohibiting wult out of tree drivers to be automatically loaded.
- Fix HTML reports not being able to be viewed locally since v1.11.2.
- Fix 'stats-collect' deployment.
- Fix several metrics missing 'min/max' summary functions in 'wult' HTML reports.
- Fix AC Power plot generation failing because of 'inf' values in raw AC Power statistic files.
- Fix 'stats-collect report' crashing on on raw acpower statistic files with bad headers.
- Add 'tool information' and 'collection date' to 'stats-collect' report intro tables.
- Fix 'stats-collect report' crashing on 'inf' acpower values.
- Change 'stats-collect', 'wult' and 'ndl' to collect 'turbostat' and 'sysinfo' statistics by default.
- Add command used in 'stats-collect start' to 'stats-collect' reports.
- Fix a regression in v1.11.2 where 'sysinfo' tabs would fail to generate diffs.
- Add '--cpunum' option for ndl.
- Fix pepc dependency, allow for pepc versions greater than 1.3.x.
- Fix 'hrt' method failing on AMD systems.
- Add module C-state support to turbostat collection and reporting.
- Add fullscreen view to diagrams in wult HTML reports.
- Add a button to hide report header in wult HTML reports.
- Improve 'tdt' method to be more accurate.
- Improve 'tdt' method to also work for 'POLL' state.
- Add basic module C-states support.
- Fix 'wult report' crashing when generating diffs where the first result contains different metrics to the rest.
- Fix 'wult report' crashing when custom axes are provided which result in empty tabs.
- Add 'pepc topology info' output to 'sysinfo' statistics collection.
- Add 'pepc topology info' output to 'sysinfo pepc' tab in wult reports.
- Moved the 'Busy%' turbostat tab from 'Misc' to 'C-states,Hardware' in wult reports.
- Renamed the 'stats-collect-components' JavaScript package to '@intc/stats-collect'.
- Fix 'ndl deploy --tmpdir-path' option.
- Fix 'ndl start' command.
- Do not crash if the 'systemctl' tool is not available.
- Fix reports generated with 'stats-collect start --report' having no title.
- Fix 'stats-collect' not maintaining reportid between 'start' and 'report' commands.
- Reports generated with 'stats-collect start --report' will now appear in an 'html-report' sub-directory if no output directory is specified.
- Fix 'wult deploy' crashing (regression in release 1.10.51).
- Fix report generation crashing when a summary table contains more than one 'N/A' value.
- Fix 'ndl' manual pages: we mistakingly documented 'wult' tool in 'ndl' man page.
- Update 'npm' packages used in wult HTML reports.
- Generate tabs in wult HTML reports even when one or more results will be excluded.
- Fix turbostat totals tabs being unopenable in wult HTML reports.
- Add statistics collection support to the 'ndl' tool ('--stats' and '--stats-intervals' options).
- Add 'stats-collect' tool. It is not very useful yet, but it will get more functionality later.
- Add warnings to wult HTML reports when a diagram has been skipped because all results contain a single value for a given metric.
- Fix 'wult report' crashing when used on a dataset with very few datapoints.
- Fix the 'wult start --no-unload' debugging option.
- Improve 'IntrLatency' accuracy for 'hrt' and 'tdt' methods'.
- Fix strange units on the axis of diagrams with 'CPUFreq' data in wult reports.
- Fix regression which caused 'wult deploy' to error when '-H' option was not used.
- Adjust to 'pepc' project changes again (no functional changes).
- Adjust to 'pepc' project changes (no functional changes).
- Fix some statistics being collected for longer than others when 'SysInfo' statistics are also collected.
- Fix 'CC0%' calculations in the 'tdt_bpf' method.
- Add new 'tdt_bpf' method.
- Fix SVOS debianization (missed dependency added).
- Stop NTP service when measuring.
- Rename the 'hrt-bpf' method to 'hrt_bpf'.
- Improve precision of the 'hrt' method.
- Add CPU frequency metric, which now appears as "CPUFreq" in hover text of scatter plots.
- Fix 'ndl deploy' command failure.
- Fix 'wult report' failing if a metric in a summary table contains all zeros.
- Add "POLL requested %" turbostat tabs to reports.
- The eBPF-based 'hrtimer' method was renamed to 'hrt-bpf'.
- Fixed and renamed '--title-descr' option to '--report-descr'.
- Fix 'wult start' failing without specifying '--stats none'. This is a regression introduced in 1.10.35.
- Fix '--stats all' so that it also collects the "sysinfo" data. This is a regression introduced in version 1.10.34.
- Fix '--stats acpower' - it failed, due to a regression in version 1.10.34.
- Debianization: include drivers' sources into the package.
- Add support for sharing URLs to specific tabs in wult reports.
- Change the wult report layout from nested tabs to use tabs and a tree for navigating sub-tabs.
- Fix the 'ipmi' statistics collection.
- Fix 'hrtimer' method's pre-compiled eBPF program.
- Fix 'hrtimer' method's outliers problem by filtering out datapoints that included unrelated SW interrupts and NMIs.
- Do not collect 'journalctl -b' output as part of the 'sysinfo' statistics.
- Remove '--headless' option from 'view_multiple_reports.py'.
- Remove 'view_report.py' from report directories.
- Increase max. launch distance to 50 milliseconds (tdt, hrt, i210).
- Rename 'view_multiple_reports.py' to 'serve_directory.py'.
- Change 'serve_directory.py' so that it does not try to open a web-browser by default.
- Do not check for 'stc-agent' and do not complain about its possible absence if statistics do not need to be collected.
- Do not check for kernel sources and do not complain about them missing when deploying with the '--skip-drivers' option.
- Fix missing package C-state tabs in reports
- Add the ability to upload a wult report directory if viewing the report locally.
- Add 'RAMWatt' tab to wult reports in the turbostat totals power/temperature tab.
- Improve the warning about viewing wult reports locally.
- Minor fix for the 'i210' method: restore network interface operational state correctly.
- Add '--dir' option to 'view_multiple_reports.py'.
- Wult report viewing scripts now tries multiple ports before failing.
- Wult mistakenly required the 'ip' tool to be installed, this is fixed now.
- New 'wult scan --all' option to print unsupported devices.
- 'wult deploy --skip-drivers' does not require kernel sources any longer.
- Merge and simplify the 'SilentTime' and 'LDist' tabs in wult reports.
- 'wult scan' does not print unsupported devices by default.
- Do not error out when CC0 cycles is greater than total cycles. Just warn instead. We observe this with 'POLL' C-state on some platforms.
- Fix for the problem of extremely slow data rate when measuring the 'POLL' state using the 'hrt' method.
- Add '--host', '--port' and '--headless' options to report viewing scripts.
- Remove the '--size=medium' report option.
- Reworked the deployment code to better support RPM packaging.
- Fix regression introduced in 1.10.23: we failed to find helpers when they were not in '$PATH'.
- Change 'wult' to not expect driver/helper sources be available - they are not available when installed from an OS package, such as an RPM package.
- Change the way 'wult' tool looks for installed drivers and helpers in order to support RPM packaging.
- Fix C-state tabs being excluded from wult HTML reports generated with '--size=large'.
- Add 'wult deploy --skip-drivers' option, useful for debug and development.
- Fix the problem of progress line for 'tdt': it always printed 0 max. latency.
- Fix wult deploy regression where 'stc-agent' failed to deploy.
- Always deploy eBPF helpers, making the new "hrtimer" method available by default.
- Fix compatibility of wult report viewing scripts for Python 3.5+.
- Fix wult report failing because it can't find scripts for viewing reports.
- wult now restores i210 network interface state after the measurement.
- Fix nic method-only regression introduced in 1.10.0: 'WarmupDelay' and 'LatchDelay' metrics were not saved in the CSV file.
- Add local viewing scripts to each wult HTML report.
- Fix occasional crash: KeyError: 'IntrLatencyRaw'.
- Added new 'hrtimer' method, which is based on eBPF and does not require kernel drivers. This method is considered to be experimental for now, and eBPF helpers are not deployed by default. Use 'wult deploy --deploy-bpf' to deploy them.
- Remove the "hrtimer" alias for the "hrt" method.
- Remove the "tsc-deadline-timer" alias for the "tdt" method.
- Fix failure when setting large launch distance (>4ms).
- Max. launch distance changed from 10ms to 20ms.
- Move scripts for local reports viewing to 'misc/servedir'.
- Add turbostat data to the "Info" tab.
- Add misc. scripts for viewing wult reports locally.
- Fix crash related to 'IntrLatency' (regression in v1.10.11).
- Change 'wult start --list-stats' to not require device id.
- Fix the 'wult start --early-intr' option.
- Fix 'wult report' generating broken HTML reports for reports with no common IPMI metrics.
- Fix HTML report screen tearing which appeared after switching tabs many times.
- Add 'dmesg', 'lspci', 'cpuidle' and 'cpufreq' to the "SysInfo" tabs in HTML reports.
- Add buttons to the "SysInfo" tab to open raw files in a separate tab.
- Remove the 'wult start --intr-focus' option.
- Changed 'wult report' so that reports will be generated with logs by default.
- Fix crashes with kernels version 5.18+ on C-states entered with interrupts enabled.
- Remove bogus 'IntrLatency' data when using the 'tdt' method.
- wult report: add "SysInfo" tab with various system info about SUTs.
- Optimization: spend time calculating TSC rate only in case of the TDT method. Skip this step for the HRT/NIC methods.
- Minor improvements required for RPM packaging
- Fix regression in v1.10.7: turbostat statistics collector was crashing.
- Fix regression in v1.10.1: generated scatter plots were too large.
- Add 'UncMHz' (uncore frequency) turbostat metric support.
- Improve Turbostat metrics description by specifying the aggregation method (whether it is max or average of values for all CPUs).
- wult: add package C-states to turbostat statistics.
- wult: add current and voltage to IPMI statistics.
- Add RPM packaging support.
- wult: fix crashes on systems that do not have 'python' in PATH.
- wult: fix crash with when unknown method is given (regression in 1.10.0).
- wult/ndl: rename the '--list-columns' option to '--list-metrics'.
- wult/ndl: rename the '--rsel' option '--include'.
- wult/ndl: rename the '--rfil' option '--exclude'.
- wult/ndl: rename the '--csel' option '--include-metrics'.
- wult/ndl: rename the '--cfil' option '--exclude-metrics'.
- wult: do not check for 'bpftool' and 'clang' dependency unnecessarily.
- ndl: fail gracefully on 'ndl start tdt'.
- wult: fix missing C-states residencies (regression in 1.10.0).
- wult report: fix '--size large'.
- wult deploy: fix deploying from sources.
- wult start --stats: fix statistics collection when run from sources.
- wult stats: fix standalone stats-collect dependencies.
- wult report: removed symbolic links to raw result files.
- wult report: changed '--relocatable' to be a binary option.
- wult report: added turbostat statistics tab.
- wult: removed 'start --dirty-cpu-cache' option/capability.
- wult: removed 'wult load' debug command.
- wult/ndl deploy: fix '--kernel-src' option which did not work.
- wult/ndl deploy: add '--local-build' option.
- Fix crash when using 'wult calc --rsel'.
- wult report: fix crash introduced in version 1.9.18.
- wult report: added AC power and IPMI statistics visualization.
- wult: bugfix release: suggest users how to view local HTML reports.
- wult: bugfix release: improve TDT driver skipping datapoints error diagnostic.
- wult: bugfix release: fix HTML report summary table hover text.
- wult: removed 'start --offline' option.
- wult: browsers now load wult HTML reports faster.
- wult: bugfix release: fix raw filters on system with older pandas/numexpr.
- wult: bugfix release: fix crash when running 'wult report --list-columns'.
- wult: bugfix release: fix 'ndl start' not finding the driver.
- wult: bugfix release: fix 'wult scan' not resolving network name.
- wult: bugfix release: fix occasional missing 'WakeLatencyRaw' crash.
- wult: bugfix release: fixed data rate, requires pepc 1.1.2.
- wult: add 'start --dirty-cpu-cache' option/capability.
- wult/ndl: use modules from the 'pepc' project (new dependency).
- wult: calculate TSC rate and improve measurements accuracy.
- wult: this version requres pepc v1.1.1.
- wult: add 'start --early-intr' option/capability.
- wult/ndl: add 'report --relocatable=noraw' support.
- wult: improve driver error diagnostics.
- wult: stop supporing kernels older than v5.6.
- wult: add 'start --intr-focus' option/capability.
- wult: add 'start --keep-raw-data' option.
- wult: add 'start --offline' option/capability.
- wult: add 'filter --human-readable' option.
- wult/ndl: removed '--post-trigger' option/capability.
- wult: many fixes for small, but annoying problems
- wult/ndl: speed up measuring remote SUTs.
- wult: add new driver: hrtimer.
- wult: add POLL idle state support.
- wult/ndl: add '--keep-filtered' option for start command.
- wult/ndl: remove broken "advanced" options.
- wult: fix 'stats-collect' deployment.
- wult: add statistics collection capability.
- wult: include less diagrams into report by default.
- wult: change default launch distance range from 0-8ms to 0-4ms.
- wult: fix false warning about C-state prewake setting.
- wult: add row filter and selector options '--rfilt' and '--rsel'.
- wult: fix regression and do not fail with pre-v5.6 kernels.
- wult: fix warnings for old kernels (pre-v5.3).
- wult: improve Icelake-D support.
- wult: fix a failure acception an i210 NIC by its PCI ID.
- wult: fix interrupt latency figures.
- wult: add new 'CStates%' metric for combined C-state residency.
- wult: print helpful message about settings possibly affecting results.
- wult/ndl: deprecate '--continue' and add '--start-over' instead.
- man: generate man pages using 'argparse-manpage' tool.
- wult: add support to configure dynamic load line feature.
- wult: add the 'IntrLatency' metric (interrupt latency).
- wult: add the 'NMIWake' and 'NMIIntr' metrics (NMI counts).
- wult: add the 'IntrDelay' metric (interrupt delay).
- wult: fix starting by NIC PCI ID
- wult/ndl: print helpful message if ASPM is enabled.
- wult/ndl: fix permission issues for copied raw results.
- wult: fix '--ldist' option, it did not work in local mode.
- wult: change default launch distance range from 0-4ms to 0-8ms.
- wult/ndl: optimize remote MSR access.
- wult/ndl: suggest OS package names for tools that should be installed.
- wult/ndl: improve error message when opening wult result with ndl.
- wult/ndl: check if we already have enough datapoints earlier.
- Same as 1.8.12, we messed up verion numbers a bit.
- ndl: add --xases, --yaxes, --hist and --chist options to 'ndl report' command.
- wult: include 'ReqCState' metric to the HTML report.
- ndl: add 'ndl scan' command.
- wult: fix bug in diff report with old results.
- wult/ndl: add the '--time-limit' option.
- wult/ndl: support specifiers in '--ldist'.
- wult: support specifiers in '--post-trigger-range'.
- wult: support 0 in '--ldist'.
- ndl: removed the '--cstate-stats' option.
- ndl: fix parsing the 'tc' tool version number.
- wult/ndl: rename the 'stats' command into 'calc'.
- wult: add SilentTime vs LDist diagram.
- wult: do not fail when events are lost.
- ndl: replace '--post-trigger-threshold' with '--post-trigger-range'.
- wult/ndl: distinguish between CC1% (HW) and DerivedCC1% (SW).
- wult/ndl: add '--reportids' command-line option.
- wult: add '--hist none' and '--chist none' support.
- wult: improve 'wult scan' to print aliases.
- wult: renamed 'tsc-deadline-timer' method to shorted 'tdt'.
- wult: first release.