~funderscore blog cgit wiki get in touch
aboutsummaryrefslogtreecommitdiff
blob: ed12d3a46186f6b957c0ec7d606af2269388bac2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# SPDX-License-Identifier: GPL-2.0+
# Copyright 2022 Google LLC
#
# Test addition of VBE

import os

import pytest
import u_boot_utils

@pytest.mark.boardspec('sandbox_vpl')
@pytest.mark.requiredtool('dtc')
def test_vbe_vpl(u_boot_console):
    cons = u_boot_console
    #cmd = [cons.config.build_dir + fname, '-v']
    ram = os.path.join(cons.config.build_dir, 'ram.bin')
    fdt = os.path.join(cons.config.build_dir, 'arch/sandbox/dts/test.dtb')
    image_fname = os.path.join(cons.config.build_dir, 'image.bin')

    # Enable firmware1 and the mmc that it uses. These are needed for the full
    # VBE flow.
    u_boot_utils.run_and_log(
        cons, f'fdtput -t s {fdt} /bootstd/firmware0 status disabled')
    u_boot_utils.run_and_log(
        cons, f'fdtput -t s {fdt} /bootstd/firmware1 status okay')
    u_boot_utils.run_and_log(
        cons, f'fdtput -t s {fdt} /mmc3 status okay')
    u_boot_utils.run_and_log(
        cons, f'fdtput -t s {fdt} /mmc3 filename {image_fname}')

    # Remove any existing RAM file, so we don't have old data present
    if os.path.exists(ram):
        os.remove(ram)
    flags = ['-p', image_fname, '-w', '-s', 'state.dtb']
    cons.restart_uboot_with_flags(flags)

    # Make sure that VBE was used in both VPL (to load SPL) and SPL (to load
    # U-Boot
    output = cons.run_command('vbe state')
    assert output == 'Phases: VPL SPL'