kerneltest/e32test/usbho/t_usbdi/src/testinterfacesettingbase.cpp
changeset 0 a41df078684a
child 43 c1f20ce4abcf
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/e32test/usbho/t_usbdi/src/testinterfacesettingbase.cpp	Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,339 @@
+// Copyright (c) 2007-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:
+// @file testinterfacesettingbase.h
+// @internalComponent
+// 
+//
+
+#include "testinterfacesettingbase.h"
+#include "testinterfacebase.h"
+#include "controltransferrequests.h"
+ 
+ 
+namespace NUnitTesting_USBDI
+	{	
+	
+CInterfaceSettingBase::CInterfaceSettingBase(const TDesC& aString)
+:	iHashEndpointFunction(EndpointNumberHash),
+	iIdRelEndpoint(EndpointIdentityRelationship),
+	iEndpoints(iHashEndpointFunction,iIdRelEndpoint)
+	{	
+	// Set the name of this interface setting
+	iSettingString.Copy(aString);
+	iInterfaceInfo().iString = &iSettingString;
+	
+	// Zero count the number of endpoints used for this setting
+	iInterfaceInfo().iTotalEndpointsUsed = 0;
+	}
+
+	
+CInterfaceSettingBase::~CInterfaceSettingBase()
+	{
+	LOG_FUNC
+	
+	iEndpointReaders.ResetAndDestroy();
+	iEndpointWriters.ResetAndDestroy();
+	}
+	
+
+const TDesC& CInterfaceSettingBase::Name() const
+	{
+	return iSettingString;
+	}
+
+
+void CInterfaceSettingBase::SetClassCodeL(TUint8 aClassCode,TUint8 aSubClassCode,TUint8 aDeviceProtocol)
+	{
+	// Set class specific information
+	iInterfaceInfo().iClass = TUsbcClassInfo(aClassCode,aSubClassCode,aDeviceProtocol);
+	}
+
+
+TInt CInterfaceSettingBase::AddEndpoint(TEndpoint& aEndpoint)
+	{
+	LOG_FUNC
+	
+	if(aEndpoint.iEndpointNumber == EEndpoint0)
+		{
+		return KErrInUse;
+		}
+	
+	if(iEndpoints.Count() < KMaxEndpointsPerClient)
+		{
+		// Set EEndpoint1, EEndpoint2, EEndpoint3, EEndpoint4 or EEndpoint5
+		iInterfaceInfo().iEndpointData[iEndpoints.Count()] = aEndpoint.iEndpointInfo;
+		iEndpoints.Insert(aEndpoint.iEndpointNumber,aEndpoint);
+		
+		// Update the total endpoints used on this interface
+		iInterfaceInfo().iTotalEndpointsUsed = iEndpoints.Count();
+		
+		return KErrNone;
+		}
+	else
+		{
+		return KErrOverflow;
+		}
+	}
+
+
+void CInterfaceSettingBase::CreateEndpointReaderL(RDevUsbcClient& aClientDriver,TUint aEndpoint)
+	{
+	LOG_FUNC	
+	// Create the reader for this endpoint and store in the container	
+	CEndpointReader* epReader = new (ELeave) CEndpointReader(aClientDriver,
+	iEndpoints.Find(static_cast<TEndpointNumber>(aEndpoint))->iEndpointNumber);
+	CleanupStack::PushL(epReader);
+	iEndpointReaders.AppendL(epReader);
+	CleanupStack::Pop(epReader);
+	}
+
+
+void CInterfaceSettingBase::CreateEndpointWriterL(RDevUsbcClient& aClientDriver,TUint aEndpoint)
+	{
+	LOG_FUNC	
+	// Create the writer for this endpoint and store in the container	
+	CEndpointWriter* epWriter = new (ELeave) CEndpointWriter(aClientDriver,
+	iEndpoints.Find(static_cast<TEndpointNumber>(aEndpoint))->iEndpointNumber);
+	CleanupStack::PushL(epWriter);
+	iEndpointWriters.AppendL(epWriter);
+	CleanupStack::Pop(epWriter);
+	}
+
+void CInterfaceSettingBase::WriteSpecifiedDataToEndpointL(const TDesC8& aData,TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and write the data to the host			
+	iEndpointWriters[aEndpointNumber-1]->Write(aData, ETrue);
+	}
+
+void CInterfaceSettingBase::WriteSpecifiedDataToEndpointL(const TDesC8& aDataPattern, const TUint aNumBytes, TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and write the data to the host
+	iEndpointWriters[aEndpointNumber-1]->WriteUsingPatternL(aDataPattern,aNumBytes,ETrue);
+	}
+
+void CInterfaceSettingBase::RepeatedWriteSpecifiedDataToEndpointL(const TDesC8& aDataPattern, TUint aNumBytesPerWrite, TUint aTotalNumBytes, TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and write the data to the host
+	iEndpointWriters[aEndpointNumber-1]->WriteInPartsUsingPatternL(aDataPattern,aNumBytesPerWrite,aTotalNumBytes,ETrue);
+	}
+
+void CInterfaceSettingBase::WriteCachedEndpointDataToEndpointL(const TUint16 aReadEndpointNumber,TUint16 aWriteEndpointNumber)
+	{
+	LOG_FUNC
+	
+	iEndpointWriters[aWriteEndpointNumber-1]->Write(iEndpointReaders[aReadEndpointNumber-1]->Buffer(), ETrue);
+	}
+
+void CInterfaceSettingBase::CancelWriteDataToEndpointL(TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and cancel any outstanding write. This will not of course work for 'synchronous' writes.			
+	iEndpointWriters[aEndpointNumber-1]->Cancel();
+	}
+
+void CInterfaceSettingBase::WriteSynchronousSpecifiedDataToEndpointL(const TDesC8& aDataPattern, const TUint aNumBytes, TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and write the data to the host
+	iEndpointWriters[aEndpointNumber-1]->WriteSynchronousUsingPatternL(aDataPattern,aNumBytes,ETrue);
+	}
+
+void CInterfaceSettingBase::WriteSynchronousSpecifiedDataToAndHaltEndpointL(const TDesC8& aDataPattern, const TUint aNumBytes, TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and write the data to the host
+	iEndpointWriters[aEndpointNumber-1]->WriteSynchronousUsingPatternAndHaltL(aDataPattern,aNumBytes);
+	}
+
+void CInterfaceSettingBase::WriteSynchronousCachedEndpointDataToEndpointL(const TUint16 aReadEndpointNumber,TUint16 aWriteEndpointNumber)
+	{
+	LOG_FUNC
+	
+	//Attempt to write the complete cached buffer by starting at zero and choosing the max length posible
+	WriteSynchronousCachedEndpointDataToEndpointL(aReadEndpointNumber, aWriteEndpointNumber, 0, KMaxTInt);
+	}
+
+void CInterfaceSettingBase::WriteSynchronousCachedEndpointDataToEndpointL(const TUint16 aReadEndpointNumber,TUint16 aWriteEndpointNumber, TUint aStartPoint, TUint aLength)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// Access the 'source' endpoint buffer. This contains data from that endpoint's last read.
+	// Write this data to the host using 'write' endpoint.
+	
+	// Check data
+	TPtr8 dataPtr(iEndpointReaders[aReadEndpointNumber-1]->Buffer());
+	User::LeaveIfError(dataPtr.MaxLength() == 0);
+	if(aStartPoint+aLength>dataPtr.Length())
+		//allow use of excessive length to imply a write of all the rest of the buffer...
+		//..otherwise 'Mid' would panic!
+		{
+		aLength = dataPtr.Length() - aStartPoint;
+		}
+	
+	// Do the 'Write'
+	// Note we need a synchronous 'Write' here
+	iEndpointWriters[aWriteEndpointNumber-1]->WriteSynchronous(iEndpointReaders[aReadEndpointNumber-1]->Buffer().Mid(aStartPoint, aLength), ETrue);
+	}
+
+TBool CInterfaceSettingBase::CachedEndpointResultL(const TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access endpoint buffer containing data from the endpoint's last read
+	// and validate with the supplied data pattern
+
+	return iEndpointReaders[aEndpointNumber-1]->IsValid();
+	}
+
+TInt CInterfaceSettingBase::NumBytesReadSoFarL(const TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access endpoint buffer containing data from the endpoint's last read
+	// and validate with the supplied data pattern
+
+	return iEndpointReaders[aEndpointNumber-1]->NumBytesReadSoFar();
+	}
+
+TInt CInterfaceSettingBase::NumBytesWrittenSoFarL(const TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access endpoint buffer containing data from the endpoint's last read
+	// and validate with the supplied data pattern
+
+	return iEndpointWriters[aEndpointNumber-1]->NumBytesWrittenSoFar();
+	}
+
+TBool CInterfaceSettingBase::ValidateCachedEndpointDataL(const TDesC8& aDataPattern, const TUint aNumBytes, const TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access endpoint buffer containing data from the endpoint's last read
+	// and validate with the supplied data pattern
+
+	return ValidateCachedEndpointDataL(aDataPattern, 0, aNumBytes, aEndpointNumber);
+	}
+
+TBool CInterfaceSettingBase::ValidateCachedEndpointDataL(const TDesC8& aDataPattern, const TUint aStartPoint, const TUint aNumBytes, const TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	__ASSERT_DEBUG(aDataPattern.Length()!=0, User::Panic(_L("Trying to validate with ZERO LENGTH STRING"), KErrArgument));
+
+	//Check data in endpoint buffer
+	TPtr8 dataToValidate(iEndpointReaders[aEndpointNumber-1]->Buffer());
+	User::LeaveIfError(dataToValidate.MaxLength() == 0);
+
+	TUint startPoint = aStartPoint%aDataPattern.Length();
+	TUint numStartBytes = (aDataPattern.Length() - startPoint)%aDataPattern.Length();
+	numStartBytes = aNumBytes<numStartBytes?aNumBytes:numStartBytes; //never test for more than aNumBytes
+	TUint fullRepeats = (aNumBytes-numStartBytes)/aDataPattern.Length();
+	TUint startEndPoint = (fullRepeats*aDataPattern.Length()) + numStartBytes;
+	TUint numEndBytes = aNumBytes - startEndPoint;//fullRepeats*aDataPattern.Length() - numStartBytes;
+	if(numStartBytes)
+		{
+		if(dataToValidate.Left(numStartBytes).Compare(aDataPattern.Mid(startPoint, numStartBytes)) != 0)
+			{
+			RDebug::Printf("ROUND TRIP VALIDATION: Start Bytes Match Failure");
+			RDebug::Printf("ROUND TRIP VALIDATION: numStartBytes = %d", numStartBytes);
+			RDebug::Printf("Start of sent data ...");
+			RDebug::RawPrint(aDataPattern.Mid(startPoint, numStartBytes));
+			RDebug::Printf("\n");
+			RDebug::Printf("ROUND TRIP VALIDATION: Start of returned data ...");				
+			RDebug::RawPrint(dataToValidate.Left(numStartBytes));
+			RDebug::Printf("\n");
+			return EFalse;
+			}
+		}
+	if(numEndBytes)
+		{
+		if(dataToValidate.Mid(startEndPoint,numEndBytes).Compare(aDataPattern.Left(numEndBytes)) != 0)
+			{
+			RDebug::Printf("ROUND TRIP VALIDATION: End Bytes Match Failure");
+			RDebug::Printf("ROUND TRIP VALIDATION: startEndPoint = %d, numEndBytes = %d", startEndPoint, numEndBytes);
+			RDebug::Printf("End of sent data ...");
+			RDebug::RawPrint(aDataPattern.Left(numEndBytes));
+			RDebug::Printf("\n");
+			RDebug::Printf("ROUND TRIP VALIDATION: End of returned data ...");				
+			RDebug::RawPrint(dataToValidate.Mid(startEndPoint,numEndBytes));
+			RDebug::Printf("\n");
+			return EFalse;
+			}
+		}
+	for(TInt i=0; i<fullRepeats; i++)
+		{
+		if(dataToValidate.Mid(numStartBytes + i*aDataPattern.Length(),aDataPattern.Length()).Compare(aDataPattern) != 0)
+			{
+			RDebug::Printf("ROUND TRIP VALIDATION: Repeated Bytes Match Failure, Repeat %d",i);
+			RDebug::Printf("sent data middle block ...");
+			RDebug::RawPrint(aDataPattern);
+			RDebug::Printf("\n");
+			RDebug::Printf("ROUND TRIP VALIDATION: Middle block of returned data ...");
+			RDebug::RawPrint(dataToValidate.Mid(numStartBytes + i*aDataPattern.Length(),aDataPattern.Length()));
+			RDebug::Printf("\n");
+			return EFalse; //from 'for' loop
+			}
+		}
+	return ETrue;
+	}
+
+
+void CInterfaceSettingBase::ReadDataFromEndpointL(TUint aNumBytes, TUint16 aEndpointNumber)	
+	{
+	LOG_FUNC	
+	// Access the correct readerer for the given endpoint
+	// and prepare to read the data to be sent by the host			
+	iEndpointReaders[aEndpointNumber-1]->ReadL(aNumBytes);
+	}
+
+void CInterfaceSettingBase::CancelAnyReadDataFromEndpointL(TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct writer for the given endpoint
+	// and cancel any outstanding write. This will not of course work for 'synchronous' writes.			
+	iEndpointReaders[aEndpointNumber-1]->Cancel();
+	}
+
+void CInterfaceSettingBase::ReadDataFromAndHaltEndpointL(TUint aNumBytes, TUint16 aEndpointNumber)	
+	{
+	LOG_FUNC	
+	// Access the correct reader for the given endpoint
+	// and prepare to read the data to be sent by the host			
+	iEndpointReaders[aEndpointNumber-1]->ReadAndHaltL(aNumBytes);
+	}
+
+void CInterfaceSettingBase::RepeatedReadAndValidateFromEndpointL(const TDesC8& aDataPattern, TUint aNumBytesPerRead, TUint aTotalNumBytes, TUint16 aEndpointNumber)
+	{
+	LOG_FUNC	
+	// Access the correct reader for the given endpoint
+	// and prepare to read the data to be sent by the host
+	// using multiple 'Reads'
+	iEndpointReaders[aEndpointNumber-1]->RepeatedReadAndValidateL(aDataPattern, aNumBytesPerRead, aTotalNumBytes);
+	}
+
+void CInterfaceSettingBase::ReadDataUntilShortFromEndpointL(TUint aNumBytes, TUint16 aEndpointNumber)	
+	{
+	LOG_FUNC	
+	// Access the correct reader for the given endpoint
+	// and prepare to read the data to be sent by the host			
+	iEndpointReaders[aEndpointNumber-1]->ReadUntilShortL(aNumBytes);
+	}
+	}
+
+