u_boot_console_sandbox.py 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. # Copyright (c) 2015 Stephen Warren
  2. # Copyright (c) 2015-2016, NVIDIA CORPORATION. All rights reserved.
  3. #
  4. # SPDX-License-Identifier: GPL-2.0
  5. # Logic to interact with the sandbox port of U-Boot, running as a sub-process.
  6. import time
  7. from u_boot_spawn import Spawn
  8. from u_boot_console_base import ConsoleBase
  9. class ConsoleSandbox(ConsoleBase):
  10. """Represents a connection to a sandbox U-Boot console, executed as a sub-
  11. process."""
  12. def __init__(self, log, config):
  13. """Initialize a U-Boot console connection.
  14. Args:
  15. log: A multiplexed_log.Logfile instance.
  16. config: A "configuration" object as defined in conftest.py.
  17. Returns:
  18. Nothing.
  19. """
  20. super(ConsoleSandbox, self).__init__(log, config, max_fifo_fill=1024)
  21. def get_spawn(self):
  22. """Connect to a fresh U-Boot instance.
  23. A new sandbox process is created, so that U-Boot begins running from
  24. scratch.
  25. Args:
  26. None.
  27. Returns:
  28. A u_boot_spawn.Spawn object that is attached to U-Boot.
  29. """
  30. return Spawn([self.config.build_dir + '/u-boot'])
  31. def kill(self, sig):
  32. """Send a specific Unix signal to the sandbox process.
  33. Args:
  34. sig: The Unix signal to send to the process.
  35. Returns:
  36. Nothing.
  37. """
  38. self.log.action('kill %d' % sig)
  39. self.p.kill(sig)
  40. def validate_exited(self):
  41. """Determine whether the sandbox process has exited.
  42. If required, this function waits a reasonable time for the process to
  43. exit.
  44. Args:
  45. None.
  46. Returns:
  47. Boolean indicating whether the process has exited.
  48. """
  49. p = self.p
  50. self.p = None
  51. for i in xrange(100):
  52. ret = not p.isalive()
  53. if ret:
  54. break
  55. time.sleep(0.1)
  56. p.close()
  57. return ret