satengine/satserver/SatServer/src/std.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:  General functions
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    <e32base.h>
hgs
parents:
diff changeset
    20
#include    <data_caging_path_literals.hrh>
hgs
parents:
diff changeset
    21
#include    "SatServerFactory.h"
hgs
parents:
diff changeset
    22
#include    "CSatSScheduler.h"
hgs
parents:
diff changeset
    23
#include    "SatSPanic.h"
hgs
parents:
diff changeset
    24
#include    "SatLog.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
const TInt8 KInitServerPop( 2 );
hgs
parents:
diff changeset
    27
_LIT( KSatServerMtx, "SATSERVERMTX" );
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// ======== LOCAL FUNCTIONS ========
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    32
// PanicServer
hgs
parents:
diff changeset
    33
// Panics the SatServer.
hgs
parents:
diff changeset
    34
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    35
//
hgs
parents:
diff changeset
    36
void PanicServer(
hgs
parents:
diff changeset
    37
    TSatSPanicCode aPanicCode ) // Panic code
hgs
parents:
diff changeset
    38
    {
hgs
parents:
diff changeset
    39
    LOG( SIMPLE, "SATSERVER: PanicServer" )
hgs
parents:
diff changeset
    40
    User::Panic( KSatServerPanic, aPanicCode );
hgs
parents:
diff changeset
    41
    }
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    44
// InitServerL
hgs
parents:
diff changeset
    45
// Initialises the SatServer.
hgs
parents:
diff changeset
    46
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    47
//
hgs
parents:
diff changeset
    48
LOCAL_C void InitServerL()
hgs
parents:
diff changeset
    49
    {
hgs
parents:
diff changeset
    50
    LOG( SIMPLE, "SATSERVER: InitServerL calling" )
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
    RMutex serverStartMutex;
hgs
parents:
diff changeset
    53
    TInt createErr( serverStartMutex.CreateGlobal( KSatServerMtx ) );
hgs
parents:
diff changeset
    54
    if ( createErr )
hgs
parents:
diff changeset
    55
        {
hgs
parents:
diff changeset
    56
        TInt openErr( serverStartMutex.OpenGlobal( KSatServerMtx ) );
hgs
parents:
diff changeset
    57
        User::LeaveIfError( openErr );
hgs
parents:
diff changeset
    58
        LOG( SIMPLE, "SATSERVER:   Opened SATSERVERMTX" )
hgs
parents:
diff changeset
    59
        }
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
    LOG( SIMPLE, "SATSERVER:   Asking ownership of SATSERVERMTX" )
hgs
parents:
diff changeset
    62
    serverStartMutex.Wait();
hgs
parents:
diff changeset
    63
    LOG( SIMPLE, "SATSERVER:   Got ownership of SATSERVERMTX" )
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
    // create server - if one of this name does not already exist
hgs
parents:
diff changeset
    66
    TFindServer findSatServer( KSatServerName );
hgs
parents:
diff changeset
    67
    TFullName pathName;
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
    // Search for the server.
hgs
parents:
diff changeset
    70
    if ( KErrNone != findSatServer.Next( pathName ) )
hgs
parents:
diff changeset
    71
        {
hgs
parents:
diff changeset
    72
        // We don't already exist.
hgs
parents:
diff changeset
    73
        // Start scheduler and server.
hgs
parents:
diff changeset
    74
        CSatSScheduler* scheduler = new ( ELeave ) CSatSScheduler;
hgs
parents:
diff changeset
    75
        __ASSERT_ALWAYS( scheduler !=
hgs
parents:
diff changeset
    76
            NULL, PanicServer( ESatSMainSchedulerError ) );
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
        CleanupStack::PushL( scheduler );
hgs
parents:
diff changeset
    79
        CActiveScheduler::Install( scheduler );
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
        // Rename the thread.
hgs
parents:
diff changeset
    82
        User::RenameThread( KSatServerName );
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
        // Create the server and connect to external interfaces.
hgs
parents:
diff changeset
    85
        CSatSServer* server = CreateSatServerL();
hgs
parents:
diff changeset
    86
        CleanupStack::PushL( server );
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
        // The scheduler needs access to the server instance.
hgs
parents:
diff changeset
    89
        //lint -e{613} scheduler cannot be null, due assertion in creation.
hgs
parents:
diff changeset
    90
        scheduler->SetServer( server );
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
        // Call Rendezvous to improve startup time
hgs
parents:
diff changeset
    93
        RProcess::Rendezvous( KErrNone );
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
        LOG( SIMPLE,
hgs
parents:
diff changeset
    96
            "SATSERVER:   Releasing ownership of SATSERVERMTX, Starting.." )
hgs
parents:
diff changeset
    97
        serverStartMutex.Signal();
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
        // start fielding requests from clients
hgs
parents:
diff changeset
   100
        CActiveScheduler::Start();
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
        // finished when the scheduler stops
hgs
parents:
diff changeset
   103
        CleanupStack::PopAndDestroy( KInitServerPop ); // scheduler, server
hgs
parents:
diff changeset
   104
        }
hgs
parents:
diff changeset
   105
    else
hgs
parents:
diff changeset
   106
        {
hgs
parents:
diff changeset
   107
        LOG( SIMPLE,
hgs
parents:
diff changeset
   108
            "SATSERVER:   Releasing ownership of SATSERVERMTX, Already started" )
hgs
parents:
diff changeset
   109
        serverStartMutex.Signal();
hgs
parents:
diff changeset
   110
        }
hgs
parents:
diff changeset
   111
    serverStartMutex.Close();
hgs
parents:
diff changeset
   112
    LOG( SIMPLE, "SATSERVER: InitServerL exiting" )
hgs
parents:
diff changeset
   113
    }
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
// ======== GLOBAL FUNCTIONS ========
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   118
// E32Main implements the executable entry function.
hgs
parents:
diff changeset
   119
// Target type of the SATServer module is EXE.
hgs
parents:
diff changeset
   120
// Creates a cleanup stack and runs the server.
hgs
parents:
diff changeset
   121
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   122
//
hgs
parents:
diff changeset
   123
GLDEF_C TInt E32Main()
hgs
parents:
diff changeset
   124
    {
hgs
parents:
diff changeset
   125
    __UHEAP_MARK;
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
    // Get a new clean-up stack.
hgs
parents:
diff changeset
   128
    CTrapCleanup* cleanup = CTrapCleanup::New();
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
    // Initialize and run the server.
hgs
parents:
diff changeset
   131
    TRAPD( error, InitServerL() );
hgs
parents:
diff changeset
   132
    __ASSERT_ALWAYS( !error, User::Panic( KSatSInitError, error ) );
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
    // Destroy clean-up stack.
hgs
parents:
diff changeset
   135
    delete cleanup;
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
    __UHEAP_MARKEND;
hgs
parents:
diff changeset
   138
    // Not called unless server is already running. This server is always on
hgs
parents:
diff changeset
   139
    LOG( SIMPLE, "SATSERVER: E32Main exiting" )
hgs
parents:
diff changeset
   140
    return KErrAlreadyExists;
hgs
parents:
diff changeset
   141
    }