#!/usr/bin/python
#
# Copyright (c) 2013 The Chromium 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, os
from autotest_lib.client.bin import test, utils
from autotest_lib.client.common_lib import error
from autotest_lib.client.cros.power import power_utils
class security_SMMLocked(test.test):
"""
Verify SMM has SMRAM unmapped and that the SMM registers are locked.
"""
version = 1
executable = 'smm'
def setup(self):
os.chdir(self.srcdir)
utils.make(self.executable)
def run_once(self):
errors = 0
cpu_arch = utils.get_cpu_arch()
if cpu_arch == "arm":
logging.debug('ok: skipping SMM test for %s.', cpu_arch)
return
cpu_arch = power_utils.get_x86_cpu_arch()
if cpu_arch == 'Stoney':
# The SMM registers (MSRC001_0112 and MSRC001_0113) can be
# locked from being altered by setting MSRC001_0015[SmmLock].
# Bit 0 : 1=SMM code in the ASeg and TSeg range and the SMM
# registers are read-only and SMI interrupts are
# not intercepted in SVM for Stoney.
Stoney_SMMLock = {'0xc0010015': [('0', 1)]}
self._registers = power_utils.Registers()
errors = self._registers.verify_msr(Stoney_SMMLock)
else:
r = utils.run("%s/%s" % (self.srcdir, self.executable),
stdout_tee=utils.TEE_TO_LOGS,
stderr_tee=utils.TEE_TO_LOGS,
ignore_status=True)
if r.exit_status != 0 or len(r.stderr) > 0:
raise error.TestFail(r.stderr)
if 'skipping' in r.stdout:
logging.debug(r.stdout)
return
if 'ok' not in r.stdout:
raise error.TestFail(r.stdout)
if errors:
logging.error('Test Failed for %s', cpu_arch)
raise error.TestFail(r.stdout)