1#!/usr/bin/python 2# 3# Copyright (c) 2013 The Chromium Authors. All rights reserved. 4# Use of this source code is governed by a BSD-style license that can be 5# found in the LICENSE file. 6 7import logging, os 8from autotest_lib.client.bin import test, utils 9from autotest_lib.client.common_lib import error 10from autotest_lib.client.cros.power import power_utils 11 12class security_SMMLocked(test.test): 13 """ 14 Verify SMM has SMRAM unmapped and that the SMM registers are locked. 15 """ 16 version = 1 17 executable = 'smm' 18 19 def setup(self): 20 os.chdir(self.srcdir) 21 utils.make(self.executable) 22 23 def run_once(self): 24 errors = 0 25 cpu_arch = utils.get_cpu_arch() 26 if cpu_arch == "arm": 27 logging.debug('ok: skipping SMM test for %s.', cpu_arch) 28 return 29 30 cpu_arch = power_utils.get_x86_cpu_arch() 31 if cpu_arch == 'Stoney': 32 # The SMM registers (MSRC001_0112 and MSRC001_0113) can be 33 # locked from being altered by setting MSRC001_0015[SmmLock]. 34 # Bit 0 : 1=SMM code in the ASeg and TSeg range and the SMM 35 # registers are read-only and SMI interrupts are 36 # not intercepted in SVM for Stoney. 37 Stoney_SMMLock = {'0xc0010015': [('0', 1)]} 38 self._registers = power_utils.Registers() 39 errors = self._registers.verify_msr(Stoney_SMMLock) 40 else: 41 r = utils.run("%s/%s" % (self.srcdir, self.executable), 42 stdout_tee=utils.TEE_TO_LOGS, 43 stderr_tee=utils.TEE_TO_LOGS, 44 ignore_status=True) 45 if r.exit_status != 0 or len(r.stderr) > 0: 46 raise error.TestFail(r.stderr) 47 if 'skipping' in r.stdout: 48 logging.debug(r.stdout) 49 return 50 if 'ok' not in r.stdout: 51 raise error.TestFail(r.stdout) 52 if errors: 53 logging.error('Test Failed for %s', cpu_arch) 54 raise error.TestFail(r.stdout) 55