diff -r 000000000000 -r 3553901f7fa8 telephonyprotocols/pdplayer/umts/spudfsm/src/tpdpstategettingnegqos.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/telephonyprotocols/pdplayer/umts/spudfsm/src/tpdpstategettingnegqos.cpp Tue Feb 02 01:41:59 2010 +0200 @@ -0,0 +1,62 @@ +// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "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: +// Retrieving Negotiated QoS state +// +// + +/** + @file + @internalComponent +*/ + +#include +#include "tpdpstates.h" +#include "spudfsmdebuglogger.h" +#include "pdpfsmnmspace.h" +#include "cpdpfsm.h" + +TInt TPdpStateGettingNegQoS::Input (CPdpFsm& aFsm, const TInt aOperation, const TInt aErrorCode) + { + SPUDFSMVERBOSE_FNLOG("TPdpStateGettingNegQoS::Input()"); + SPUDFSMVERBOSE_LOG2(_L("aOperation : %S(%d)"), LogOperation(aFsm, aOperation), aOperation); + + switch (aOperation) + { + case SpudMan::EGetNegQoS: + EtelDriverInput(aFsm, EtelDriver::ENegQoSGet); + return KErrNone; + + case PdpFsm::EPdpNegQoSRetrieved: + SPUDFSMVERBOSE_LOG(_L("*** SUCCESS ***")); + aFsm.ChangeStateToOpen(); + SpudManNotify(aFsm, KGetNegQoSEvent, KErrNone); + return KErrNone; + + case PdpFsm::EPdpNegQoSRetrievedFailed: + SPUDFSMVERBOSE_LOG(_L("*** FAILURE ***")); + // As far as everybody is concerned, the context was activated: + // This makes it eligible for certain events. + // We have to move to Open state, so that that we can handle any operations + // on the activated PDP context correctly. + aFsm.ChangeStateToOpen(); + SpudManNotify(aFsm, KGetNegQoSEvent, aErrorCode); + return KErrNone; + } + + // default error handling + return TPdpState::Input(aFsm, aOperation, aErrorCode); + } + + +