datasourcemodules/gpspositioningmodule/lbsagpspsy/src/cagpspositioner.cpp
changeset 0 9cfd9a3ee49c
equal deleted inserted replaced
-1:000000000000 0:9cfd9a3ee49c
       
     1 // Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
       
     2 // All rights reserved.
       
     3 // This component and the accompanying materials are made available
       
     4 // under the terms of "Eclipse Public License v1.0"
       
     5 // which accompanies this distribution, and is available
       
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     7 //
       
     8 // Initial Contributors:
       
     9 // Nokia Corporation - initial contribution.
       
    10 //
       
    11 // Contributors:
       
    12 //
       
    13 // Description:
       
    14 //
       
    15 
       
    16 /**
       
    17  @file
       
    18  @InternalComponent
       
    19 */
       
    20 
       
    21 #include <e32base.h>
       
    22 #include <lbs/epos_mpositionerstatus.h>
       
    23 #include <ecom/implementationproxy.h>
       
    24 #include <lbssatellite.h>
       
    25 #include <lbs/lbsadmin.h>
       
    26 
       
    27 #include "cagpspositioner.h"
       
    28 #include "agpspsy.hrh"
       
    29 #include "agpspsypanic.h"
       
    30 #include "cpositionerq.h"
       
    31 #include "crequesthandler.h"
       
    32 #include "cagpsenvironment.h"
       
    33 #include "utilfunctions.h"
       
    34 #include "tagpsrequestparameters.h"
       
    35 #include "agpsrequestconstants.h"
       
    36 #include "psylogging.h"
       
    37 #include "psypanic.h"
       
    38 
       
    39 /*
       
    40 * 
       
    41 */
       
    42 CAgpsPositioner::CAgpsPositioner()
       
    43     {
       
    44 	iState = ERequestStateInitial;
       
    45 	iTerminalAssisted = EFalse;
       
    46     }
       
    47 
       
    48 // -----------------------------------------------------------------------------
       
    49 // Destructor
       
    50 // -----------------------------------------------------------------------------
       
    51 //
       
    52 CAgpsPositioner::~CAgpsPositioner()
       
    53     {
       
    54 	TRACESTRING("CAgpsPositioner::~CAgpsPositioner")
       
    55 
       
    56 	if(iEnvironment)
       
    57 		{
       
    58 		iEnvironment->UnregisterPSY(this);
       
    59 		}
       
    60 	
       
    61 	iNetRegStatus.Close();
       
    62     }
       
    63 
       
    64 /**
       
    65  * Creates a new instance of a CPositioner implementation.
       
    66  *
       
    67  * @param aConstructionParameters Construction parameters for CPositioner.
       
    68  * @return The positioner implementation.
       
    69  */
       
    70 CAgpsPositioner* CAgpsPositioner::NewL(TAny* aConstructionParameters)
       
    71     {
       
    72     CAgpsPositioner* self = new( ELeave ) CAgpsPositioner;
       
    73 
       
    74     CleanupStack::PushL( self );
       
    75     self->ConstructL(aConstructionParameters);
       
    76     CleanupStack::Pop(self);
       
    77 
       
    78     return self;
       
    79     }
       
    80 
       
    81 /**
       
    82  * 2nd phase constructor
       
    83  *
       
    84  * @param aConstructionParameters Construction parameters for CPositioner.
       
    85  */
       
    86 void CAgpsPositioner::ConstructL(TAny* aConstructionParameters)
       
    87 	{
       
    88 	TRACESTRING("CAgpsPositioner::ConstructL")
       
    89 
       
    90 	// Must call BaseConstructL first thing during construction.
       
    91 	BaseConstructL(aConstructionParameters);
       
    92 
       
    93 	iEnvironment = CAgpsEnvironment::NewL();
       
    94 	iEnvironment->RegisterPSYL(this);
       
    95 	iEnvironment->GetEnvCriteriaL(iCriteria, TUid::Uid(KPosAGPSPSYImplUid));
       
    96 	iInactivityTimeout = iEnvironment->GetInactivityTimeoutL(TUid::Uid(KPosAGPSPSYImplUid));
       
    97 	iRequestHandler = iEnvironment->GetRequestHandler();
       
    98 
       
    99 	// Get the request timeout from the LS:
       
   100 	if(iEnvironment->ProfileInUse())	// default timeout was taken from profile, so let LS know
       
   101 		{
       
   102 		TPositionQuality quality;
       
   103 		iCriteria.GetRequiredQuality(quality);
       
   104 		iTimeOutInterval = quality.TimeToFirstFix();	
       
   105 		SetPsyDefaultUpdateTimeOut(iTimeOutInterval);
       
   106 		}	    
       
   107 
       
   108 	iNetRegStatus.OpenL();
       
   109 	}
       
   110 
       
   111 /**
       
   112 * Initiate a tracking session.
       
   113 *
       
   114 * @param aInterval Interval for position requests.
       
   115 */
       
   116 void CAgpsPositioner::StartTrackingL(const TTimeIntervalMicroSeconds& aInterval)
       
   117     {
       
   118 	TRACESTRING2("CAdaptationPositioner::StartTrackingL, interval = %d", aInterval)
       
   119 
       
   120 	TTime timeNow;
       
   121     
       
   122     TTime trackingTime = LbsTimerUtils::AddUpInt64TimersWithOverflowCheck(iTargetTime, aInterval);
       
   123 	timeNow.UniversalTime();
       
   124     
       
   125 	iTrackingInterval = aInterval;
       
   126 	    
       
   127     if(! (trackingTime < timeNow)) // if this is not a default proxy call to StartTracking
       
   128 	    {
       
   129     	TRACESTRING("Non-DefProxy Start")
       
   130 	    SetupTrackingRequestL();
       
   131         SetAGPSMode();
       
   132 		iRequestHandler->SubmitNewRequestL(this);
       
   133 	    }
       
   134     }
       
   135     
       
   136 /**
       
   137 * Requests position info asynchronously. 
       
   138 *
       
   139 * @param aPosInfo A reference to a position info object. This object
       
   140 *                 must be in scope until the request has completed.
       
   141 *                 The position (TPosition) of this position info object
       
   142 *                 must be in WGS84 geodetic datum.
       
   143 * @param aClientStatus The request status
       
   144 *
       
   145 */
       
   146 void CAgpsPositioner::NotifyPositionUpdate(TPositionInfoBase& aPosInfo, TRequestStatus& aClientStatus)
       
   147     {
       
   148     TRACESTRING("CAdaptationPositioner::NotifyPositionUpdate")
       
   149 
       
   150 	// we're about to submit a new request, so stop warmdown timer if running: 
       
   151 	StopMaxFixTimer();
       
   152     StopWarmDownTimer();
       
   153 	
       
   154     // Clear position info
       
   155     ClearPositionInfo(aPosInfo);
       
   156     
       
   157     aClientStatus = KRequestPending;
       
   158     iPosInfo = &aPosInfo;
       
   159     iClientStatus = &aClientStatus;
       
   160     
       
   161     if(!UseLastLocation(aPosInfo)) // Attempt to complete the client immediately with an old position
       
   162 		{
       
   163 		TTime timeNow;
       
   164 		timeNow.UniversalTime();
       
   165 	    iActive = ETrue;
       
   166 	
       
   167 		GetUpdateTimeOut(iTimeOutInterval);
       
   168 
       
   169 		TDateTime debugTime = timeNow.DateTime();
       
   170 		TRACESTRING38("Time Now = %d.%d", debugTime.Second(), debugTime.MicroSecond());
       
   171 		
       
   172 		// Add on the lag time
       
   173 		if(iTerminalAssisted)
       
   174 			{
       
   175         	CAgpsEnvironment* agpsEnvironment = static_cast<CAgpsEnvironment*>(iEnvironment);
       
   176         	ExtendUpdateTimeOut(agpsEnvironment->GetFinalNetPositionLag());
       
   177 			}
       
   178 				
       
   179 		if( !IsTracking() ||
       
   180 			(IsTracking() && (iTargetTime <= timeNow)) )
       
   181 			{
       
   182 			iTargetTime.UniversalTime();
       
   183 	        TRACESTRING("CAdaptationPositioner::NotifyPositionUpdate submitting new request")
       
   184 
       
   185 	        SetAGPSMode();
       
   186 	        
       
   187 	        // (re)start maxfix timer so that we know when the module has stopped trying	        
       
   188 	        TRAPD(error,StartMaxFixTimerL());	 
       
   189 	        if(!error)
       
   190 	        	{
       
   191 	        	TRAP(error, iRequestHandler->SubmitNewRequestL(this));
       
   192 	        	}
       
   193 	        if(error)
       
   194 		        {
       
   195 				UpdateFailed(error);
       
   196 		        }
       
   197 			}
       
   198 			
       
   199 		debugTime = iTargetTime.DateTime();
       
   200 		TRACESTRING38("Target Time = %d.%d", debugTime.Second(), debugTime.MicroSecond());
       
   201 		}
       
   202     }
       
   203 
       
   204 
       
   205 void CAgpsPositioner::SetModuleId(TPositionInfoBase* aPosInfo)
       
   206 	{
       
   207 	if(aPosInfo)
       
   208 		{
       
   209 		aPosInfo->SetModuleId(TUid::Uid(KPosAGPSPSYImplUid)); // Use the PSY module Id rather than the AGPS managers
       
   210 		}
       
   211 	}
       
   212 
       
   213 const TRequestParameters* CAgpsPositioner::PositionRequestParams()
       
   214 	{
       
   215 	TBool state = (iState == ERequestStateInitial);
       
   216 	
       
   217 	iRequestParameters.iTargetTime = iTargetTime;
       
   218 	iRequestParameters.iTimeForFix = iTimeOutInterval;
       
   219 	iRequestParameters.iCriteria = iCriteria;
       
   220 	iRequestParameters.iNewClient = state;
       
   221 	iRequestParameters.iTracking = IsTracking();
       
   222 	iRequestParameters.iAGPSMode = iAGPSMode;
       
   223 	
       
   224 	return &iRequestParameters;
       
   225 	}
       
   226 	
       
   227 /**
       
   228 * Checks for a transition into TA mode and extends the max fix time to allow for 
       
   229 * the final network position arriving  
       
   230 *
       
   231 * @param aMode The mode of the last update.
       
   232 *
       
   233 */
       
   234 void CAgpsPositioner::ModeUpdate(TUint aMode)
       
   235 	{
       
   236     TRACESTRING("CPositionerSubSession::CheckMode()")
       
   237 
       
   238 	if ( ((aMode & RLbsPositionUpdates::EGpsModeTerminalAssisted) == RLbsPositionUpdates::EGpsModeTerminalAssisted) 
       
   239 		&& !iTerminalAssisted )
       
   240 		{
       
   241 		iTerminalAssisted = ETrue;
       
   242 		CAgpsEnvironment* agpsEnvironment = static_cast<CAgpsEnvironment*>(iEnvironment);
       
   243 		ExtendUpdateTimeOut(agpsEnvironment->GetFinalNetPositionLag());
       
   244 		}
       
   245 	else if (((aMode & RLbsPositionUpdates::EGpsModeTerminalAssisted) != RLbsPositionUpdates::EGpsModeTerminalAssisted))
       
   246 		{
       
   247 		iTerminalAssisted = EFalse;
       
   248 		}
       
   249 	}
       
   250 
       
   251 void CAgpsPositioner::SetAGPSMode()
       
   252 	{
       
   253     TRACESTRING("CPositionerSubSession::GpsMode()")
       
   254 	
       
   255     CLbsAdmin::TGpsMode mode = CLbsAdmin::EGpsModeUnknown;
       
   256 	iAGPSMode = KAutonomousMode;
       
   257 	
       
   258 	RLbsNetworkRegistrationStatus::TLbsNetworkRegistrationStatus netRegStatus(RLbsNetworkRegistrationStatus::ENetworkRegistrationUnknown);
       
   259 	
       
   260 	// Read the current network registration status
       
   261 	TInt err = iNetRegStatus.GetNetworkRegistrationStatus(netRegStatus);
       
   262 
       
   263 	if (err == KErrNone)
       
   264 		{
       
   265 		// Read the admin setting
       
   266 		switch (netRegStatus)
       
   267 			{
       
   268 			case RLbsNetworkRegistrationStatus::ERegisteredHomeNetwork:
       
   269 				{
       
   270 				err = iEnvironment->Admin().Get(KLbsSettingHomeGpsMode, mode);
       
   271 				break;
       
   272 				}
       
   273 			case RLbsNetworkRegistrationStatus::ERegisteredRoamingNetwork:
       
   274 			case RLbsNetworkRegistrationStatus::ENotRegistered:
       
   275 				{
       
   276 				err = iEnvironment->Admin().Get(KLbsSettingRoamingGpsMode, mode);
       
   277 				break;
       
   278 				}		
       
   279 			case RLbsNetworkRegistrationStatus::ENetworkRegistrationUnknown:
       
   280 			default:
       
   281 				{
       
   282 				TRACESTRING("Unrecognised TLbsNetworkRegistrationStatus")
       
   283 				break;
       
   284 				}
       
   285 			}
       
   286 		
       
   287 		// Convert to internal mode
       
   288 		switch (mode)
       
   289 			{
       
   290 			case CLbsAdmin::EGpsPreferTerminalBased:
       
   291 			case CLbsAdmin::EGpsAlwaysTerminalBased:
       
   292 				iAGPSMode = KTerminalBasedMode;
       
   293 			break;
       
   294 			
       
   295 			case CLbsAdmin::EGpsPreferTerminalAssisted:
       
   296 			case CLbsAdmin::EGpsAlwaysTerminalAssisted:
       
   297 				iAGPSMode = KTerminalAssistedMode;
       
   298 			break;
       
   299 			
       
   300 			case CLbsAdmin::EGpsModeUnknown:
       
   301 				__ASSERT_DEBUG(EFalse,User::Panic(KAdaptationPanicCategory, KErrArgument));
       
   302 			break;
       
   303 			
       
   304 			case CLbsAdmin::EGpsAutonomous:
       
   305 			default:
       
   306 				iAGPSMode = KAutonomousMode;
       
   307 			break;
       
   308 			}
       
   309 		}
       
   310 	}
       
   311 
       
   312 //  End of File