os/kernelhwsrv/kerneltest/f32test/shostmassstorage/msman/app/husbconsapp.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
// Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of the License "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// USB Mass Storage Application - also used as an improvised boot loader mechanism
sl@0
    15
//
sl@0
    16
//
sl@0
    17
sl@0
    18
sl@0
    19
sl@0
    20
/**
sl@0
    21
 @file
sl@0
    22
*/
sl@0
    23
sl@0
    24
#include <e32cons.h>
sl@0
    25
#include <hal.h>
sl@0
    26
#include <f32file.h>
sl@0
    27
sl@0
    28
#include "rusbhostmsdevice.h"
sl@0
    29
#include "rusbhostmslogicalunit.h"
sl@0
    30
sl@0
    31
#include <d32usbdi_hubdriver.h>
sl@0
    32
#include "usbtypes.h"
sl@0
    33
#include "rextfilesystem.h"
sl@0
    34
#include "cusbmsmountmanager.h"
sl@0
    35
sl@0
    36
#include "mdrivedisplay.h"
sl@0
    37
#include "cusbhostao.h"
sl@0
    38
#include "cusbhost.h"
sl@0
    39
sl@0
    40
#include "rusbotgsession.h"
sl@0
    41
sl@0
    42
#include "cdisplay.h"
sl@0
    43
#include "husbconsapp.h"
sl@0
    44
#include "tmslog.h"
sl@0
    45
sl@0
    46
sl@0
    47
_LIT(KTxtApp,"HOST USB CONSOLE APP");
sl@0
    48
sl@0
    49
sl@0
    50
sl@0
    51
CHeartBeat* CHeartBeat::NewLC(CDisplay& aDisplay)
sl@0
    52
	{
sl@0
    53
	CHeartBeat* me = new(ELeave) CHeartBeat(aDisplay);
sl@0
    54
	CleanupStack::PushL(me);
sl@0
    55
	me->ConstructL();
sl@0
    56
	return me;
sl@0
    57
	}
sl@0
    58
sl@0
    59
sl@0
    60
CHeartBeat::CHeartBeat(CDisplay& aDisplay)
sl@0
    61
:   CActive(0),
sl@0
    62
    iDisplay(aDisplay)
sl@0
    63
	{}
sl@0
    64
sl@0
    65
sl@0
    66
void CHeartBeat::ConstructL()
sl@0
    67
	{
sl@0
    68
	CActiveScheduler::Add(this);
sl@0
    69
	iTimer.CreateLocal();
sl@0
    70
	RunL();
sl@0
    71
	}
sl@0
    72
sl@0
    73
sl@0
    74
CHeartBeat::~CHeartBeat()
sl@0
    75
	{
sl@0
    76
	Cancel();
sl@0
    77
	}
sl@0
    78
sl@0
    79
sl@0
    80
void CHeartBeat::DoCancel()
sl@0
    81
	{
sl@0
    82
    iTimer.Cancel();
sl@0
    83
	}
sl@0
    84
sl@0
    85
sl@0
    86
void CHeartBeat::RunL()
sl@0
    87
	{
sl@0
    88
	SetActive();
sl@0
    89
	// Print RAM usage & up time
sl@0
    90
	iUpTime++;
sl@0
    91
    iDisplay.UpTime(iUpTime);
sl@0
    92
sl@0
    93
	TInt mem=0;
sl@0
    94
	if (HAL::Get(HALData::EMemoryRAMFree, mem)==KErrNone)
sl@0
    95
		{
sl@0
    96
        iDisplay.MemoryFree(mem);
sl@0
    97
		}
sl@0
    98
	iTimer.After(iStatus, 1000000);
sl@0
    99
	}
sl@0
   100
sl@0
   101
sl@0
   102
GLDEF_C void RunAppL()
sl@0
   103
    {
sl@0
   104
    __MSFNSLOG
sl@0
   105
    CActiveScheduler* sched = new(ELeave) CActiveScheduler;
sl@0
   106
    CleanupStack::PushL(sched);
sl@0
   107
    CActiveScheduler::Install(sched);
sl@0
   108
sl@0
   109
    RFs fs;
sl@0
   110
    User::LeaveIfError(fs.Connect());
sl@0
   111
    CleanupClosePushL(fs);
sl@0
   112
sl@0
   113
    RUsbOtgSession usbOtgSession;
sl@0
   114
    TInt err = usbOtgSession.Connect();
sl@0
   115
    User::LeaveIfError(err);
sl@0
   116
sl@0
   117
    CConsoleBase* console;
sl@0
   118
	console = Console::NewL(KTxtApp, TSize(KConsFullScreen,KConsFullScreen));
sl@0
   119
	CleanupStack::PushL(console);
sl@0
   120
sl@0
   121
    CDisplay* display = CDisplay::NewLC(fs, *console);
sl@0
   122
	CMessageKeyProcessor::NewLC(*display, usbOtgSession);
sl@0
   123
    CHeartBeat::NewLC(*display);
sl@0
   124
sl@0
   125
    display->Menu();
sl@0
   126
    display->DriveListL();
sl@0
   127
sl@0
   128
sl@0
   129
    CUsbHostDisp* usbHost = CUsbHostDisp::NewL(*display);
sl@0
   130
    CleanupStack::PushL(usbHost);
sl@0
   131
sl@0
   132
    usbHost->Start();
sl@0
   133
sl@0
   134
    // *************************************************************************
sl@0
   135
    // Start Active Scheduler
sl@0
   136
    // *************************************************************************
sl@0
   137
    CActiveScheduler::Start();
sl@0
   138
sl@0
   139
	// 1 sec delay for sessions to stop
sl@0
   140
	User::After(1000000);
sl@0
   141
    CleanupStack::PopAndDestroy(usbHost);
sl@0
   142
    CleanupStack::PopAndDestroy();  // CPeriodUpdate
sl@0
   143
    CleanupStack::PopAndDestroy();  // CMessageKeyProcessor
sl@0
   144
    CleanupStack::PopAndDestroy();  // CDisplay
sl@0
   145
    CleanupStack::PopAndDestroy(console);
sl@0
   146
    CleanupStack::PopAndDestroy();  // fs
sl@0
   147
    CleanupStack::PopAndDestroy(sched);
sl@0
   148
    }
sl@0
   149
sl@0
   150
sl@0
   151
sl@0
   152
GLDEF_C TInt E32Main()
sl@0
   153
	{
sl@0
   154
	__UHEAP_MARK;
sl@0
   155
	CTrapCleanup* cleanup = CTrapCleanup::New();
sl@0
   156
	TRAPD(error, RunAppL());
sl@0
   157
	__ASSERT_ALWAYS(!error, User::Panic(KTxtApp, error));
sl@0
   158
	delete cleanup;
sl@0
   159
	__UHEAP_MARKEND;
sl@0
   160
	return 0;
sl@0
   161
	}