# Copyright (c) 2012 The Chromium OS Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import logging from autotest_lib.client.common_lib import error from autotest_lib.server.cros.faft.firmware_test import FirmwareTest class firmware_ECPeci(FirmwareTest): """ Servo based EC PECI test. """ version = 1 # Repeat read count READ_COUNT = 200 def initialize(self, host, cmdline_args): super(firmware_ECPeci, self).initialize(host, cmdline_args) # Don't bother if there is no Chrome EC. if not self.check_ec_capability(['peci']): raise error.TestNAError("Nothing needs to be tested on this device") self.ec.send_command("chan 0") def cleanup(self): try: self.ec.send_command("chan 0xffffffff") except Exception as e: logging.error("Caught exception: %s", str(e)) super(firmware_ECPeci, self).cleanup() def _check_read(self): """Read CPU temperature through PECI. Raises: error.TestFail: Raised when read fails. """ t = int(self.ec.send_command_get_output("pecitemp", ["CPU temp = (\d+) K"])[0][1]) if t < 273 or t > 400: raise error.TestFail("Abnormal CPU temperature %d K" % t) def run_once(self): """Execute the main body of the test. """ if not self.check_ec_capability(['peci']): raise error.TestNAError("Nothing needs to be tested on this device") logging.info("Reading PECI CPU temperature for %d times.", self.READ_COUNT) for _ in xrange(self.READ_COUNT): self._check_read()