2016-01-16 02:15:24 +08:00
|
|
|
# Copyright (c) 2015 Stephen Warren
|
|
|
|
# Copyright (c) 2015-2016, NVIDIA CORPORATION. All rights reserved.
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
|
|
|
# Logic to interact with U-Boot running on real hardware, typically via a
|
|
|
|
# physical serial port.
|
|
|
|
|
|
|
|
import sys
|
|
|
|
from u_boot_spawn import Spawn
|
|
|
|
from u_boot_console_base import ConsoleBase
|
|
|
|
|
|
|
|
class ConsoleExecAttach(ConsoleBase):
|
2016-01-27 04:41:30 +08:00
|
|
|
"""Represents a physical connection to a U-Boot console, typically via a
|
2016-01-16 02:15:24 +08:00
|
|
|
serial port. This implementation executes a sub-process to attach to the
|
|
|
|
console, expecting that the stdin/out of the sub-process will be forwarded
|
|
|
|
to/from the physical hardware. This approach isolates the test infra-
|
|
|
|
structure from the user-/installation-specific details of how to
|
2016-01-27 04:41:30 +08:00
|
|
|
communicate with, and the identity of, serial ports etc."""
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
def __init__(self, log, config):
|
2016-01-27 04:41:30 +08:00
|
|
|
"""Initialize a U-Boot console connection.
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
Args:
|
|
|
|
log: A multiplexed_log.Logfile instance.
|
|
|
|
config: A "configuration" object as defined in conftest.py.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
Nothing.
|
2016-01-27 04:41:30 +08:00
|
|
|
"""
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
# The max_fifo_fill value might need tweaking per-board/-SoC?
|
|
|
|
# 1 would be safe anywhere, but is very slow (a pexpect issue?).
|
|
|
|
# 16 is a common FIFO size.
|
|
|
|
# HW flow control would mean this could be infinite.
|
|
|
|
super(ConsoleExecAttach, self).__init__(log, config, max_fifo_fill=16)
|
|
|
|
|
2016-02-04 07:46:34 +08:00
|
|
|
with self.log.section('flash'):
|
|
|
|
self.log.action('Flashing U-Boot')
|
|
|
|
cmd = ['u-boot-test-flash', config.board_type, config.board_identity]
|
|
|
|
runner = self.log.get_runner(cmd[0], sys.stdout)
|
|
|
|
runner.run(cmd)
|
|
|
|
runner.close()
|
|
|
|
self.log.status_pass('OK')
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
def get_spawn(self):
|
2016-01-27 04:41:30 +08:00
|
|
|
"""Connect to a fresh U-Boot instance.
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
The target board is reset, so that U-Boot begins running from scratch.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
None.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
A u_boot_spawn.Spawn object that is attached to U-Boot.
|
2016-01-27 04:41:30 +08:00
|
|
|
"""
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
args = [self.config.board_type, self.config.board_identity]
|
|
|
|
s = Spawn(['u-boot-test-console'] + args)
|
|
|
|
|
2016-02-11 07:54:37 +08:00
|
|
|
try:
|
|
|
|
self.log.action('Resetting board')
|
|
|
|
cmd = ['u-boot-test-reset'] + args
|
|
|
|
runner = self.log.get_runner(cmd[0], sys.stdout)
|
|
|
|
runner.run(cmd)
|
|
|
|
runner.close()
|
|
|
|
except:
|
|
|
|
s.close()
|
|
|
|
raise
|
2016-01-16 02:15:24 +08:00
|
|
|
|
|
|
|
return s
|