Drivers API¶
Drivers provide low-level hardware control and protocol implementations.
On this page:
Power Drivers — VesyncPowerDriver, CyberPowerDriver, CyberPowerPdu, HomeAssistantPowerDriver, HomeAssistantClient
Power Drivers¶
VesyncPowerDriver¶
- class adi_lg_plugins.drivers.vesyncdriver.VesyncPowerDriver(target, name)[source]¶
Bases:
Driver,PowerResetMixin,PowerProtocolVesyncPowerDriver - Driver using a Vesync Smart Outlet to control a target’s power - https://github.com/webdjoe/pyvesync. Uses pyvesync tool to control the outlet.
- on()[source]¶
Turn on all configured VeSync outlets.
This method powers on all outlets specified in the VesyncOutlet resource configuration. If multiple outlets are configured, they will all be turned on sequentially.
- Raises:
Exception – If outlet control fails or outlets are not found.
- off()[source]¶
Turn off all configured VeSync outlets.
This method powers off all outlets specified in the VesyncOutlet resource configuration. If multiple outlets are configured, they will all be turned off sequentially.
- Raises:
Exception – If outlet control fails or outlets are not found.
- reset()[source]¶
Perform a power reset cycle on all outlets.
This method turns off the outlets, waits for the configured delay period, then turns them back on. This is useful for hard-resetting hardware.
The delay duration is configured in the VesyncOutlet resource.
- Raises:
Exception – If outlet control fails.
- cycle()[source]¶
Power cycle all outlets (same as reset).
Alias for reset(). Turns off the outlets, waits for the configured delay, then turns them back on.
- Raises:
Exception – If outlet control fails.
- get()[source]¶
Get the current power state of all outlets.
- Returns:
True if all configured outlets are on, False otherwise.
- Return type:
- __init__(target, name)¶
Method generated by attrs for class VesyncPowerDriver.
- Return type:
None
CyberPowerDriver¶
- class adi_lg_plugins.drivers.cyberpowerdriver.CyberPowerDriver(target, name)[source]¶
Bases:
Driver,PowerResetMixin,PowerProtocolCyberPowerDriver - Driver using a CyberPower PDU to control a target’s power
- __init__(target, name)¶
Method generated by attrs for class CyberPowerDriver.
- Return type:
None
- on()[source]¶
Turn on the configured CyberPower PDU outlet.
Uses SNMP to send an ‘immediateOn’ command to the outlet specified in the CyberPowerOutlet resource configuration.
- Raises:
CyberPowerPduException – If SNMP communication fails.
- off()[source]¶
Turn off the configured CyberPower PDU outlet.
Uses SNMP to send an ‘immediateOff’ command to the outlet specified in the CyberPowerOutlet resource configuration.
- Raises:
CyberPowerPduException – If SNMP communication fails.
- reset()[source]¶
Perform a power reset cycle on the outlet.
This method turns off the outlet, waits for the configured delay period, then turns it back on. Useful for hard-resetting hardware.
The delay duration is configured in the CyberPowerOutlet resource.
- Raises:
CyberPowerPduException – If SNMP communication fails.
CyberPowerPdu¶
- class adi_lg_plugins.drivers.cyberpowerdriver.CyberPowerPdu(host)[source]¶
Bases:
objectClass to query & control a CyberPower PDU via SNMP.
Tested on the PDU15SWHVIEC8FNET. I don’t understand SNMP well enough to have any idea if this would be expected to work on other models.
This class is basically just a piece of copy-pasted pysnmp code and a depository for comments.
- Parameters:
host (str) – IP address or hostname of the PDU on the network
- outlet_state_oids = {'cancelPendingCommand': 7, 'delayedOff': 5, 'delayedOn': 4, 'delayedReboot': 6, 'immediateOff': 2, 'immediateOn': 1, 'immediateReboot': 3, 'outletIdentify': 8}¶
HomeAssistantPowerDriver¶
- class adi_lg_plugins.drivers.homeassistantdriver.HomeAssistantPowerDriver(target, name)[source]¶
Bases:
Driver,PowerResetMixin,PowerProtocolHomeAssistantPowerDriver - Driver using a Home Assistant switch/outlet to control a target’s power via the Home Assistant REST API.
- get()[source]¶
Get the current power state.
- Returns:
True if the switch is on, False otherwise.
- Return type:
- __init__(target, name)¶
Method generated by attrs for class HomeAssistantPowerDriver.
- Return type:
None
HomeAssistantClient¶
Shell and File Transfer¶
ADIShellDriver¶
- class adi_lg_plugins.drivers.shelldriver.ADIShellDriver(target, name, prompt, login_prompt, username, password=None, keyfile='', login_timeout=60, console_ready='', await_login_timeout=2, post_login_settle_time=0)[source]¶
Bases:
CommandMixin,Driver,CommandProtocol,FileTransferProtocolADIShellDriver - Driver to execute commands on the shell ADIShellDriver binds on top of a ConsoleProtocol.
On activation, the ADIShellDriver will look for the login prompt on the console, and login to provide shell access.
- Parameters:
prompt (regex) – the shell prompt to detect
login_prompt (regex) – the login prompt to detect
username (str) – username to login with
password (str) – password to login with
keyfile (str) – keyfile to bind mount over users authorized keys
login_timeout (int) – optional, timeout for login prompt detection
console_ready (regex) – optional, pattern used by the kernel to inform the user that a console can be activated by pressing enter.
await_login_timeout (int) – optional, time in seconds of silence that needs to pass before sending a newline to device.
post_login_settle_time (int) – optional, seconds of silence after logging in before check for a prompt. Useful when the console is interleaved with boot output which may interrupt prompt detection.
- get_status()[source]¶
Returns the status of the shell-driver. 0 means not connected/found, 1 means shell
- put_bytes(buf, remotefile)[source]¶
Upload a file to the target. Will silently overwrite the remote file if it already exists.
- put(localfile, remotefile)[source]¶
Upload a file to the target. Will silently overwrite the remote file if it already exists.
- get_bytes(remotefile)[source]¶
Download a file from the target.
- Parameters:
remotefile (str) – source filename on the target
- Returns:
(bytes) file contents
- Raises:
ExecutionError – if something went wrong
- get(remotefile, localfile)[source]¶
Download a file from the target. Will silently overwrite the local file if it already exists.
- run_script_file(scriptfile, *args, timeout=60)[source]¶
Upload a script file to the target and run it.
- Parameters:
- Returns:
str, stderr: str, return_value: int)
- Return type:
Tuple of (stdout
- Raises:
ExecutionError – if something went wrong
IOError – if the provided localfile could not be found
- get_default_interface_device_name(version=4)[source]¶
Retrieve the default route’s interface device name.
- Parameters:
version (int) – IP version
- Returns:
Name of the device of the default route
- Raises:
ExecutionError – if no or multiple routes are set up
- get_ip_addresses(device=None)[source]¶
Retrieves IP addresses for given interface name.
Note that although the return type is named IPv4Interface/IPv6Interface, it contains an IP address with the corresponding network prefix.
- Parameters:
device (str) – Name of the interface to query, defaults to default route’s device name.
- Returns:
List of IPv4Interface or IPv6Interface objects
- get_status_uboot()[source]¶
Retrieve status of the UBootDriver. 0 means inactive, 1 means active.
- Returns:
status of the driver
- Return type:
- __init__(target, name, prompt, login_prompt, username, password=None, keyfile='', login_timeout=60, console_ready='', await_login_timeout=2, post_login_settle_time=0)¶
Method generated by attrs for class ADIShellDriver.
- Return type:
None
Storage Drivers¶
MassStorageDriver¶
- class adi_lg_plugins.drivers.massstoragedriver.MassStorageDriver(target, name, partition=None, mount_label='lg_mass_storage')[source]¶
Bases:
RemoteExecMixin,DriverMount and copy files to a USB mass storage device.
Supports both local-only (test runner == exporter) and remote-exporter bindings. When the bound resource is proxied from a coordinator, pmount/pumount/mkdir run on the exporter host and file copies are staged there over a single reused ssh connection (see
RemoteExecMixin).Specify partition when the bound resource points at a whole block device (e.g. /dev/sdb) rather than a specific partition; its value is the absolute partition path on the exporter host — a raw device (/dev/sdb1) or a stable symlink (/dev/disk/by-partuuid/…).
- copy_file(src, dst)[source]¶
Copy a local file onto the mass storage device.
- Parameters:
src – source file path on the test runner host.
dst – destination path relative to the mount point.
- update_files()[source]¶
Batch-copy files listed in mass_storage.file_updates (local-only path mapping).
- __init__(target, name, partition=None, mount_label='lg_mass_storage')¶
Method generated by attrs for class MassStorageDriver.
- Return type:
None
Kuiper Drivers¶
KuiperDLDriver¶
- class adi_lg_plugins.drivers.kuiperdldriver.KuiperDLDriver(target, name)[source]¶
Bases:
DriverKuiperDLDriver - Driver to download and manage Kuiper releases and provide files to the target device.
- cache_datafile = 'cache_info.json'¶
- check_cached(release_version=None)[source]¶
Check if the specified Kuiper release version is cached locally. :param release_version: Version of the Kuiper release to check. If None, uses the version from kuiper_resource. :type release_version: str
- Returns:
True if the release is cached, False otherwise.
- Return type:
- download_release(release_version=None)[source]¶
Download the specified Kuiper release version if not already cached.
- get_full_image_path(release_version=None)[source]¶
Return the cached full SD image (.img) path for the configured release.
Downloads + extracts the release first if it isn’t cached. Caller is responsible for activating/deactivating the driver.
- add_files_to_target(filename)[source]¶
Add a file to the target device.
- Parameters:
filename (str) – Path to the file to add to the target.
- __init__(target, name)¶
Method generated by attrs for class KuiperDLDriver.
- Return type:
None
Cloudsmith Drivers¶
CloudsmithDLDriver¶
- class adi_lg_plugins.drivers.cloudsmithdldriver.CloudsmithDLDriver(target, name)[source]¶
Bases:
DriverDriver to resolve and download Cloudsmith boot artifacts.
Exposes the same
get_boot_files_from_release()/_boot_filescontract as KuiperDLDriver so it drops into the FPGA SoC boot strategies.- cache_datafile = 'cache_info.json'¶
- download_release(version=None)[source]¶
Resolve, download, and cache the boot artifact; return its local path.
- get_boot_file_path(version=None)[source]¶
Ensure the artifact is downloaded and return its local path.
- __init__(target, name)¶
Method generated by attrs for class CloudsmithDLDriver.
- Return type:
None
FPGA/JTAG Drivers¶
XilinxJTAGDriver¶
- class adi_lg_plugins.drivers.xilinxjtagdriver.XilinxJTAGDriver(target, name)[source]¶
Bases:
RemoteExecMixin,DriverProgram Xilinx FPGAs via JTAG using xsdb.
- Bindings:
- xilinxdevicejtag: XilinxDeviceJTAG resource (JTAG target IDs + bitstream/kernel paths
as seen by the host that runs xsdb).
xilinxvivado: XilinxVivadoTool resource (vivado_path / xsdb_path).
- bindings: Dict[str, Any] = {'xilinxdevicejtag': {'XilinxDeviceJTAG'}, 'xilinxvivado': {'XilinxVivadoTool'}}¶
- load_zynq_uboot(ps7_init_tcl, uboot_elf, a9_target_name='*Cortex-A9 MPCore #0', bitstream_path=None, fsbl_elf=None)[source]¶
JTAG-bootstrap U-Boot on a Zynq-7000 device.
The board can be in any boot state — xsdb will
rst -systemfirst to clear residual DDR/PS state before sourcing the board-specificps7_init.tcl. Used for SD-card recovery when BootROM cannot load FSBL from a corrupted card.The
a9_target_namefilter is used instead of an integer target index because Zynq-7000 xsdb target ordering shifts when the PL is loaded; the name-pattern form matches Xilinx’s generated wrappers and is stable across Vivado versions.
- load_and_run_elf(elf_path, a9_target_name='*Cortex-A9 MPCore #0', bitstream_path=None, ps7_init_tcl=None)[source]¶
JTAG-load and start an arbitrary bare-metal ELF (e.g. no-os firmware).
Generalizes
load_zynq_uboot()to any ELF that runs directly on a Zynq core (no FSBL/U-Boot chain). The same xsdb sequence is used:connect → rst -system → [fpga] → [ps7_init] → dow elf → con. The optionalbitstream_pathprograms the PL first (required when the firmware touches FPGA-fabric peripherals), andps7_init_tclruns the board PS init — both are produced by the no-os build’s HDL.xsa.Paths are resolved to absolute before being embedded in the xsdb TCL: xsdb runs the script from its own working directory (not the caller’s), so a relative
dow/fpga -fpath would fail to open.
- stop_zynq_cpu(a9_target_name='*Cortex-A9 MPCore #0')[source]¶
Halt the A9 #0 core — used between failed bootstrap attempts.
- Parameters:
a9_target_name (str)
- Return type:
None
- __init__(target, name)¶
Method generated by attrs for class XilinxJTAGDriver.
- Return type:
None
Network Drivers¶
TFTPServerDriver¶
- class adi_lg_plugins.drivers.tftpserverdriver.TFTPServerDriver(target, name)[source]¶
Bases:
DriverTFTPServerDriver provides a pure Python TFTP server.
- bindings: Dict[str, Any] = {'resource': <class 'adi_lg_plugins.resources.tftpserver.TFTPServerResource'>}¶
- __init__(target, name)¶
Method generated by attrs for class TFTPServerDriver.
- Return type:
None
Utility Classes¶
- class adi_lg_plugins.drivers.kuiperdldriver.Downloader[source]¶
Utility class for downloading and verifying Kuiper Linux releases.
This class handles downloading release archives from ADI’s servers, verifying MD5 checksums, and extracting compressed archives. It supports both .xz and .zip compressed formats and displays progress bars using tqdm.
The Downloader is used internally by KuiperDLDriver but can also be used standalone via the kuiperdl CLI tool.
Example
>>> dl = Downloader() >>> rel = dl.releases("2023_R2_P1") >>> dl.download(rel["link"], rel["zipname"]) >>> dl.check(rel["zipname"], rel["zipmd5"]) >>> dl.extract(rel["zipname"], rel["imgname"])
- class adi_lg_plugins.drivers.imageextractor.IMGFileExtractor(img_path, logger=None)[source]¶
Extract files from disk image (.img) files using pytsk3.
This utility class provides methods to inspect partitions, list files, and extract individual files or directories from disk image files without mounting them. It’s primarily used by KuiperDLDriver to extract boot files from Kuiper Linux release images.
- Parameters:
img_path (str) – Path to the disk image file.
logger (Logger, optional) – Logger instance for debug output. If None, prints to stdout.
Example
>>> extractor = IMGFileExtractor("kuiper.img") >>> partitions = extractor.get_partitions() >>> fs = extractor.open_filesystem(partitions[0]["start"]) >>> extractor.extract_file(fs, "/Image", "./output/Image") >>> extractor.close()
- class adi_lg_plugins.drivers.cloudsmithdldriver.Downloader[source]¶
Streaming downloader with retry + sha256 verification.
Copied from KuiperDLDriver’s Downloader (kept independent). Only the pieces needed for individual-file downloads are retained: a retrying session and a streaming
downloadthat returns the sha256 digest.
- adi_lg_plugins.drivers.cloudsmithdldriver.get_latest_bootfiles(owner, repo, fpga_carrier=None, daughter_card=None, vfilter=None, vnot=None, filename=None, token=None, pin=None)[source]¶
Resolve the matching Cloudsmith package, returning the raw package dict.
Without
pinthe newest matching package (byuploaded_at) is returned; withpinthe package whoseversionequalspinis returned. The returned dict carriescdn_url,checksumsversionanduploaded_atplus a parsed_infoentry.
- adi_lg_plugins.drivers.cloudsmithdldriver.parse_version_info(version_str, tags, repo=None)[source]¶
Parse a Cloudsmith version string into structured metadata.
Returns
None(rather than raising) for unparseable strings, ignored systems, or unknown carriers, so one unexpected package never crashes resolution.
Software Installer¶
SoftwareInstallerDriver¶
- class adi_lg_plugins.drivers.softwareinstaller.SoftwareInstallerDriver(target, name)[source]¶
Bases:
DriverSoftwareInstallerDriver - Driver to install software, clone repos, copy directories, and run builds/tests on a DUT.
- bindings: Dict[str, Any] = {'command': <class 'labgrid.protocol.commandprotocol.CommandProtocol'>, 'file_transfer': <class 'labgrid.protocol.filetransferprotocol.FileTransferProtocol'>}¶
- install_package(package_name, update=False)[source]¶
Installs a package using the detected package manager.
- __init__(target, name)¶
Method generated by attrs for class SoftwareInstallerDriver.
- Return type:
None