# 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()