diff -r 000000000000 -r c40eb8fe8501 wlan_bearer/wlanengine/wlan_common/wlanengine_common_3.1/src/core_operation_unload_drivers.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/wlan_bearer/wlanengine/wlan_common/wlanengine_common_3.1/src/core_operation_unload_drivers.cpp Tue Feb 02 02:03:13 2010 +0200 @@ -0,0 +1,118 @@ +/* +* Copyright (c) 2005-2010 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of the License "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: Statemachine for unloading drivers +* +*/ + +/* +* %version: 11 % +*/ + +#include "core_operation_unload_drivers.h" +#include "core_operation_release.h" +#include "core_server.h" +#include "am_debug.h" + +// ======== MEMBER FUNCTIONS ======== + +// --------------------------------------------------------------------------- +// --------------------------------------------------------------------------- +// +core_operation_unload_drivers_c::core_operation_unload_drivers_c( + u32_t request_id, + core_server_c* server, + abs_core_driverif_c* drivers, + abs_core_server_callback_c* adaptation ) : + core_operation_base_c( core_operation_unload_drivers, request_id, server, drivers, adaptation, + core_base_flag_only_one_instance ) + { + DEBUG( "core_operation_unload_drivers_c::core_operation_unload_drivers_c()" ); + } + +// --------------------------------------------------------------------------- +// --------------------------------------------------------------------------- +// +core_operation_unload_drivers_c::~core_operation_unload_drivers_c() + { + DEBUG( "core_operation_unload_drivers_c::~core_operation_unload_drivers_c()" ); + } + +// --------------------------------------------------------------------------- +// --------------------------------------------------------------------------- +// +core_error_e core_operation_unload_drivers_c::next_state() + { + DEBUG( "core_operation_unload_drivers_c::next_state()" ); + switch( operation_state_m ) + { + case core_state_init: + { + DEBUG( "- core_state_init" ); + if( server_m->get_core_settings().is_connected() ) + { + DEBUG( "core_operation_unload_drivers_c::next_state() - still connected, notifying state change" ); + // connection is open, first send state change notification + u8_t buf[5]; + buf[0] = static_cast( core_connection_state_notconnected ); + buf[1] = static_cast( core_release_reason_hw_failure ); + adaptation_m->notify( + core_notification_connection_state_changed, + sizeof( buf ), + buf ); + + server_m->get_connection_data()->set_last_connection_state( + core_connection_state_notconnected ); + + // Delay unloading a little bit so that data pipe can be + // disconnected from adaptation side + return asynch_goto( core_state_notifying, DELAY_FOR_AGENT ); + } + else + { + // not connected, jump directly to unloading drivers + return goto_state( core_state_releasing ); + } + } + case core_state_notifying: + { + DEBUG( "core_operation_connect_c::next_state() - notification sent, releasing" ); + core_operation_base_c* operation = new core_operation_release_c( + request_id_m, + server_m, + drivers_m, + adaptation_m, + core_release_reason_hw_failure ); + operation_state_m = core_state_releasing; + return run_sub_operation( operation ); + } + case core_state_releasing: + { + DEBUG( "core_operation_unload_drivers_c::next_state() - unloading drivers" ); + drivers_m->unload_drivers( request_id_m ); + operation_state_m = core_state_unloading; + break; + } + case core_state_unloading: + { + DEBUG( "core_operation_unload_drivers_c::next_state() - unloading done" ); + server_m->get_core_settings().set_driver_state( false_t ); + return core_error_ok; + } + default: + { + ASSERT( false_t ); + } + } + return core_error_request_pending; + }