blob: 7dac9031682029304bc60449c6675f6bb4a8f57a [file] [log] [blame]
# Copyright (c) 2011 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.
# This is a hardware test for EC. The test uses ectool to check if the EC can
# receive message from host and send expected reponse back to host. It also
# checks basic EC functionality, such as FAN and temperature sensor.
import re
import time
import logging
from autotest_lib.client.bin import test, utils
from autotest_lib.client.common_lib import error
class ECControl(object):
HELLO_RE = "EC says hello"
GET_FANSPEED_RE = "Current fan RPM: ([0-9]*)"
SET_FANSPEED_RE = "Fan target RPM set."
TEMP_SENSOR_RE = "Reading temperature...([0-9]*)"
TOGGLE_AUTO_FAN_RE = "Automatic fan control is now on"
BATTERY_RE = "Cycle count"
LIGHTBAR_RE = "^ 05\s+3f\s+3f$"
def ec_command(self, cmd):
full_cmd = 'ectool %s' % cmd
result = utils.system_output(full_cmd)'Command: %s' % full_cmd)'Result: %s' % result)
return result
def hello(self):
response = self.ec_command('hello')
return (, response) is not None)
def auto_fan_ctrl(self):
response = self.ec_command('autofanctrl')'Turned on auto fan control.')
return (, response) is not None)
def get_fanspeed(self):
response = self.ec_command('pwmgetfanrpm')
match =, response).group(1)'Fan speed: %s', match)
if match:
return int(match)
raise error.TestError('Unable to read fan speed')
def set_fanspeed(self, rpm):
response = self.ec_command('pwmsetfanrpm %d' % rpm)'Set fan speed: %d', rpm)
return (, response) is not None)
def get_temperature(self, idx):
response = self.ec_command('temps %d' % idx)
match =, response).group(1)
if match:
return int(match)
raise error.TestError('Unable to read temperature sensor %d' % idx)
def get_battery(self):
response = self.ec_command('battery')
return (, response) is not None)
def get_lightbar(self):
self.ec_command('lightbar on')
self.ec_command('lightbar init')
self.ec_command('lightbar 4 255 255 255')
response = self.ec_command('lightbar')
self.ec_command('lightbar off')
return (, response, re.MULTILINE) is not None)
class hardware_EC(test.test):
version = 1
def run_once(self,
ec = ECControl()
if not ec.hello():
raise error.TestError('EC communication failed')
if test_fan:
max_reading = ec.get_fanspeed()
if max_reading == 0:
raise error.TestError('Unable to start fan')
ec.set_fanspeed(max_reading / 2)
current_reading = ec.get_fanspeed()
# Sometimes the actual fan speed is close but not equal to
# the target speed, so we add some error margin here.
if (current_reading < max_reading / 2 - fan_rpm_error_margin or
current_reading >= max_reading + fan_rpm_error_margin):
raise error.TestError('Unable to set fan speed')
if temp_sensor_to_test is None:
temp_sensor_to_test = list(range(num_temp_sensor))
for idx in temp_sensor_to_test:
temperature = ec.get_temperature(idx) - 273
if temperature < 0 or temperature > 100:
raise error.TestError(
'Abnormal temperature reading on sensor %d' % idx);
if test_battery and not ec.get_battery():
raise error.TestError('Battery communication failed')
if test_lightbar and not ec.get_lightbar():
raise error.TestError('Lightbar communication failed')