Difference between revisions of "R-Car/LAVA"

From eLinux.org
Jump to: navigation, search
m (corrected lava-dispatcher-host link)
m (small device definition clarification)
(3 intermediate revisions by the same user not shown)
Line 30: Line 30:
  
 
=== Device definitions ===
 
=== Device definitions ===
<TBA 1. extending device dictionary>
+
For LAVA to control ADB/Fastboot on the host and DUT the following LAVA variables need to be set:
 +
<syntaxhighlight lang=text>
 +
fastboot_deploy_uboot_commands
 +
fastboot_serial_number
 +
adb_serial_number
 +
device_info
 +
</syntaxhighlight>
  
<TBA 2. extending device-type template>
+
''fastboot_deploy_uboot_commands'' details the u-boot commands required to deploy using fastboot. The remaining variables are used for DUT discovery by fastboot and ADB.  
  
<2.1. LXC side effect>
+
Here is an example of setting these in an R-Car device-type template:
 +
<syntaxhighlight lang=jinja2>
 +
{% set fastboot_deploy_uboot_commands = fastboot_deploy_uboot_commands|default(['fastboot']) %}
 +
{% set fastboot_serial_number = fastboot_serial_number|default("0000000000") %}
 +
{% set adb_serial_number = adb_serial_number|default(fastboot_serial_number) %}
 +
{% set device_info = device_info|default([{'board_id': fastboot_serial_number}]) %}
 +
</syntaxhighlight>
 +
 
 +
Note: At the time of writing (version 2021.05) LAVA contains LXC related code that fails test jobs if the adb/fastboot serial_number variable is set in the device-type template but the DUT device dictionary does not have a unique number. This is a feature of LAVA and applies to all boards. You may therefore consider what device-type template you update to avoid the need to provide numbers for DUTs that do not use fastboot/adb. For example if your R-Car H3 boards with Kingfisher fitted are typically used for AOSP but other boards are not then you might update the template r8a7795-h3ulcb-kf.jinja2 rather than rcar-gen3-common.jinja2 (the common device-type template for all R-Car boards in upstream LAVA).
 +
 
 +
The unique serial number for each DUT can be set in its LAVA device dictionary.
 +
For example:
 +
<syntaxhighlight lang=jinja2>
 +
{% set fastboot_serial_number = '00025269' %}
 +
{% set adb_serial_number = '00025269' %}
 +
</syntaxhighlight>
 +
 
 +
The device-type templates and device dictionary can be appended to using the LAVA lavacli utility, e.g:
 +
<syntaxhighlight lang=text>
 +
lavacli device-types template get <name>
 +
lavacli device-types template set <name> <template.jinja2>
 +
</syntaxhighlight>
 
==== Using lava-docker ====
 
==== Using lava-docker ====
If you are using lava-docker you tell LAVA the serial number for the DUT in the boards.yaml.
+
If you are using lava-docker the device dictionary can be updated for the DUT in the boards.yaml.
 
This can be done in a ''custom_option'' block for the DUT.  
 
This can be done in a ''custom_option'' block for the DUT.  
  

Revision as of 11:42, 23 August 2021

Introduction

This page contains information on using the LAVA CI project on R-Car platforms.

It is not intended as a complete 'end to end' tutorial on running LAVA. There are numerous sources for such tutorials including the official LAVA documentation. Instead, the aim is to explain nuances of using R-Car platforms in LAVA and to accelerate integration.

Glossary

DUT = Device Under Test, e.g. hardware platform to be tested

Serial console

LAVA interacts with the DUT via a serial console. A typical test job will involve restarting the DUT through a power cycle. This can be for multiple reasons. Power cycling means each job starts with the same setup for example. Another is restarting after flashing the DUT to use the flashed software.

The challenge is therefore for LAVA to maintain a serial console connection through such resets. Some R-Car platforms reset the serial on power on causing LAVA to lose the ser2net/telnet console link and therefore its ability to control the DUT. This can be mitigated by setting the LOCAL option for the DUT in the LAVA Worker ser2net configuration file.

Using lava-docker

If you are managing your LAVA instance using lava-docker (a project that simplifies LAVA instances using Docker) you can automate this by setting the option in your boards.yaml:

      ser2net_options:
        - LOCAL

ADB/Fastboot/Android/AOSP

AOSP brings a complication to a LAVA instance because of the need to run tools such as ADB and Fastboot on the Host which then communicate with the DUT. LAVA needs to be able to handle running different versions of these tools and to support the DUT discovery and communication.

Different host tooling versions are supported by running them on the host in LXC or Docker containers. LXC is now considered legacy support and Docker is strongly recommended. See the LAVA documentation for details. When LAVA is itself running in a Docker container, such as when using lava-docker, the host tooling containers are run as a sibling of the LAVA container not a child.

Fastboot and ADB use serial numbers to find DUTs. LAVA uses the host package lava-dispatcher-host to find the DUT and share it into the Docker container specified in the test job. For that to succeed we must describe each serial number to LAVA. How to do that for R-Car is described in the section on device definitions below.

Device definitions

For LAVA to control ADB/Fastboot on the host and DUT the following LAVA variables need to be set:

fastboot_deploy_uboot_commands
fastboot_serial_number
adb_serial_number
device_info

fastboot_deploy_uboot_commands details the u-boot commands required to deploy using fastboot. The remaining variables are used for DUT discovery by fastboot and ADB.

Here is an example of setting these in an R-Car device-type template:

{% set fastboot_deploy_uboot_commands = fastboot_deploy_uboot_commands|default(['fastboot']) %}
{% set fastboot_serial_number = fastboot_serial_number|default("0000000000") %}
{% set adb_serial_number = adb_serial_number|default(fastboot_serial_number) %}
{% set device_info = device_info|default([{'board_id': fastboot_serial_number}]) %}

Note: At the time of writing (version 2021.05) LAVA contains LXC related code that fails test jobs if the adb/fastboot serial_number variable is set in the device-type template but the DUT device dictionary does not have a unique number. This is a feature of LAVA and applies to all boards. You may therefore consider what device-type template you update to avoid the need to provide numbers for DUTs that do not use fastboot/adb. For example if your R-Car H3 boards with Kingfisher fitted are typically used for AOSP but other boards are not then you might update the template r8a7795-h3ulcb-kf.jinja2 rather than rcar-gen3-common.jinja2 (the common device-type template for all R-Car boards in upstream LAVA).

The unique serial number for each DUT can be set in its LAVA device dictionary. For example:

{% set fastboot_serial_number = '00025269' %}
{% set adb_serial_number = '00025269' %}

The device-type templates and device dictionary can be appended to using the LAVA lavacli utility, e.g:

lavacli device-types template get <name>
lavacli device-types template set <name> <template.jinja2>

Using lava-docker

If you are using lava-docker the device dictionary can be updated for the DUT in the boards.yaml. This can be done in a custom_option block for the DUT.

For example:

    custom_option:
    - "set fastboot_serial_number = '00012345'"
    - "set adb_serial_number = '00012345'"

Flashing AOSP

<TBA how to flash using R-Car flash script>