1# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5import logging
6
7from autotest_lib.server.cros import vboot_constants as vboot
8from autotest_lib.server.cros.faft.firmware_test import FirmwareTest
9
10
11class firmware_RONormalBoot(FirmwareTest):
12    """
13    Servo based firmware RO normal boot test.
14
15    This test only runs on the firmware on which its firmware preamble flags
16    have USE_RO_NORMAL enabled. Since we always build and pack a workable
17    RW firmware in the RW firmware body section, although it is not used when
18    the USE_RO_NORMAL flag is enabled.
19
20    On runtime, the test disables the RO normal boot flag in the current
21    firmware and checks its next boot result.
22    """
23    version = 1
24
25    def initialize(self, host, cmdline_args, dev_mode=False, ec_wp=None):
26        super(firmware_RONormalBoot, self).initialize(host, cmdline_args,
27                                                      ec_wp=ec_wp)
28        self.backup_firmware()
29        self.switcher.setup_mode('dev' if dev_mode else 'normal')
30        self.setup_usbkey(usbkey=False)
31
32    def cleanup(self):
33        try:
34            if self.is_firmware_saved():
35                self.restore_firmware()
36        except Exception as e:
37            logging.error("Caught exception: %s", str(e))
38        super(firmware_RONormalBoot, self).cleanup()
39
40    def run_once(self):
41        flags = self.faft_client.bios.get_preamble_flags('a')
42        if flags & vboot.PREAMBLE_USE_RO_NORMAL == 0:
43            logging.info('The firmware USE_RO_NORMAL flag is disabled.')
44            return
45
46        logging.info("Disable the RO normal boot flag.")
47        self.check_state((self.checkers.ro_normal_checker, 'A'))
48        self.faft_client.bios.set_preamble_flags(('a',
49                                      flags ^ vboot.PREAMBLE_USE_RO_NORMAL))
50        self.switcher.mode_aware_reboot()
51
52        logging.info("Expected TwoStop boot, restore the original flags.")
53        self.check_state((lambda: self.checkers.ro_normal_checker('A',
54                                                                  twostop=True)))
55        self.faft_client.bios.set_preamble_flags('a', flags)
56        self.switcher.mode_aware_reboot()
57        self.check_state((self.checkers.ro_normal_checker, 'A'))
58