Device management task description¶
The goal of the Device Management task is to:
Read, monitor and record the sensor values:
Sensor values are read every second via the Xilinx® Runtime (XRT) native library C++ device APIs.
Measurements can be checked against provided thresholds. A Critical Warning is only issue once if the value goes out of range throughout the entire test.
Measurements are recorded in an output CSV file when enabled.
Configure the HW watchdog (disable or extend it). When the watchdog reaches its duration, it stops all CU present in the xclbin. Xbtest SW resets the HW watchdog on a regular basis (half the HW duration).
By default, the following sensors are monitored (this list can be amended by other sensors defined in Platform definition).
FPGA fan speed.
FPGA temperature.
Board power.
3v3_pex: power, current and voltage.
12v_pex: power, current and voltage.
Vccint: power, current and voltage.
12v_aux: power, current and voltage (when auxiliary power cable is present).
You can use this task to monitor other sensors or change the behaviour of sensor warnings (threshold or severity).
Note
This task is always running and does not require any parameters. So, there is no need to include it inside your test JSON file unless you want to modify the default behaviour. For more information, see Device management test JSON members.
Sensor source definition¶
A sensor source is defined by a type and an ID.
The following table presents the different types of sensor that can monitored by xbtest and for each type, the ID of the sources monitored by default:
| Sensor type | Description | Default sensor IDs | Identify supported sensor IDs | 
|---|---|---|---|
| 
 | Mechanical sensors on and surrounding the device. Typically, mechanical measurements are fan speed recorded in Revolutions Per Minute (RPM). | 
 | 
 $ xbutil examine --device <BDF> --report mechanical --format JSON --output <filename>
 | 
| 
 | Thermal sensors present on the device. Typically, thermal measurements are temperatures recorded in degree Celsius. | 
 | 
 $ xbutil examine --device <BDF> --report thermal --format JSON --output <filename>
 | 
| 
 | Electrical and power sensors present on the device. Typically, electrical measurements are currents recorded in mA, voltages recorded in mV and power recorded in W. | 
 | 
 $ xbutil examine --device <BDF> --report electrical --format JSON --output <filename>
 | 
Refer to the documentation for your card for more information on the sensors.
The sources monitored by default are defined in the Platform definition JSON file (see Platform definition). Other sources can be monitored when specified using sensor parameter.
The supported sources are also reported depending on targeted platform using the following command:
$ xbtest -d <BDF> -g device_mgmt
Device management test JSON members¶
The following is an example of a device management task parameter definition:
"tasks": {
    "device_mgmt": {
        "sensor" : [
            {
                "id"   : "12v_pex",
                "type" : "electrical",
                "warning_threshold" : {
                    "min": 1.0,
                    "max": 65.0
                },
                "error_threshold" : {
                    "min": 0.1,
                    "max": 70.0
                },
                "abort_threshold" : {
                    "min": 0.0,
                    "max": 75.0
                }
            }
        ],
        "watchdog_duration": 32
    }
}
Definition¶
The following table shows all members available for this task. More details are provided for each member in the subsequent sections.
| Member | JSON format | Mandatory/optional | Description | ||
|---|---|---|---|---|---|
| List | Optional | List of sensors definitions. | |||
| Value | Mandatory 
 | Sensor type. | |||
| Value | Mandatory 
 | Sensor ID. | |||
| Object | Optional | Warning limits. | |||
| Value | Mandatory 
 | Minimum warning limit. | |||
| Value | Mandatory 
 | Maximum warning limit. | |||
| Object | Optional | Error limits. | |||
| Value | Mandatory 
 | Minimum error limit. | |||
| Value | Mandatory 
 | Maximum error limit. | |||
| Object | Optional | Abort limits. | |||
| Value | Mandatory 
 | Minimum abort limit. | |||
| Value | Mandatory 
 | Maximum abort limit. | |||
| Value | Optional | Store in a file all measurements of the task. | |||
| Value | Optional | Control Watchdog behaviour. | |||
sensor¶
Optional; Type: List of objects.
Define list of sensors definitions (JSON objects). Override existing sensor definition or define new sensor sources.
type¶
Mandatory if sensor was provided;
Type           : string;
Possible values: mechanical, thermal or electrical;
id¶
Mandatory if sensor was provided; Type : string; Possible values: depend on targeted platform;
ID of the sensor source to monitor. See Sensor source definition for more information on the supported sensor sources.
warning_threshold¶
Optional; Type: Object.
Warning limits: if measurement is out of range, a critical warning is displayed (once), the test cases are not stopped and global result is pass.
warning_threshold.min¶
Optional; Type : double; Possible values: any double value provided as max > min.
Minimum warning limit.
warning_threshold.max¶
Optional; Type : double; Possible values: any double value provided as max > min.
Maximum warning limit.
error_threshold¶
Optional; Type: Object.
Error limits: if measurement is out of range, an error is displayed (once), the test cases are not stopped and global result is failure.
error_threshold.min¶
Optional; Type : double; Possible values: any double value provided as max > min.
Minimum error limit.
error_threshold.max¶
Optional; Type : double; Possible values: any double value provided as max > min.
Maximum error limit.
abort_threshold¶
Optional; Type: Object.
Abort limits: if measurement is out of range, a failure is displayed (once), all test cases are stopped and global result is failure.
abort_threshold.min¶
Optional; Type : double; Possible values: any double value provided as max > min.
Minimum abort limit.
abort_threshold.max¶
Optional; Type : double; Possible values: any double value provided as max > min.
Maximum abort limit.
use_output_file¶
Optional;
Type           : boolean;
Possible values: true or false.
By default, when not specified, the output CSV file is only generated if any sensor parameter is specified.
Based on use_output_file parameters:
When set to
true, the output CSV file is generated.
When set to
false, the output CSV file is not generated.
The Device Management can store all measurements in an output CSV file (see Output files).
watchdog_duration¶
Optional;
Type           : integer;
Possible values: 0 (disable),  16 (default), 32, 64 and 128.
Controls the HW watchdog duration.
Output files¶
All sensor measurements are stored in output CSV file named sensor.csv which is generated in xbtest logging directory.
The values are stored in CSV type format with one column for each information type. By default, this file is not generated.
Important
If the command line option -L is used while calling the Application software, no output file is generated.
A new line is written in this file every second. At a minimum, the following values are recorded:
time (s): Timestamp of the measurement.
measurement ID: Measurement identifier. ID of first measurement is 1.
measurement valid: Set to
OKif theTestsoftware was able to successfully gets power and temperature measurements via the Xilinx® Runtime (XRT) native library C++ device APIs, otherwise set toKO.
sensor reading duration (s): Duration in seconds of the Xilinx® Runtime (XRT) native library C++ device APIs commands execution. This value is rounded, for example a value of 0 means that the XRT Device APIs commands took less than 1 second.
Mechanical measurements: Group of one or more columns recording measurements for each mechanical sensor source monitored by xbtest.
Thermal measurements: Group of one or more columns recording measurements for each thermal sensor source monitored by xbtest.
Electrical measurements: Group of one or more columns recording detailed measurements for each electrical sensor source monitored by xbtest.
See Sensor source definition for more information on the sensor sources monitored by xbtest.