diff -r 000000000000 -r c6b0df440bee dbgsrv/coredumpserver/test/automatictests/tcds_unit/src/tcds_unitBlockServer.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dbgsrv/coredumpserver/test/automatictests/tcds_unit/src/tcds_unitBlockServer.cpp Tue Mar 02 10:33:16 2010 +0530 @@ -0,0 +1,96 @@ +// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "Eclipse Public License v1.0" +// which accompanies this distribution, and is available +// at the URL "http://www.eclipse.org/legal/epl-v10.html". +// +// Initial Contributors: +// Nokia Corporation - initial contribution. +// +// Contributors: +// +// Description: +// + + + +/** + @file tcds_unitBlockServer.cpp + @internalTechnology +*/ + +#include "tcds_unitBlockServer.h" + +Ctcds_unitBlockServer* Ctcds_unitBlockServer::NewL() + { + Ctcds_unitBlockServer* server = new (ELeave) Ctcds_unitBlockServer(); + CleanupStack::PushL(server); + server->ConstructL(); + CleanupStack::Pop(server); + return server; + } + +CTestBlockController* Ctcds_unitBlockServer::CreateTestBlock() +/** + * @return - Instance of the test block controller + * Called when Ctcds_unitBlockServer initializing. + */ + { + CTestBlockController* controller = NULL; + TRAPD(err, controller = Ctcds_unitBlockController::NewL()); + if(KErrNone != err) + User::Panic(_L("Failed to create Ctcds_unitBlockController"), err); + + return controller; + } + +// Secure variants much simpler +// For EKA2, just an E32Main and a MainL() +LOCAL_C void MainL() +/** + * Secure variant + * Much simpler, uses the new Rendezvous() call to sync with the client + */ + { + // Leave the hooks in for platform security +#if (defined __DATA_CAGING__) + RProcess().DataCaging(RProcess::EDataCagingOn); + RProcess().DataCaging(RProcess::ESecureApiOn); +#endif + CActiveScheduler* sched=NULL; + sched=new(ELeave) CActiveScheduler; + CActiveScheduler::Install(sched); + Ctcds_unitBlockServer* server = NULL; + // Create the Ctcds_unitBlockServer derived server + TRAPD(err,server = Ctcds_unitBlockServer::NewL()); + if(!err) + { + // Sync with the client and enter the active scheduler + RProcess::Rendezvous(KErrNone); + sched->Start(); + } + delete server; + delete sched; + } + + + +GLDEF_C TInt E32Main() +/** + * @return - Standard Epoc error code on process exit + * Secure variant only + * Process entry point. Called by client using RProcess API + */ + { + __UHEAP_MARK; + CTrapCleanup* cleanup = CTrapCleanup::New(); + if(cleanup == NULL) + { + return KErrNoMemory; + } + TRAPD(err,MainL()); + delete cleanup; + __UHEAP_MARKEND; + return err; + }