1
0
mirror of https://github.com/ARM-software/devlib.git synced 2024-10-05 18:30:50 +01:00
Go to file
Metin Kaya 228baeb317 target: Implement target runner classes
Add support for launching emulated targets on QEMU. The base class
``TargetRunner`` has groundwork for target runners like
``QEMUTargetRunner``.

``TargetRunner`` is a contextmanager which starts runner process (e.g.,
QEMU), makes sure the target is accessible over SSH (if
``connect=True``), and terminates the runner process once it's done.

The other newly introduced ``QEMUTargetRunner`` class:
- performs sanity checks to ensure QEMU executable, kernel, and initrd
  images exist,
- builds QEMU parameters properly,
- creates ``Target`` object,
- and lets ``TargetRunner`` manage the QEMU instance.

Also add a new test case in ``tests/test_target.py`` to ensure devlib
can run a QEMU target and execute some basic commands on it.

While we are in neighborhood, fix a typo in ``Target.setup()``.

Signed-off-by: Metin Kaya <metin.kaya@arm.com>
2024-03-20 12:16:12 +00:00
devlib target: Implement target runner classes 2024-03-20 12:16:12 +00:00
doc tools/buildroot: Add support for generating Linux target system images 2024-03-20 12:16:12 +00:00
src instrument/daq: Use clock boottime for the time column of the energy measurements 2020-11-09 17:27:21 +00:00
tests target: Implement target runner classes 2024-03-20 12:16:12 +00:00
tools tools/buildroot: Add support for generating Linux target system images 2024-03-20 12:16:12 +00:00
.gitignore Add build/ and dist/ to .gitingore 2017-04-26 17:19:55 +01:00
.readthedocs.yml docs: Add readthedocs config and requirements.txt 2021-10-28 11:03:08 +01:00
README.rst README: Update to include installation notes for paramiko 2020-04-20 12:03:42 +01:00
setup.py tests/test_target: Read target connection settings from a YAML file 2024-02-23 12:48:44 -08:00

devlib
======

``devlib`` exposes an interface for interacting with and collecting
measurements from a variety of devices (such as mobile phones, tablets and
development boards) running a Linux-based operating system.


Installation
------------

::

        sudo -H pip install devlib


Dependencies
------------

``devlib`` should install all dependencies automatically, however if you run
into issues please ensure you are using that latest version of pip.

On some systems there may additional steps required to install the dependency
``paramiko`` please consult the `module documentation <http://www.paramiko.org/installing.html>`_
for more information.

Usage
-----

Please refer  to the "Overview" section of the `documentation <http://devlib.readthedocs.io/en/latest/>`_.


License
-------

This package is distributed under `Apache v2.0 License <http://www.apache.org/licenses/LICENSE-2.0>`_. 


Feedback, Contrubutions and Support
-----------------------------------

- Please use the GitHub Issue Tracker associated with this repository for
  feedback.
- ARM licensees may contact ARM directly via their partner managers.
- We welcome code contributions via GitHub Pull requests. Please try to
  stick to the style in the rest of the code for your contributions.