hti/HtiRestart/src/HtiRestart.cpp
author hgs
Mon, 28 Jun 2010 15:36:07 +0300
changeset 30 86a2e675b80a
permissions -rw-r--r--
201025
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 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:  HtiWatchDog implementation.
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 FILES
hgs
parents:
diff changeset
    20
#include <e32base.h>
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#ifdef __ENABLE_LOGGING__
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include <flogger.h>
hgs
parents:
diff changeset
    25
_LIT( KLogFolder, "hti" );
hgs
parents:
diff changeset
    26
_LIT( KLogFile,   "htirestart.txt" );
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
#define HTI_LOG_TEXT(a1) {_LIT(temp, a1); RFileLogger::Write(KLogFolder, KLogFile, EFileLoggingModeAppend, temp);}
hgs
parents:
diff changeset
    29
#define HTI_LOG_DES(a1) {RFileLogger::Write(KLogFolder, KLogFile, EFileLoggingModeAppend, a1);}
hgs
parents:
diff changeset
    30
#define HTI_LOG_FORMAT(a1,a2) {_LIT(temp, a1); RFileLogger::WriteFormat(KLogFolder, KLogFile, EFileLoggingModeAppend, temp, (a2));}
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
#else   // !__ENABLE_LOGGING__
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
#define HTI_LOG_TEXT(a1)
hgs
parents:
diff changeset
    35
#define HTI_LOG_DES(a1)
hgs
parents:
diff changeset
    36
#define HTI_LOG_FORMAT(a1,a2)
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
#endif // __ENABLE_LOGGING__
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
// CONSTANTS
hgs
parents:
diff changeset
    41
_LIT( KHtiFrameworkExeName,    "HtiFramework.exe" );
hgs
parents:
diff changeset
    42
_LIT( KHtiMainThreadName,      "HtiMain" );
hgs
parents:
diff changeset
    43
_LIT( KHtiRestartName,        "HtiRestart" );
hgs
parents:
diff changeset
    44
_LIT( KHtiAdminStartParameter, "admin" );
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
// MACROS
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
// LOCAL CONSTANTS AND MACROS
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
// MODULE DATA STRUCTURES
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
// LOCAL FUNCTION PROTOTYPES
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
// ============================ LOCAL FUNCTIONS ===============================
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
LOCAL_C void StartHtiProcessL()
hgs
parents:
diff changeset
    60
    {
hgs
parents:
diff changeset
    61
    RProcess htiProcess;
hgs
parents:
diff changeset
    62
    User::LeaveIfError( htiProcess.Create(
hgs
parents:
diff changeset
    63
            KHtiFrameworkExeName, KHtiAdminStartParameter ) );
hgs
parents:
diff changeset
    64
    htiProcess.Resume();
hgs
parents:
diff changeset
    65
    htiProcess.Close();
hgs
parents:
diff changeset
    66
    }
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
LOCAL_C TInt StartL()
hgs
parents:
diff changeset
    70
    {
hgs
parents:
diff changeset
    71
    HTI_LOG_TEXT( "HtiRestart starting..." );
hgs
parents:
diff changeset
    72
    TFullName threadName;
hgs
parents:
diff changeset
    73
    TFullName matchPattern;
hgs
parents:
diff changeset
    74
    matchPattern.Append(_L( "*" ));
hgs
parents:
diff changeset
    75
    matchPattern.Append(KHtiMainThreadName);
hgs
parents:
diff changeset
    76
    matchPattern.Append(_L( "*" ));
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
    // Use thread finder to find the HTI main thread
hgs
parents:
diff changeset
    79
    TFindThread threadFinder;
hgs
parents:
diff changeset
    80
    threadFinder.Find(matchPattern);
hgs
parents:
diff changeset
    81
    HTI_LOG_TEXT( "Trying to find HTI main thread" );
hgs
parents:
diff changeset
    82
    TInt err = threadFinder.Next(threadName);
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
    if (err == KErrNone)
hgs
parents:
diff changeset
    85
        {
hgs
parents:
diff changeset
    86
        HTI_LOG_TEXT( "HTI main thread found, opening it" );
hgs
parents:
diff changeset
    87
        RThread thread;
hgs
parents:
diff changeset
    88
        err = thread.Open(threadName);
hgs
parents:
diff changeset
    89
        if (err)
hgs
parents:
diff changeset
    90
            {
hgs
parents:
diff changeset
    91
            HTI_LOG_FORMAT( "Could not open HTI main thread, err: %d", err );
hgs
parents:
diff changeset
    92
            User::Panic(_L( "HTI open err" ), err);
hgs
parents:
diff changeset
    93
            }
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
        // Logon to HTI main thread and wait for its death
hgs
parents:
diff changeset
    96
        HTI_LOG_TEXT( "HTI main thread opened, waiting for its death" );
hgs
parents:
diff changeset
    97
        TRequestStatus status;
hgs
parents:
diff changeset
    98
        thread.Logon(status);
hgs
parents:
diff changeset
    99
        User::WaitForRequest(status);
hgs
parents:
diff changeset
   100
        thread.Close();
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
        HTI_LOG_TEXT( "HTI died");
hgs
parents:
diff changeset
   103
        }
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
    TBuf<0x20> cmd;
hgs
parents:
diff changeset
   106
    User::CommandLine(cmd);
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
    TLex lex(cmd);
hgs
parents:
diff changeset
   109
    TInt microseconds = 0;
hgs
parents:
diff changeset
   110
    lex.Val(microseconds);
hgs
parents:
diff changeset
   111
    HTI_LOG_FORMAT("After %d milliseconds...", microseconds);
hgs
parents:
diff changeset
   112
    User::After(microseconds);
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
    // try to restart HTI
hgs
parents:
diff changeset
   115
    HTI_LOG_TEXT( "Trying to restart it" );
hgs
parents:
diff changeset
   116
    TRAP( err, StartHtiProcessL() );
hgs
parents:
diff changeset
   117
    if (err)
hgs
parents:
diff changeset
   118
        {
hgs
parents:
diff changeset
   119
        HTI_LOG_FORMAT( "Could not restart HTI, err: %d", err );
hgs
parents:
diff changeset
   120
        User::Panic(_L( "HTI start err" ), err);
hgs
parents:
diff changeset
   121
        }
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
    HTI_LOG_TEXT( "HtiRestart shutting down" );
hgs
parents:
diff changeset
   124
    return KErrNone;
hgs
parents:
diff changeset
   125
    }
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
GLDEF_C TInt E32Main()
hgs
parents:
diff changeset
   128
    {
hgs
parents:
diff changeset
   129
    __UHEAP_MARK;
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
    CTrapCleanup* cleanup = CTrapCleanup::New();
hgs
parents:
diff changeset
   132
    CActiveScheduler *scheduler = new(ELeave) CActiveScheduler;
hgs
parents:
diff changeset
   133
    CActiveScheduler::Install( scheduler );
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
    User::RenameThread( KHtiRestartName );
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
    TRAPD( err, StartL() );
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
    delete scheduler;
hgs
parents:
diff changeset
   140
    delete cleanup;
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
   __UHEAP_MARKEND;
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
    return err;
hgs
parents:
diff changeset
   145
    }
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
hgs
parents:
diff changeset
   148
// End of File