os/ossrv/genericopenlibs/posixrealtimeextensions/test/testcapclock/src/tcapclockserver.cpp
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/os/ossrv/genericopenlibs/posixrealtimeextensions/test/testcapclock/src/tcapclockserver.cpp Fri Jun 15 03:10:57 2012 +0200
1.3 @@ -0,0 +1,130 @@
1.4 +// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
1.5 +// All rights reserved.
1.6 +// This component and the accompanying materials are made available
1.7 +// under the terms of "Eclipse Public License v1.0"
1.8 +// which accompanies this distribution, and is available
1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
1.10 +//
1.11 +// Initial Contributors:
1.12 +// Nokia Corporation - initial contribution.
1.13 +//
1.14 +// Contributors:
1.15 +//
1.16 +// Description:
1.17 +// Name : tcapclockserver.cpp
1.18 +//
1.19 +//
1.20 +
1.21 +
1.22 +#include <c32comm.h>
1.23 +
1.24 +#if defined (__WINS__)
1.25 +#define PDD_NAME _L("ECDRV")
1.26 +#else
1.27 +#define PDD_NAME _L("EUART1")
1.28 +#define PDD2_NAME _L("EUART2")
1.29 +#define PDD3_NAME _L("EUART3")
1.30 +#define PDD4_NAME _L("EUART4")
1.31 +#endif
1.32 +
1.33 +#define LDD_NAME _L("ECOMM")
1.34 +
1.35 +#include "tcapclockserver.h"
1.36 +#include "tcapclock.h"
1.37 +
1.38 +
1.39 +//_LIT(KServerName, "tstdiocap");
1.40 +
1.41 +CCapclockTestServer* CCapclockTestServer::NewL()
1.42 + {
1.43 + CCapclockTestServer *server = new(ELeave) CCapclockTestServer();
1.44 + CleanupStack::PushL(server);
1.45 + //server->ConstructL(KServerName);
1.46 +RProcess handle = RProcess();
1.47 + TParsePtrC serverName(handle.FileName());
1.48 + server->StartL(serverName.Name());
1.49 +
1.50 +
1.51 + CleanupStack::Pop(server);
1.52 + return server;
1.53 + }
1.54 +
1.55 +static void InitCommsL()
1.56 + {
1.57 + TInt ret = User::LoadPhysicalDevice(PDD_NAME);
1.58 + User::LeaveIfError(ret == KErrAlreadyExists?KErrNone:ret);
1.59 +
1.60 +#ifndef __WINS__
1.61 + ret = User::LoadPhysicalDevice(PDD2_NAME);
1.62 + ret = User::LoadPhysicalDevice(PDD3_NAME);
1.63 + ret = User::LoadPhysicalDevice(PDD4_NAME);
1.64 +#endif
1.65 +
1.66 + ret = User::LoadLogicalDevice(LDD_NAME);
1.67 + User::LeaveIfError(ret == KErrAlreadyExists?KErrNone:ret);
1.68 + ret = StartC32();
1.69 + User::LeaveIfError(ret == KErrAlreadyExists?KErrNone:ret);
1.70 + }
1.71 +
1.72 +LOCAL_C void MainL()
1.73 + {
1.74 + // Leave the hooks in for platform security
1.75 +#if (defined __DATA_CAGING__)
1.76 + RProcess().DataCaging(RProcess::EDataCagingOn);
1.77 + RProcess().SecureApi(RProcess::ESecureApiOn);
1.78 +#endif
1.79 + //InitCommsL();
1.80 +
1.81 + CActiveScheduler* sched=NULL;
1.82 + sched=new(ELeave) CActiveScheduler;
1.83 + CActiveScheduler::Install(sched);
1.84 + CCapclockTestServer* server = NULL;
1.85 + // Create the CTestServer derived server
1.86 + TRAPD(err, server = CCapclockTestServer::NewL());
1.87 + if(!err)
1.88 + {
1.89 + // Sync with the client and enter the active scheduler
1.90 + RProcess::Rendezvous(KErrNone);
1.91 + sched->Start();
1.92 + }
1.93 + delete server;
1.94 + delete sched;
1.95 + }
1.96 +
1.97 +/**
1.98 + * Server entry point
1.99 + * @return Standard Epoc error code on exit
1.100 + */
1.101 +TInt main()
1.102 + {
1.103 + __UHEAP_MARK;
1.104 + CTrapCleanup* cleanup = CTrapCleanup::New();
1.105 + if(cleanup == NULL)
1.106 + {
1.107 + return KErrNoMemory;
1.108 + }
1.109 + TRAP_IGNORE(MainL());
1.110 + delete cleanup;
1.111 + __UHEAP_MARKEND;
1.112 +
1.113 + return KErrNone;
1.114 + }
1.115 +
1.116 +CTestStep* CCapclockTestServer::CreateTestStep(const TDesC& aStepName)
1.117 + {
1.118 + CTestStep* testStep = NULL;
1.119 +
1.120 + // This server creates just one step but create as many as you want
1.121 + // They are created "just in time" when the worker thread is created
1.122 + // install steps
1.123 +
1.124 + //steps for captest.
1.125 +
1.126 + if(aStepName == KTestcapclocksettime1)
1.127 + {
1.128 + testStep = new Ctestcapclock(aStepName);
1.129 + }
1.130 +
1.131 + return testStep;
1.132 + }
1.133 +