wlan_bearer/wlanengine/wlan_common/wlanengine_common_3.1/src/core_operation_get_statistics.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 02:03:13 +0200
changeset 0 c40eb8fe8501
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* Copyright (c) 2006-2007 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 getting the packet statistics.
*
*/


#include "core_operation_get_statistics.h"
#include "core_roam_metrics.h"
#include "core_server.h"
#include "am_debug.h"

// ======== MEMBER FUNCTIONS ========

// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------------
//
core_operation_get_statistics_c::core_operation_get_statistics_c(
    u32_t request_id,
    core_server_c* server,
    abs_core_driverif_c* drivers,
    abs_core_server_callback_c* adaptation,
    core_packet_statistics_s& statistics ) :
    core_operation_base_c( core_operation_get_statistics, request_id, server, drivers, adaptation,
        core_base_flag_none ),
    client_statistics_m( statistics )
    {
    DEBUG( "core_operation_get_statistics_c::core_operation_get_statistics_c()" );
    }

// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------------
//
core_operation_get_statistics_c::~core_operation_get_statistics_c()
    {
    DEBUG( "core_operation_get_statistics_c::~core_operation_get_statistics_c()" );
    }
    
// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------------
//
core_error_e core_operation_get_statistics_c::next_state()
    {
    DEBUG( "core_operation_get_statistics_c::next_state()" );    

    switch ( operation_state_m )
        {
        case core_state_init:
            {
            server_m->get_core_settings().roam_metrics().trace_current_roam_metrics();

            if ( !server_m->get_core_settings().is_connected() )
                {
                DEBUG( "core_operation_connect_c::next_state() - not connected, returning cached packet statistics" );

                client_statistics_m = server_m->get_core_settings().connection_statistics();

                return core_error_ok;
                }

            operation_state_m = core_state_req_packet_statistics;

            DEBUG( "core_operation_get_statistics_c::next_state() - requesting packet statistics from drivers" );

            drivers_m->get_packet_statistics(
                request_id_m,
                current_statistics_m );        

            break;
            }
        case core_state_req_packet_statistics:
            {
            core_packet_statistics_s statistics =
                server_m->get_core_settings().connection_statistics();

            DEBUG( "core_operation_get_statistics_c::next_state() - previous packet statistics:" );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_frames:           %u",
                statistics.tx_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - rx_frames:           %u",
                statistics.rx_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_multicast_frames: %u",
                statistics.tx_multicast_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - rx_multicast_frames: %u",
                statistics.rx_multicast_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - fcs_errors:          %u",
                statistics.fcs_errors );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_retries:          %u",
                statistics.tx_retries );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_errors:           %u",
                statistics.tx_errors );

            server_m->get_core_settings().update_connection_statistics(
                current_statistics_m );

            client_statistics_m = server_m->get_core_settings().connection_statistics();

            DEBUG( "core_operation_get_statistics_c::next_state() - current packet statistics:" );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_frames:           %u",
                client_statistics_m.tx_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - rx_frames:           %u",
                client_statistics_m.rx_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_multicast_frames: %u",
                client_statistics_m.tx_multicast_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - rx_multicast_frames: %u",
                client_statistics_m.rx_multicast_frames );
            DEBUG1( "core_operation_get_statistics_c::next_state() - fcs_errors:          %u",
                client_statistics_m.fcs_errors );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_retries:          %u",
                client_statistics_m.tx_retries );
            DEBUG1( "core_operation_get_statistics_c::next_state() - tx_errors:           %u",
                client_statistics_m.tx_errors );

            return core_error_ok;
            }
        default:
            {
            ASSERT( false_t );
            }
        }

    return core_error_request_pending;
    }