kerneltest/e32test/mmu/d_shbuf.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 07 Jan 2010 13:38:45 +0200
changeset 6 0173bcd7697c
parent 0 a41df078684a
permissions -rw-r--r--
Revision: 201001 Kit: 201001

// Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "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:
// e32test/mmu/d_shbuf.h
//
//

#ifndef D_SHBUF_H
#define D_SHBUF_H

#include <e32cmn.h>
#include <e32ver.h>
#include <e32shbufcmn.h>

class TShPoolInfo;
class TShPoolCreateInfo;

// Device driver names
_LIT(KTestShBufClient, "d_shbuf_client"); // Driver 0
_LIT(KTestShBufOwn, "d_shbuf_own"); // Driver 1

// Some test data
_LIT8(KTestData1, "QTWHEIRSTTYEUSITOAPPAPSIDSFAGFHUJCKKLIZNXGCPVIBLNEMOQFWCERRATPEA");
_LIT8(KTestData2, "8297382917319823712893719824737644563284328746372468732643287463");

const TInt KTestMinimumAlignmentLog2 = 5;
const TInt KTestPoolSizeInBufs = 10;
const TInt KDefaultPoolHandleFlags = EShPoolWriteable | EShPoolAllocate;

class RShBufTestChannel : public RBusLogicalChannel
	{
public:
	enum TTestControl
		{
		ETestOpenUserPool,
		ETestOpenKernelPool,
		ETestCloseUserPool,
		ETestCloseKernelPool,
		ETestManipulateUserBuffer,
		ETestAllocateKernelBuffer,
		ETestCreatePoolPhysAddrCont,
		ETestCreatePoolPhysAddrNonCont,
		ETestAllocateMax,
		ETestBufferAlignmentKernel,
		ETestNegativeTestsKernel,
		ETestCreatePoolContiguousPool,
		ETestPinBuffer,
		// Performance tests
		EFromRShBufProcessAndReturn = 100,
		EFromRShBufProcessAndRelease,
		EFromTPtr8ProcessAndReturn,
		EFromTPtr8ProcessAndRelease
		};

	enum { EClientThread = 0, EOwnThread = 1 };

#ifndef __KERNEL_MODE__
	inline TInt Open(TInt aDriverNo);	// driver 0 executes in client thread, driver 1 has its own thread
	inline TInt OpenUserPool(TInt aHandle, const TShPoolInfo& aPoolInfo);
	inline TInt OpenKernelPool(TShPoolCreateInfo& aInfo, TInt& aHandle);
	inline TInt CloseUserPool();
	inline TInt CloseKernelPool();
	inline TInt ManipulateUserBuffer(TInt aHandle);
	inline TInt AllocateKernelBuffer(TInt aPoolIndex, TInt& aHandle);
	inline TInt CreatePoolPhysAddrCont(TInt aBufSize);
	inline TInt CreatePoolPhysAddrNonCont(TInt aBufSize);
	inline TInt AllocateMax(TInt aPoolIndex, TInt& aAllocated);
	inline TInt BufferAlignmentKernel(TInt aBufSize, TInt aAlignment);
	inline TInt NegativeTestsKernel();
	inline TInt ContiguousPoolKernel(TShPoolCreateInfo& aInfo);
	inline TInt PinBuffer(TInt aPoolHandle, TInt aBufferHandle);
	// Performance tests
	inline TInt FromRShBufProcessAndReturn(TUint aBufSize);
	inline TInt FromRShBufProcessAndRelease(TInt aHandle);
	inline TInt FromTPtr8ProcessAndReturn(TDes8& aBuf, TUint bufferSize);
	inline TInt FromTPtr8ProcessAndRelease(TDes8& aBuf);
#endif // __KERNEL_MODE__
	};

