# Copyright (c) 2013 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 import pm_errors import register_machine from autotest_lib.client.cros.cellular import mm1_constants class RegisterCdmaMachine(register_machine.RegisterMachine): """ RegisterCdmaMachine handles the CDMA specific state transitions involved in bringing the modem to the REGISTERED state. """ def Cancel(self): """ Cancel the current machine. Overwritten from parent class. """ logging.info('RegisterCdmaMachine: Canceling register.') super(RegisterCdmaMachine, self).Cancel() state = self._modem.Get(mm1_constants.I_MODEM, 'State') reason = mm1_constants.MM_MODEM_STATE_CHANGE_REASON_USER_REQUESTED if state == mm1_constants.MM_MODEM_STATE_SEARCHING: logging.info('RegisterCdmaMachine: Setting state to ENABLED.') self._modem.ChangeState(mm1_constants.MM_MODEM_STATE_ENABLED, reason) self._modem.SetRegistrationState( mm1_constants.MM_MODEM_CDMA_REGISTRATION_STATE_UNKNOWN) self._modem.register_step = None if self._raise_cb: self._raise_cb( pm_errors.MMCoreError(pm_errors.MMCoreError.CANCELLED, 'Cancelled')) def _GetModemStateFunctionMap(self): return { mm1_constants.MM_MODEM_STATE_ENABLED: RegisterCdmaMachine._HandleEnabledState, mm1_constants.MM_MODEM_STATE_SEARCHING: RegisterCdmaMachine._HandleSearchingState } def _HandleEnabledState(self): logging.info('RegisterCdmaMachine: Modem is ENABLED.') logging.info('RegisterCdmaMachine: Setting state to SEARCHING.') self._modem.ChangeState( mm1_constants.MM_MODEM_STATE_SEARCHING, mm1_constants.MM_MODEM_STATE_CHANGE_REASON_USER_REQUESTED) return True def _HandleSearchingState(self): logging.info('RegisterCdmaMachine: Modem is SEARCHING.') network = self._modem.GetHomeNetwork() if not network: logging.info('RegisterCdmaMachine: No network available.') logging.info('RegisterCdmaMachine: Setting state to ENABLED.') self._modem.ChangeState(mm1_constants.MM_MODEM_STATE_ENABLED, mm1_constants.MM_MODEM_STATE_CHANGE_REASON_UNKNOWN) if self._raise_cb: self._raise_cb( pm_errors.MMMobileEquipmentError( pm_errors.MMMobileEquipmentError.NO_NETWORK, 'No networks were found to register.')) self._modem.register_step = None return False logging.info( 'RegisterMachineCdma: Registering to network: ' + str(network)) logging.info('RegisterMachineCdma: Setting state to REGISTERED.') self._modem.SetRegistered(network) self._modem.ChangeState( mm1_constants.MM_MODEM_STATE_REGISTERED, mm1_constants.MM_MODEM_STATE_CHANGE_REASON_USER_REQUESTED) self._modem.register_step = None if self._return_cb: self._return_cb() return False