20th February 2020 Version 2020.2 Intel Corporation www.intel.com Legal Information ### Contents | Legal Information | 3 | |---------------------------------------------------------------------|--------| | Version History | | | Customer Support | | | Chapter 1: Introduction | | | Chapter 2: New in This Release | | | Chapter 3: System Requirements Supported Architectures Dependencies | 8<br>8 | | Chapter 4: Where to Find the Release | | | Chapter 5: Installation Notes | | | Extracting the Intel SoC Watch package | 10 | | Build the Kernel Modules | 10 | | Building Android* Kernel Modules | | | Install Intel SoC Watch | | | Intel SoC Watch for Android* Installation | | | Key Files | 11 | | Remove the Intel SoC Watch Drivers | 12 | | Chapter 6: Fixed Issues | | | Chapter 7: Known Issues | | | | | **Chapter 8: Related Documentation** ### Legal Information No license (express or implied, by estoppel or otherwise) to any intellectual property rights is granted by this document. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. No product or component can be absolutely secure. Check with your system manufacturer or retailer or learn more at [intel.com]. Intel disclaims all express and implied warranties, including without limitation, the implied warranties of merchantability, fitness for a particular purpose, and non-infringement, as well as any warranty arising from course of performance, course of dealing, or usage in trade. This document contains information on products, services and/or processes in development. All information provided here is subject to change without notice. Contact your Intel representative to obtain the latest forecast, schedule, specifications and roadmaps. The products and services described may contain defects or errors which may cause deviations from published specifications. Current characterized errata are available on request. Intel, the Intel logo, Intel Atom, Intel Core, Intel Xeon Phi, VTune and Xeon are trademarks of Intel Corporation in the U.S. and/or other countries. \*Other names and brands may be claimed as the property of others. Intel, the Intel logo, Intel Atom, Intel Core, Intel Xeon Phi, VTune and Xeon are trademarks of Intel Corporation in the U.S. and/or other countries. Microsoft, Windows, and the Windows logo are trademarks, or registered trademarks of Microsoft Corporation in the United States and/or other countries. Java is a registered trademark of Oracle and/or its affiliates. OpenCL and the OpenCL logo are trademarks of Apple Inc. used by permission by Khronos. #### © Intel Corporation This software and the related documents are Intel copyrighted materials, and your use of them is governed by the express license under which they were provided to you (**License**). Unless the License provides otherwise, you may not use, modify, copy, publish, distribute, disclose or transmit this software or the related documents without Intel's prior written permission. This software and the related documents are provided as is, with no express or implied warranties, other than those that are expressly stated in the License. # Version History These are the main releases of Intel® SoC Watch: | Date | Revision | Description | | |--------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | June, 2019 | 2.11 | Improves handling of unrecognized CPUs, reporting S-state when hibernation occurs, and other bug fixes. | | | September,<br>2019 | 2019.12 | Added support for Intel platform code named Ice Lake. Modified hw-cpu-pstate reporting. | | | October,<br>2019 | 2019.13 | Fixed issue in hw-cpu-pstate for Intel platform code named Ice Lake. | | | November,<br>2019 | 2020.1 | Added support for Intel platform code named Comet Lake. | | | February,<br>2020 | 2020.2 | Added collection of tool usage analytics. Added new features pch-slps0, pch-slps0-dbg. Improved error messages and help output. Enhanced driver security. | | ## Customer Support For technical support, including answers to questions not addressed in this product, see the Intel System Studio forum (https://software.intel.com/en-us/forums/intel-system-studio). ### Introduction Intel® SoC Watch is a data collector for power-related data that can help identify issues on a platform that prevent entry to power-saving states. Captured metrics include: - System sleep states - CPU and GPU sleep states - Processor frequencies - Temperature data - Device sleep states You can correlate the collected data and visualize over time using Intel®VTune Profiler. This document provides system requirements, installation instructions, issues and limitations, and legal information. To learn more about this product, see: - New features listed in the New in This Release section below, or in the help. - Reference documentation listed in the Related Documentation section below - Installation instructions can be found in the Installation Notes section below. - For a detailed quick start guide to running the tool, see the *Intel SoC Watch User's Guide* in your installed documentation. #### **Optimization Notice** Intel's compilers may or may not optimize to the same degree for non-Intel microprocessors for optimizations that are not unique to Intel microprocessors. These optimizations include SSE2, SSE3, and SSSE3 instruction sets and other optimizations. Intel does not guarantee the availability, functionality, or effectiveness of any optimization on microprocessors not manufactured by Intel. Microprocessor-dependent optimizations in this product are intended for use with Intel microprocessors. Certain optimizations not specific to Intel microarchitecture are reserved for Intel microprocessors. Please refer to the applicable product User and Reference Guides for more information regarding the specific instruction sets covered by this notice. Notice revision #20110804 # New in This Release 2 The 2020.2 release (driver v2.11.1) contains these changes: - Added collection of SoC Watch usage analytics. After installing Intel SoC Watch, upon first use, a dialog box prompts you to allow the collection of non-personal information about the system and SoC Watch command line used in this and future collections (i.e., to opt-in). If allowed, this data is sent to Intel if the system is connected to the internet at the end of the SoC Watch collection. If the data cannot be sent for any reason, the data is deleted. The data will not accumulate on the system. Use these command line options to respond to the dialog box: - To opt-in or change a former decision to opt-in: --update-usage-consent yes - To opt-out or change a former decision to opt-out: --update-usage-consent no - To skip prompt and disable usage collection (regardless of a prior opt-in): --skip-usage-collection #### New features: - -f pch-slps0: Reports residency in lowest power sleep state, SLP\_S0 (s0i3/Modern Standby). - -f pch-slps0-dbg: Reports blocking reasons (IP state conditions) that may be preventing entry to lowest power sleep state, SLP\_S0 (s0i3/Modern Standby). #### Improved error messages and help: - Improved error message when -f hw-cpu-pstate cannot be collected. Previously, just reported that the required frequency values were invalid. Since this may occur because a driver is not loaded, the error message reported to the user now includes: "CANNOT collect hw-cpu-pstate metric because invalid low, high and bus frequency values (x,x,x) were read from system. Please make sure the SoC Watch driver or MSR driver is installed correctly. See the SoC Watch User Guide regarding installing the necessary driver." - Clarified -f pkg-pwr report's Note regarding multi-DIE topology: "Die-level power is included in package power on platforms with a multi-die CPU topology." There is no breakdown for energy at the Die-level. - Improved help output by aligning terminology and form used across the features. - **Enhanced security of SoC Watch drivers**. The drivers now limit access to only those registers or memory intended by the tool development team for collecting platform power and performance information. ### System Requirements ### **Supported Architectures** Intel SoC Watch supports these Intel microarchitecture or platform code names: - Anniedale - · Cherryview (Cherry Trail) - Apollo Lake - · Gemini Lake - Broadwell - Skylake - Kaby Lake - Coffee Lake - Whiskey Lake - Amber Lake - Comet Lake - Ice Lake ### **Dependencies** Intel SoC Watch depends on specific OS configurations and hardware capabilities. If these are not present on the target system, Intel SoC Watch may fail to work properly. - Linux Kernel version needs to be 2.6.32 or later. - GNU C Library version must be GLIBC\_2.17 or later. - KERNEL\_CONFIG\_TRACEPOINTS must be enabled. - Kernel should be compiled with "CONFIG MODULES" enabled. - P States - Kernel config CONFIG\_X86\_SFI\_CPUFREQ or CONFIG\_X86\_ACPI\_CPUFREQ must be enabled (i.e. set to 'y' or 'm'). - One of these pstate drivers must be utilized: sfi-cpufreq, acpi-cpufreq, or intel\_pstate. To determine which driver is loaded, check the sysfs /sys/devices/system/cpu/cpu0/cpufreq/scaling\_driver file. - If one of these pstate drivers is not loaded, the kernel needs to be reconfigured and recompiled. - C States - Kernel config CONFIG TIMER STATS must be enabled. - Kernel config CONFIG\_INTEL\_IDLE must be enabled and the intel\_idle kernel module has to support the core of the target platform. - To determine if the intel\_idle kernel module is loaded, check the sysfs /sys/devices/system/cpu/ cpuidle/current\_driver file. It must equal intel\_idle. If it equals acpi\_idle, only C0 and C1 will be used by the core. # Where to Find the Release Go to the Intel® System Studio website (https://software.intel.com/en-us/intel-system-studio) to get either an Evaluation (30-day trial release) license or a commercial license, and download the package from the Intel Registration Center (http://registrationcenter.intel.com/). ### **Installation Notes** Intel SoC Watch for Android\* OS is available as part of Intel System Studio. Use the steps below to install Intel SoC Watch on a target Android system. ### **Extracting the Intel SoC Watch package** Extract the Intel SoC Watch package to the system containing the kernel of the target device. This may be: - The host system, if the target device is running an Android kernel. - The target system, if the device is running a Linux kernel. By default, you can find the Intel SoC Watch package here: - On Linux systems: /opt/intel/system\_studio\_<version>/energy\_profiler\_and\_socwatch/ socwatch for target - On Windows\* systems: C:\Program Files (x86)\IntelSWTools\energy\_profiler\_and\_socwatch \socwatch for target Use the find . -name Module.symvers command on the device containing the target system's kernel to determine the kernel build directory. #### **Build the Kernel Modules** If the Intel SoC Watch kernel modules (i.e. device drivers) are not present in the OS image of the target system, you will need to build and sign them. Building and signing device drivers requires access to the kernel build directory for the OS image running on your target device. A kernel build directory is generated while building the OS image of the target system. When building the kernel modules, do not open (or unzip) the Intel SoC Watch package (i.e. tar.gz file) on a Windows\* based system and copy a Linux system. Unzip the package on the Linux build system using the unzip command to make sure the build scripts and make files are unmodified. If a kernel is built with the CONFIG\_MODULE\_SIG kernel config enabled, any device driver loaded into that kernel must be signed with the same keys used to build the kernel. In general, drivers built for Linux targets do not need to be signed and the following description assumes the drivers do not need to be signed. But, if an end user tries to load an unsigned driver into a kernel that requires signed drivers, the insmod command will fail with the error Required key not available. If a signed driver is loaded into a kernel that does not require signed drivers, the load will succeed. The build\_drivers script is provided to simplify building all of the drivers. The script supports multiple switches including; - -n // do not build the socperf driver; used for Intel® Core™ processor based systems - -1 // build the kernel for a Linux target - -s <full path to sign-file> // signs the drivers; the path is normally .../kernel/\*/scripts/sign-file #### **Building Android\* Kernel Modules** - 1. Copy the Intel SoC Watch package to the host system used to build the target system's Android kernel. - 2. Extract the contents. The <extract dir>/socwatch android v<version> directory will be created. - **3.** Use one of the following commands to build the appropriate files: - a. If the target system is based on an Intel® Core™ processor, use the following command to build the socwatch2\_10.ko file. sh ./build drivers.sh -k <kernel-build-dir> -n -s <full path to sign-file> Installation Notes 5 **b.** If the target system is based on an Intel Atom® processor, use the following command to build the socwatch2 10.ko and socperf3.ko files. sh ./build drivers.sh -k <kernel-build-dir> -s <full path to sign-file> #### **NOTE** If the build fails because the <code>asm/intel\_mid\_pcihelpers.h</code> file is missing, remove the following line from the <code>soc perf driver/src/Makefile</code> EXTRA CFLAGS += -DCPI HELPERS API #### Install Intel SoC Watch **Host**: laptop, desktop, or server used to communicate with target device. **Target**: device to be analyzed with Intel SoC Watch. #### Intel SoC Watch for Android\* Installation Make sure the host is connected to the target via adb before running the install script. 1. After extracting the Intel SoC Watch package on your host system, run the socwatch\_android\_install.sh script on a Linux host or from a Cygwin window on a Windows host. Run socwatch android install.bat from a Windows host. socwatch android install.sh or socwatch android install.bat - 2. The script installs the Intel SoC Watch executables to the <code>/data/socwatch</code> directory on the target by default. Use the <code>-d</code> option to select a different install directory and the <code>-s</code> option to define a specific Android\* device if multiple devices are connected to the host via <code>adb</code>. - **3.** Using the adb command, start a shell with root privileges. adb root adb shell - **4.** Navigate to the directory containing the drivers on the target system. If the drivers are preinstalled, they are located in the /lib/modules or /system/lib/modules directory. If the drivers are built on the host system, they should be copied to a directory on the target system. - **5.** Load the drivers. Note that the <code>socperf</code> driver must be loaded before the <code>socwatch</code> driver on a system with an Intel Atom® processor. insmod socperf3.ko insmod socwatch2 10.ko **6.** Confirm the drivers are loaded. > 1smod #### NOTE - Make sure to use the latest version of the socperf driver. - Previous versions of the <code>socwatch2\_x.ko</code> driver (e.g. <code>socwatch2\_0.ko</code>) will work, but new collector support and/or bug fixes may be missing in the older drivers. If an older <code>socwatch2\_x.ko</code> driver is used, some metrics may not be collected. ### **Key Files** The following table describes the key files. | File | Description | |--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | build_drivers.sh | The build script used to build all of the device drivers utilized by Intel SoC Watch. | | socperf3.ko | The socperf kernel module used to measure bandwidth and DRAM self refresh on systems with an Intel Atom® processor. | | socwatch2_x.ko | The Intel SoC Watch kernel module used to collect both hardware and kernel data at runtime. | | setup_socwatch_env.sh | The script used to setup the Intel SoC Watch runtime environment. | | socwatch | The Intel SoC Watch executable built as a native application. Use this file to collect data and generate additional results from a raw SW2 file. | | SOCWatchConfig.txt | The Intel SoC Watch configuration file. The configuration file is read by Intel SoC Watch immediately before each collection. It contains hardware addresses utilized by the device driver during the collection. | | EULA.txt | End User License Agreement file. | | third-party-programs.txt | List of third party programs included in the package. | | plugins/libSWCore.so | A library providing Intel SoC Watch functionality. | ### **Remove the Intel SoC Watch Drivers** After using Intel SoC Watch, remove the drivers using the rmmod command (e.g. rmmod socwatch2\_10). The socwatch driver must be unloaded before the socperf driver is unloaded. ### Fixed Issues Release v2020.2 has a fix for these issues. • Removed extra tables reported for features igfx-throt-rsn, ia-throt-rsn, and ring-throt-rsn, and added Total Samples Received table, to align with tables reported for similar features. ### Known Issues #### **Bandwidth (on Intel Core Platforms)** - The presence of EDRAM on a system may not be detected by Intel SoC Watch. This is known to occur when the accelerator card VCA2, which contains EDRAM, is present. - Total DDR bandwidth does not include EDRAM. On systems using EDRAM, the ddr-bw feature report may have a discrepancy between the total data reads and writes and the total component requests. The Data Reads+Data Writes will be significantly higher than the total IA+GT+IO requests, because the EDRAM requests are not included. #### Bandwidth and DRAM Self Refresh (on Intel Atom® Platforms) - On Intel platforms code named Apollo Lake and Gemini Lake, memory bandwidth and memory self-refresh metrics are not available. These features are not supported: ddr-bw, cpu-ddr-bw, cpu-ddr-mod0-bw, cpu-ddr-mod1-bw, disp-ddr-bw, isp-ddr-bw, gfx-ddr-bw, io-bw, all-approx-bw, dram-srr. - Intel SoC Watch v2.10.0 and later versions require loading the socperf v3.0 driver to measure bandwidths or DRAM self-refresh on Intel platforms code named Cherry View, Broxton, and Apollo Lake. This version can automatically detect if the system is configured to support use of the hardware signals required to collect these metrics (ddr-bw, gfx-ddr-bw, cpu-ddr-mod0-bw, cpu-ddr-mod1-bw, disp-ddr-bw, isp-ddr-bw, all-approx-bw, io-bw and dram-srr). In older releases, these metrics were disabled completely on Apollo Lake platforms to avoid a system crash. If the system does not support these metrics, use dram-bw as an alternative for collecting bandwidth. Use the -v option to determine which version of the socperf driver is loaded. If a mismatch occurs (socperf v1.2.0 used with socwatch >=v2.6.1), Intel SoC Watch will report this error: -1, SOCPERF ERROR configuring SOCPERF interface. - If Intel SoC Watch crashes while collecting a bandwidth feature (e.g. -f ddr-bw) or the DRAM self-refresh feature (i.e. -f dram-srr) AND a subsequent collection prints the error: ERROR: ERROR configuring SOCPERF interface! then both the socperf3.ko and socwatch2\_10.ko kernel modules must be unloaded with the rmmod command and reloaded with the insmod command before Intel SoC Watch can be used to collect additional data. - When measuring DRAM self refresh using the -f dram-srr feature on cost reduced systems (e.g. Intel platforms code named CherryTrail cost reduced), Intel SoC Watch may report 100% self refresh residency on Channel 1. These systems are single channel systems and therefore, the result should be 0%. - On a very small number of systems, results from the all-approx-bw feature may be one half of the correct result. During testing, this issue was only experienced on the first collection after the system was booted. All subsequent collections correctly measured the systems bandwidth as expected. - If socperf reads occur before the start of collection, a dmesg error message is generated: "socperf3: [ERROR] ERROR: RETURNING EARLY from Read\_Data". This message is benign and can safely be ignored. #### **C-States / P-States** - When collecting a trace of residency data from hardware counters (i.e., using -m), the summarized residency data could be 2-3% inaccurate due to error propagation in the accumulation of each sample's calculated residency. Collecting without -m results in greater accuracy because only a single sample is taken. However, long collection duration could result in a counter rollover, and that will not be detected without the use of -m. - The hardware CPU P-state data may be missing for some Cores when using feature <code>-f hw-cpu-pstate</code> on Intel platforms code named Skylake, Kaby Lake, Whiskey Lake, and Amber Lake. The issue is caused by unexpected behavior of the hardware counters. The tool ignores these bad samples which results in the missing data. - On Intel platforms code named Broxton and Apollo Lake, the cpu-cstate metric results do not contain. module C-state information. - On Intel Atom® platforms, if all cores in a module request C6FS but actual sleep time is short, the Auto-Demotion logic of the hardware resolves the module state to module CO. Consequently, you may find module C0 to be greater than the sum of core C0 and C1 on all the cores in a module. On the same lines (auto demotion at the package level), the package C0 may be greater than module C0 residencies of the two modules. - During the transition time from core C1/C1e/C6 to core C0, a core may run in LFM which will be properly measured by Intel SoC Watch. Therefore, results that include a large number of C1/C1e/C6 residencies may show a lower PState than expected. #### S States & D States - On Intel platform code named CherryView based devices: - Even when the device's screen is off, the NC DState called Display DPIO is reported in the D0i0 state 100% of the time. This result may or may not be correct. - When collecting NC D0ix states with the -f nc-dstate switch, note that the Display Island B (HDMI) IP block will remain in D0i0 when the primary display is enabled even if an HDMI cable is removed. - When using the sc-dstate feature, the SEC IP block results are incorrect and should be ignored. Also, the UFS IP block results are incorrect because an internal fuse is disabled. #### Miscellaneous - Metrics report Unknown 0 when -m is not used and hibernation occurs. Metrics with a snapshot default collection mode, such as CPU C-state, will show the Unknown state with 0 time and the remaining states will not sum to the total collection duration if the system entered hibernation during the collection and the -m option was not specified. The snapshot metrics are only collected at the start and end of a collection by default, but finding hibernation time requires samples taken throughout the collection. Including -m will cause continuous sampling to occur for all metrics. When hibernation occurs, a message reporting time spent in hibernation appears at the beginning of the summary report. The Unknown state is then included for all appropriate metrics and the time in hibernation is included in that state. Refer to the Intel SoC Watch User's Guide "Options Quick Reference" section to learn which metrics have a snapshot collection mode by default. - Intel SoC Watch reads PMIC and Skin Temperatures from the system's sysfs. Rarely, a sysfs read may not return before a subsequent sysfs read occurs. When this occurs, specific sample results may be missing in the timed trace CSV and raw text files. - Permission issues with SELinux will cause Intel SoC Watch collection to fail. Some distributions enable SELinux by default. If you have the following file your system may have SELinux enabled: /selinux/enforce If that file exists, you can disable by issuing: 'echo 0 > /selinux/enforce · Syntax errors in the command line may not report a visible error message. If a collection did not run and you are not seeing any error message, add option -d 2 to your command line to get more information. #### **Intel® VTune™ Amplifier Visualization** - The Intel VTune Amplifier System Summary does not report the rated frequency for the CPU when viewing results from data collected by SoC Watch, such as Throttling Analysis. Instead, it reports 1GHz which is the clock frequency used in the calculations for processing the SoC Watch data. - Intel VTune Amplifier 2017 for Systems Update 1 or later is required for visualizing and analyzing Intel SoC Watch v2.10.0 and newer PWR files. We recommend using the latest version of Intel VTune Amplifier. - If the bandwidth is 0 Mb throughout the collection for a particular bandwidth type, Intel VTune Amplifier will not show a timeline entry for it. The timeline is shown only if there is at least one non-zero value. - In some cases, the summary CSV results produced by Intel SoC Watch can vary from the summary results shown by Intel VTune Amplifier even though they represent the same collection. For example, the summary CSV file may report a specific cpu-pstate residency of 50.78% and Intel VTune Amplifier may report the same cpu-pstate residency as 50.8%. - Intel VTune Amplifier currently does not support bandwidth ranges used for ReadPartial and WritePartial. In order to keep the visualization consistent with Intel SoC Watch v1.x, Intel VTune Amplifier uses the upper bound of the range to visualize the bandwidth. - The minimum and average calculations displayed in the grid for Sampled Value metrics don't take 0 values into consideration in older versions of Intel VTune Amplifier. For example, Sampled Graphics P-States minimum values may show a value higher than 0 Mhz even when some samples have 0 Mhz values. This in turn affects the average value calculation. - In order to visualize graphics C-states that are reported as Render and Media, the table headers in the trace file (generated with option -r int), must be manually modified, adding *Render* and *Media* to the appropriate C0, C1, and C6 column headers. # 8 ### **Related Documentation** The release contains these documents: • Energy Analysis help (https://software.intel.com/en-us/energy-analysis-user-guide)