#ifndef __KERNEL_MODE__
inline TInt RShBufTestChannel::Open(TInt aDriverNo)
	{
	if (aDriverNo!=0&&aDriverNo!=1)
		{
		return KErrArgument;
		}
	return (DoCreate((aDriverNo)?(KTestShBufOwn()):(KTestShBufClient()),TVersion(1,0,KE32BuildVersionNumber),KNullUnit,NULL,NULL,EOwnerThread));
	}
inline TInt RShBufTestChannel::OpenUserPool(TInt aHandle, const TShPoolInfo& aPoolInfo)
	{return DoControl(ETestOpenUserPool, (TAny*) aHandle, (TAny*) &aPoolInfo);}
inline TInt RShBufTestChannel::OpenKernelPool(TShPoolCreateInfo& aInfo, TInt& aHandle)
	{return DoControl(ETestOpenKernelPool, (TAny*) &aInfo, (TAny*) &aHandle);}
inline TInt RShBufTestChannel::CloseUserPool()
	{return DoControl(ETestCloseUserPool);}
inline TInt RShBufTestChannel::CloseKernelPool()
	{return DoControl(ETestCloseKernelPool);}
inline TInt RShBufTestChannel::ManipulateUserBuffer(TInt aHandle)
	{return DoControl(ETestManipulateUserBuffer, (TAny*) aHandle);}
inline TInt RShBufTestChannel::AllocateKernelBuffer(TInt aPoolIndex, TInt& aHandle)
	{return DoControl(ETestAllocateKernelBuffer, (TAny*) aPoolIndex, (TAny*) &aHandle);}
inline TInt RShBufTestChannel::CreatePoolPhysAddrCont(TInt aBufSize)
	{return DoControl(ETestCreatePoolPhysAddrCont, (TAny*) aBufSize);}
inline TInt RShBufTestChannel::CreatePoolPhysAddrNonCont(TInt aBufSize)
	{return DoControl(ETestCreatePoolPhysAddrNonCont, (TAny*) aBufSize);}
inline TInt RShBufTestChannel::AllocateMax(TInt aPoolIndex, TInt& aAllocated)
	{return DoControl(ETestAllocateMax, (TAny*) aPoolIndex, (TAny*) &aAllocated);}
inline TInt RShBufTestChannel::BufferAlignmentKernel(TInt aBufSize, TInt aAlignment)
	{return DoControl(ETestBufferAlignmentKernel, (TAny*) aBufSize, (TAny*) aAlignment);}
inline TInt RShBufTestChannel::NegativeTestsKernel()
	{return DoControl(ETestNegativeTestsKernel);}
inline TInt RShBufTestChannel::ContiguousPoolKernel(TShPoolCreateInfo& aInfo)
	{return DoControl(ETestCreatePoolContiguousPool, (TAny*)&aInfo);}
inline TInt RShBufTestChannel::PinBuffer(TInt aPoolHandle, TInt aBufferHandle)
	{return DoControl(ETestPinBuffer, (TAny*) aPoolHandle, (TAny*) aBufferHandle);}
// Performance tests
inline TInt RShBufTestChannel::FromRShBufProcessAndReturn(TUint aBufSize)
	{return DoControl(EFromRShBufProcessAndReturn, (TAny*) aBufSize);}
inline TInt RShBufTestChannel::FromRShBufProcessAndRelease(TInt aHandle)
	{return DoControl(EFromRShBufProcessAndRelease,(TAny*)aHandle);}
inline TInt RShBufTestChannel::FromTPtr8ProcessAndReturn(TDes8& aBuf, TUint aBufSize)
	{return DoControl(EFromTPtr8ProcessAndReturn,(TAny*)&aBuf, (TAny*) aBufSize);}
inline TInt RShBufTestChannel::FromTPtr8ProcessAndRelease(TDes8& aBuf)
	{return DoControl(EFromTPtr8ProcessAndRelease,(TAny*)&aBuf);}
#endif // __KERNEL_MODE__
#endif // D_SHBUF_H