satengine/satserver/SatClient/src/RSatSession.cpp
author hgs
Fri, 15 Oct 2010 13:21:28 +0300
changeset 53 25b8d29b7c59
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2007 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Session class to connect SatServer.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include    <rsatsession.h>
hgs
parents:
diff changeset
    20
#include    "SatSOpcodes.h"
hgs
parents:
diff changeset
    21
#include    "SatServerFactory.h"
hgs
parents:
diff changeset
    22
#include    "SatLog.h"
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
_LIT( KSatSessionMtx, "SATSESSIONMTX" );
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    29
// RSatSession::RSatSession
hgs
parents:
diff changeset
    30
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    31
// might leave.
hgs
parents:
diff changeset
    32
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
//
hgs
parents:
diff changeset
    34
EXPORT_C RSatSession::RSatSession() :
hgs
parents:
diff changeset
    35
    RSessionBase()
hgs
parents:
diff changeset
    36
    {
hgs
parents:
diff changeset
    37
    LOG( SIMPLE, "SATCLIENT: RSatSession::RSatSession calling-exiting" )
hgs
parents:
diff changeset
    38
    }
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    41
// RSatSession::ConnectL
hgs
parents:
diff changeset
    42
// Connects to SatServer.
hgs
parents:
diff changeset
    43
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    44
//
hgs
parents:
diff changeset
    45
EXPORT_C void RSatSession::ConnectL()
hgs
parents:
diff changeset
    46
    {
hgs
parents:
diff changeset
    47
    LOG( SIMPLE, "SATCLIENT: RSatSession::ConnectL calling" )
hgs
parents:
diff changeset
    48
    
hgs
parents:
diff changeset
    49
    #ifdef ENABLE_SAT_LOGGING
hgs
parents:
diff changeset
    50
    RProcess test;
hgs
parents:
diff changeset
    51
    LOG2( SIMPLE, 
hgs
parents:
diff changeset
    52
    "SATCLIENT: RSatSession::ConnectL UID of calling process: 0x%x",
hgs
parents:
diff changeset
    53
    test.SecureId().iId )
hgs
parents:
diff changeset
    54
    test.Close();
hgs
parents:
diff changeset
    55
    #endif
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
    RMutex sessionStartMutex;
hgs
parents:
diff changeset
    58
    TInt createErr( sessionStartMutex.CreateGlobal( KSatSessionMtx ) );
hgs
parents:
diff changeset
    59
    if ( createErr )
hgs
parents:
diff changeset
    60
        {
hgs
parents:
diff changeset
    61
        TInt openErr( sessionStartMutex.OpenGlobal( KSatSessionMtx ) );
hgs
parents:
diff changeset
    62
        User::LeaveIfError( openErr );
hgs
parents:
diff changeset
    63
        LOG( SIMPLE, "SATCLIENT:   Opened SATSESSIONMTX" )
hgs
parents:
diff changeset
    64
        }
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
    LOG( SIMPLE, "SATCLIENT:   Asking ownership of SATSESSIONMTX" )
hgs
parents:
diff changeset
    67
    sessionStartMutex.Wait();
hgs
parents:
diff changeset
    68
    LOG( SIMPLE, "SATCLIENT:   Got ownership of SATSESSIONMTX" )
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
    // Create new session for SatServer.
hgs
parents:
diff changeset
    71
    TInt error( CreateSession( KSatServerName, Version(), KSatMessageSlots ) );
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
    // Server may not be fully started, so let's retry after synchronization.
hgs
parents:
diff changeset
    74
    if ( KErrNone != error )
hgs
parents:
diff changeset
    75
        {
hgs
parents:
diff changeset
    76
        LOG2( SIMPLE,
hgs
parents:
diff changeset
    77
              "SATCLIENT: RSatSession::ConnectL CreateSession %d", error )
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
        // Starts a new process, loading SAT Server.
hgs
parents:
diff changeset
    80
        TBuf<1> arguments;
hgs
parents:
diff changeset
    81
        RProcess satProcess;
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
        if ( KErrNone == satProcess.Create( KSatServerNameAndPath, arguments ) )
hgs
parents:
diff changeset
    84
            {
hgs
parents:
diff changeset
    85
            TRequestStatus rendezvousStatus;
hgs
parents:
diff changeset
    86
hgs
parents:
diff changeset
    87
            satProcess.Rendezvous( rendezvousStatus );
hgs
parents:
diff changeset
    88
            satProcess.Resume();
hgs
parents:
diff changeset
    89
            User::WaitForRequest( rendezvousStatus );
hgs
parents:
diff changeset
    90
            LOG2( SIMPLE,
hgs
parents:
diff changeset
    91
                  "SATCLIENT: RSatSession::ConnectL Rendezvous %d",
hgs
parents:
diff changeset
    92
                   rendezvousStatus.Int() )
hgs
parents:
diff changeset
    93
            satProcess.Close();
hgs
parents:
diff changeset
    94
            }
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
        // Retry session creation.
hgs
parents:
diff changeset
    97
        error = CreateSession( KSatServerName,
hgs
parents:
diff changeset
    98
                               Version(), KSatMessageSlots );
hgs
parents:
diff changeset
    99
        LOG2( DETAILED,
hgs
parents:
diff changeset
   100
              "SATCLIENT: RSatSession::ConnectL CreateSession %d",
hgs
parents:
diff changeset
   101
              error )
hgs
parents:
diff changeset
   102
        }
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
    LOG( SIMPLE, "SATCLIENT:   Releasing ownership of SATSESSIONMTX" )
hgs
parents:
diff changeset
   105
    sessionStartMutex.Signal();
hgs
parents:
diff changeset
   106
    sessionStartMutex.Close();
hgs
parents:
diff changeset
   107
    User::LeaveIfError( error );
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
    LOG( SIMPLE, "SATCLIENT: RSatSession::ConnectL exiting" )
hgs
parents:
diff changeset
   110
    }
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   113
// RSatSession::Version
hgs
parents:
diff changeset
   114
// Returns the version of this API.
hgs
parents:
diff changeset
   115
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   116
//
hgs
parents:
diff changeset
   117
EXPORT_C TVersion RSatSession::Version() const
hgs
parents:
diff changeset
   118
    {
hgs
parents:
diff changeset
   119
    LOG( SIMPLE, "SATCLIENT: RSatSession::Version calling-exiting" )
hgs
parents:
diff changeset
   120
    
hgs
parents:
diff changeset
   121
    #ifdef ENABLE_SAT_LOGGING
hgs
parents:
diff changeset
   122
    RProcess test;
hgs
parents:
diff changeset
   123
    LOG2( SIMPLE, 
hgs
parents:
diff changeset
   124
    "SATCLIENT: RSatSession::Version UID of calling process: 0x%x",
hgs
parents:
diff changeset
   125
    test.SecureId().iId )
hgs
parents:
diff changeset
   126
    test.Close();
hgs
parents:
diff changeset
   127
    #endif
hgs
parents:
diff changeset
   128
    
hgs
parents:
diff changeset
   129
    return TVersion(
hgs
parents:
diff changeset
   130
        KSatServerMajorVersionNumber,
hgs
parents:
diff changeset
   131
        KSatServerMinorVersionNumber,
hgs
parents:
diff changeset
   132
        KSatServerBuildVersionNumber );
hgs
parents:
diff changeset
   133
    }