Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 2 | # Copyright (c) 2015 Stephen Warren |
| 3 | # Copyright (c) 2015-2016, NVIDIA CORPORATION. All rights reserved. |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 4 | |
Heinrich Schuchardt | 8ca17c1 | 2021-11-23 00:01:49 +0100 | [diff] [blame] | 5 | """ |
| 6 | Logic to interact with U-Boot running on real hardware, typically via a |
| 7 | physical serial port. |
| 8 | """ |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 9 | |
| 10 | import sys |
| 11 | from u_boot_spawn import Spawn |
| 12 | from u_boot_console_base import ConsoleBase |
| 13 | |
| 14 | class ConsoleExecAttach(ConsoleBase): |
Stephen Warren | 75e731e | 2016-01-26 13:41:30 -0700 | [diff] [blame] | 15 | """Represents a physical connection to a U-Boot console, typically via a |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 16 | serial port. This implementation executes a sub-process to attach to the |
| 17 | console, expecting that the stdin/out of the sub-process will be forwarded |
| 18 | to/from the physical hardware. This approach isolates the test infra- |
| 19 | structure from the user-/installation-specific details of how to |
Stephen Warren | 75e731e | 2016-01-26 13:41:30 -0700 | [diff] [blame] | 20 | communicate with, and the identity of, serial ports etc.""" |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 21 | |
| 22 | def __init__(self, log, config): |
Stephen Warren | 75e731e | 2016-01-26 13:41:30 -0700 | [diff] [blame] | 23 | """Initialize a U-Boot console connection. |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 24 | |
| 25 | Args: |
| 26 | log: A multiplexed_log.Logfile instance. |
| 27 | config: A "configuration" object as defined in conftest.py. |
| 28 | |
| 29 | Returns: |
| 30 | Nothing. |
Stephen Warren | 75e731e | 2016-01-26 13:41:30 -0700 | [diff] [blame] | 31 | """ |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 32 | |
| 33 | # The max_fifo_fill value might need tweaking per-board/-SoC? |
| 34 | # 1 would be safe anywhere, but is very slow (a pexpect issue?). |
| 35 | # 16 is a common FIFO size. |
| 36 | # HW flow control would mean this could be infinite. |
| 37 | super(ConsoleExecAttach, self).__init__(log, config, max_fifo_fill=16) |
| 38 | |
Stephen Warren | e3f2a50 | 2016-02-03 16:46:34 -0700 | [diff] [blame] | 39 | with self.log.section('flash'): |
| 40 | self.log.action('Flashing U-Boot') |
| 41 | cmd = ['u-boot-test-flash', config.board_type, config.board_identity] |
| 42 | runner = self.log.get_runner(cmd[0], sys.stdout) |
| 43 | runner.run(cmd) |
| 44 | runner.close() |
| 45 | self.log.status_pass('OK') |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 46 | |
| 47 | def get_spawn(self): |
Stephen Warren | 75e731e | 2016-01-26 13:41:30 -0700 | [diff] [blame] | 48 | """Connect to a fresh U-Boot instance. |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 49 | |
| 50 | The target board is reset, so that U-Boot begins running from scratch. |
| 51 | |
| 52 | Args: |
| 53 | None. |
| 54 | |
| 55 | Returns: |
| 56 | A u_boot_spawn.Spawn object that is attached to U-Boot. |
Stephen Warren | 75e731e | 2016-01-26 13:41:30 -0700 | [diff] [blame] | 57 | """ |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 58 | |
| 59 | args = [self.config.board_type, self.config.board_identity] |
| 60 | s = Spawn(['u-boot-test-console'] + args) |
| 61 | |
Simon Glass | f1b1bb8 | 2024-11-12 07:13:17 -0700 | [diff] [blame^] | 62 | if self.config.use_running_system: |
| 63 | self.log.action('Connecting to board without reset') |
| 64 | else: |
| 65 | try: |
| 66 | self.log.action('Resetting board') |
| 67 | cmd = ['u-boot-test-reset'] + args |
| 68 | runner = self.log.get_runner(cmd[0], sys.stdout) |
| 69 | runner.run(cmd) |
| 70 | runner.close() |
| 71 | except: |
| 72 | s.close() |
| 73 | raise |
Stephen Warren | 10e5063 | 2016-01-15 11:15:24 -0700 | [diff] [blame] | 74 | |
| 75 | return s |
Simon Glass | dcb97ed | 2024-11-12 07:13:16 -0700 | [diff] [blame] | 76 | |
| 77 | def close(self): |
| 78 | super().close() |
| 79 | |
| 80 | self.log.action('Releasing board') |
| 81 | args = [self.config.board_type, self.config.board_identity] |
| 82 | cmd = ['u-boot-test-release'] + args |
| 83 | runner = self.log.get_runner(cmd[0], sys.stdout) |
| 84 | runner.run(cmd) |
| 85 | runner.close() |