kerneltest/e32test/dmav2/test_cases.cpp
changeset 45 329ab0095843
child 87 2f92ad2dc5db
equal deleted inserted replaced
44:36bfc973b146 45:329ab0095843
       
     1 /*
       
     2 * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:
       
    15 * This file contains statically defined test cases, a pointer to each
       
    16 * new test case should be entered in StaticTestArray
       
    17 *
       
    18 */
       
    19 
       
    20 #include "t_dma2.h"
       
    21 #include "cap_reqs.h"
       
    22 
       
    23 const TCallbackRecord threadCallback(TCallbackRecord::EThread,1);
       
    24 const TCallbackRecord isrCallback(TCallbackRecord::EIsr,1);
       
    25 
       
    26 const TInt size = 128 * KKilo;
       
    27 //--------------------------------------------------------------------------------------------
       
    28 //! @SYMTestCaseID      KBASE-DMA-2560
       
    29 //! @SYMTestType        CIT
       
    30 //! @SYMPREQ            REQ
       
    31 //! @SYMTestCaseDesc    Simple DMA transfer test using CSingleTransferTest and New DMA APIs
       
    32 //!
       
    33 //! @SYMTestActions     
       
    34 //!						1.
       
    35 //!						2.	
       
    36 //!
       
    37 //!
       
    38 //! @SYMTestExpectedResults 
       
    39 //!						1.  
       
    40 //!						2.		
       
    41 //!							
       
    42 //!
       
    43 //! @SYMTestPriority        High
       
    44 //! @SYMTestStatus          Implemented
       
    45 //----------------------------------------------------------------------------------------------
       
    46 namespace Simple_1
       
    47 	{
       
    48 	TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
    49 
       
    50 	const TResultSet expectedResults(threadCallback);
       
    51 
       
    52 	CSingleTransferTest simpleTest(_L("Simple Test - New DMA APIs"), 1, transferArgs, expectedResults);
       
    53 
       
    54 	TTestCase testCase(&simpleTest, EFalse, capAboveV1);
       
    55 	TTestCase testCaseConcurrent(&simpleTest, ETrue, capAboveV1);
       
    56 	}
       
    57 
       
    58 //----------------------------------------------------------------------------------------------
       
    59 //! @SYMTestCaseID      KBASE-DMA-2561
       
    60 //! @SYMTestType        CIT
       
    61 //! @SYMPREQ            REQ
       
    62 //! @SYMTestCaseDesc    Simple DMA transfer test using CSingleTransferTest and OLD DMA APIs
       
    63 //!
       
    64 //! @SYMTestActions     
       
    65 //!						1.
       
    66 //!						2.	
       
    67 //!
       
    68 //!
       
    69 //! @SYMTestExpectedResults 
       
    70 //!						1.  
       
    71 //!						2.						
       
    72 //!							
       
    73 //!
       
    74 //! @SYMTestPriority        High
       
    75 //! @SYMTestStatus          Implemented
       
    76 //----------------------------------------------------------------------------------------------
       
    77 namespace Simple_2
       
    78 	{
       
    79 	TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
    80 
       
    81 	const TResultSet expectedResults(threadCallback);
       
    82 
       
    83 	CSingleTransferTest simpleTest = CSingleTransferTest(_L("Simple Test - Old DMA APIs"), 1, transferArgs, expectedResults, 0).
       
    84 		UseNewDmaApi(EFalse);
       
    85 
       
    86 	TTestCase testCase(&simpleTest, EFalse);
       
    87 	TTestCase testCaseConcurrent(&simpleTest, ETrue);
       
    88 	}
       
    89 
       
    90 //----------------------------------------------------------------------------------------------
       
    91 //! @SYMTestCaseID      KBASE-DMA-2573
       
    92 //! @SYMTestType        CIT
       
    93 //! @SYMPREQ            REQ
       
    94 //! @SYMTestCaseDesc    DMA ISR Callback test (Isr Callback - use old request Ctor)
       
    95 //!
       
    96 //! @SYMTestActions     
       
    97 //!						1.
       
    98 //!						2.	
       
    99 //!
       
   100 //!
       
   101 //! @SYMTestExpectedResults 
       
   102 //!						1.  
       
   103 //!						2.		
       
   104 //!							
       
   105 //!
       
   106 //! @SYMTestPriority        High
       
   107 //! @SYMTestStatus          Implemented
       
   108 //----------------------------------------------------------------------------------------------
       
   109 namespace Callback
       
   110 	{
       
   111 	TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr, KDmaSyncAuto, KDmaRequestCallbackFromIsr);
       
   112 
       
   113 	const TResultSet expectedResults(isrCallback);
       
   114 
       
   115 	CSingleTransferTest isrTest(_L("Isr Callback"), 1, transferArgs, expectedResults);
       
   116 	TTestCase testCase(&isrTest, EFalse, capAboveV1);
       
   117 
       
   118 
       
   119 	const TRequestResults fragmentFails = TRequestResults().
       
   120 		FragmentationResult(KErrArgument).
       
   121 		QueueResult(KErrUnknown);
       
   122 
       
   123 	const TResultSet expectedResultsFail = TResultSet(EFalse).
       
   124 		ChannelOpenResult(KErrNone).
       
   125 		RequestResult(fragmentFails).
       
   126 		PostTransferResult(1); // PostTransferResult of 1 means buffers don't match
       
   127 
       
   128 	CSingleTransferTest isrTestOldRequest = CSingleTransferTest(_L("Isr Callback - use old request Ctor"), 1, transferArgs, expectedResultsFail)
       
   129 		.UseNewRequest(EFalse);
       
   130 	TTestCase testCaseOldRequest(&isrTestOldRequest, EFalse, capAboveV1);
       
   131 	}
       
   132 
       
   133 //----------------------------------------------------------------------------------------------
       
   134 //! @SYMTestCaseID      KBASE-DMA-2574,KBASE-DMA-2575
       
   135 //! @SYMTestType        CIT
       
   136 //! @SYMPREQ            REQ
       
   137 //! @SYMTestCaseDesc    DMA ISR Reque test
       
   138 //!
       
   139 //! @SYMTestActions     
       
   140 //!						1.
       
   141 //!						2.	
       
   142 //!
       
   143 //!
       
   144 //! @SYMTestExpectedResults 
       
   145 //!						1.  
       
   146 //!						2.		
       
   147 //!							
       
   148 //!
       
   149 //! @SYMTestPriority        High
       
   150 //! @SYMTestStatus          Implemented
       
   151 //----------------------------------------------------------------------------------------------
       
   152 namespace ISR_Reque
       
   153 	{
       
   154 	const TInt size = 4 * KKilo;
       
   155 	TDmaTransferArgs tferArgs(0, 2*size, size, KDmaMemAddr, KDmaSyncAuto, KDmaRequestCallbackFromIsr);
       
   156 
       
   157 	const TRequestResults requestResult(KErrNone, 1); // request must be in a single fragment
       
   158 
       
   159 	namespace endOnIsrCb
       
   160 		{
       
   161 		TIsrRequeArgs requeArgs[] = {
       
   162 			TIsrRequeArgs(),
       
   163 			TIsrRequeArgs(size,3*size,size,0, ETrue),
       
   164 			TIsrRequeArgs(size,4*size,size,0, ETrue),
       
   165 			TIsrRequeArgs(0,5*size,size,0, ETrue),
       
   166 		};
       
   167 		const TInt count = ARRAY_LENGTH(requeArgs);
       
   168 
       
   169 		// we expect a cb for each requeue + 1 for the original
       
   170 		// transfer
       
   171 		const TCallbackRecord callbackRecord = TCallbackRecord(TCallbackRecord::EIsr, count + 1).IsrRedoResult(KErrNone);
       
   172 		const TResultSet expected(KErrNone, requestResult, KErrNone, callbackRecord);
       
   173 
       
   174 		TTestCase testCase(new (ELeave) CIsrRequeTest(_L("4 Requeues - end on isr cb"), 1, tferArgs, requeArgs, count, expected, &KPreTransferIncrBytes, &KCompareSrcDst), ETrue, capAboveV1);
       
   175 		}
       
   176 
       
   177 	namespace endOnThreadCb
       
   178 		{
       
   179 		TIsrRequeArgs requeArgs[] = {
       
   180 			TIsrRequeArgs(),
       
   181 			TIsrRequeArgs(size,3*size,size,0, ETrue),
       
   182 			TIsrRequeArgs(size,4*size,size,0, ETrue),
       
   183 			TIsrRequeArgs(0,5*size,size,0, EFalse),
       
   184 		};
       
   185 		const TInt count = ARRAY_LENGTH(requeArgs);
       
   186 
       
   187 		const TCallbackRecord callbackRecord = TCallbackRecord(TCallbackRecord::EThread, count + 1).IsrRedoResult(KErrNone);
       
   188 		const TResultSet expected(KErrNone, requestResult, KErrNone, callbackRecord);
       
   189 
       
   190 		TTestCase testCase(new (ELeave) CIsrRequeTest(_L("4 Requeues - end on thread cb"), 1, tferArgs, requeArgs, count, expected, &KPreTransferIncrBytes, &KCompareSrcDst), ETrue, capAboveV1);
       
   191 		}
       
   192 
       
   193 	namespace changeSize
       
   194 		{
       
   195 		TIsrRequeArgs requeArgs[] = {
       
   196 			TIsrRequeArgs(3*size,5*size,2*size,0, EFalse),
       
   197 		};
       
   198 		const TInt count = ARRAY_LENGTH(requeArgs);
       
   199 
       
   200 		const TCallbackRecord callbackRecord = TCallbackRecord(TCallbackRecord::EThread, count + 1).IsrRedoResult(KErrNone);
       
   201 		const TResultSet expected(KErrNone, requestResult, KErrNone, callbackRecord);
       
   202 
       
   203 		TTestCase testCase(new (ELeave) CIsrRequeTest(_L("1 Requeues - change transfer size"), 1, tferArgs, requeArgs, count, expected, &KPreTransferIncrBytes, &KCompareSrcDst), ETrue, capAboveV1);
       
   204 		}
       
   205 
       
   206 	namespace endOnRedo
       
   207 		{
       
   208 		// TODO have made this bigger than 4k so that we don't miss the second interrupt when tracing enabled
       
   209 		// this indicates the PSL's interrupt handler misses an interrupt if it occurs during the interrupt.
       
   210 		const TInt size = 0x10000;
       
   211 		TDmaTransferArgs tferArgs(0, 2*size, size, KDmaMemAddr, KDmaSyncAuto, KDmaRequestCallbackFromIsr);
       
   212 
       
   213 		TIsrRequeArgs requeArgs[] = {
       
   214 			TIsrRequeArgs(3*size,5*size,2*size,0, ETrue),
       
   215 			TIsrRequeArgs() //repeat the previous transfer
       
   216 		};
       
   217 		const TInt count = ARRAY_LENGTH(requeArgs);
       
   218 
       
   219 		const TCallbackRecord callbackRecord = TCallbackRecord(TCallbackRecord::EIsr, count + 1).IsrRedoResult(KErrNone);
       
   220 		const TResultSet expected(KErrNone, requestResult, KErrNone, callbackRecord);
       
   221 
       
   222 		TTestCase testCase(new (ELeave) CIsrRequeTest(_L("2 Requeues - Isr redo request repeated"), 1, tferArgs, requeArgs, count, expected, &KPreTransferIncrBytes, &KCompareSrcDst), EFalse, capAboveV1);
       
   223 		}
       
   224 
       
   225 	namespace invalidAddresses
       
   226 		{
       
   227 		TIsrRequeArgs requeArgs[] = {
       
   228 			TIsrRequeArgs(size, size)
       
   229 		};
       
   230 		const TInt count = ARRAY_LENGTH(requeArgs);
       
   231 
       
   232 		const TCallbackRecord callbackRecord = TCallbackRecord(TCallbackRecord::EIsr, 1).IsrRedoResult(KErrArgument);
       
   233 		const TResultSet expected(KErrNone, requestResult, KErrUnknown, callbackRecord);
       
   234 
       
   235 		// pre and post test would fail because of bad requeue parameters
       
   236 		TTestCase testCase(new (ELeave) CIsrRequeTest(_L("Requeue with matching addresses"), 1, tferArgs, requeArgs, count, expected, NULL, NULL), ETrue, capAboveV1);
       
   237 		}
       
   238 
       
   239 	namespace multipleFragments
       
   240 		{
       
   241 		TIsrRequeArgs requeArgs[] = {
       
   242 			TIsrRequeArgs()
       
   243 		};
       
   244 		const TInt count = ARRAY_LENGTH(requeArgs);
       
   245 
       
   246 		const TCallbackRecord callbackRecord = TCallbackRecord(TCallbackRecord::EThread, count + 1).IsrRedoResult(KErrNone);
       
   247 
       
   248 		TRequestResults results2Fragments = TRequestResults(requestResult).FragmentCount(2);
       
   249 		const TResultSet expected(KErrNone, results2Fragments, KErrNone, callbackRecord);
       
   250 
       
   251 		TTestCase testCase(new (ELeave) CIsrRequeTest(_L("Attempt to Requeue 2 fragment request"), 1, tferArgs, requeArgs, count, expected, &KPreTransferIncrBytes, &KCompareSrcDst, size/2), ETrue, capAboveV1);
       
   252 
       
   253 		}
       
   254 	}
       
   255 
       
   256 //----------------------------------------------------------------------------------------------
       
   257 //! @SYMTestCaseID      PBASE-DMA-FUNC-xxx
       
   258 //! @SYMTestType        CIT
       
   259 //! @SYMPREQ            REQ
       
   260 //! @SYMTestCaseDesc    DMA Multiple transfer test
       
   261 //! @SYMTestActions     
       
   262 //!						1.
       
   263 //!						2.	
       
   264 //!
       
   265 //!
       
   266 //! @SYMTestExpectedResults 
       
   267 //!						1.  
       
   268 //!						2.		
       
   269 //!							
       
   270 //!
       
   271 //! @SYMTestPriority        High
       
   272 //! @SYMTestStatus          Implemented
       
   273 //----------------------------------------------------------------------------------------------
       
   274 namespace Multipart
       
   275 	{
       
   276 	// need long transfer, to try and force adjacent
       
   277 	// requests to be concatinated
       
   278 	const TInt size = 2 * KMega;
       
   279 	const TDmaTransferArgs transferArgArray[] = {
       
   280 		TDmaTransferArgs(0, size, size, KDmaMemAddr),
       
   281 		TDmaTransferArgs(size, 2 * size, size, KDmaMemAddr)
       
   282 	};
       
   283 
       
   284 	const TResultSet expected[] =
       
   285 		{
       
   286 		TResultSet(),
       
   287 		TResultSet()
       
   288 		};
       
   289 	const TResultSet expectedResults(isrCallback);
       
   290 
       
   291 	CMultiTransferTest multipart =
       
   292 		CMultiTransferTest(_L("Sg request concatination"), 1, transferArgArray, expected, ARRAY_LENGTH(transferArgArray))
       
   293 			.SetPreTransferTest(&KPreTransferIncrBytes)
       
   294 			.SetPostTransferTest(&KCompareSrcDst);
       
   295 
       
   296 	TTestCase testCase(&multipart, EFalse, hwDesWanted_skip);
       
   297 	}
       
   298 
       
   299 //----------------------------------------------------------------------------------------------
       
   300 //! @SYMTestCaseID      KBASE-DMA-2580
       
   301 //! @SYMTestType        CIT
       
   302 //! @SYMPREQ            REQ
       
   303 //! @SYMTestCaseDesc    These tests attempt to queue ISR cb requests while the queue is not 
       
   304 //!						empty and queing normal requests when an ISR cb is pending
       
   305 //! @SYMTestActions     
       
   306 //!						1.
       
   307 //!						2.	
       
   308 //!
       
   309 //!
       
   310 //! @SYMTestExpectedResults 
       
   311 //!						1.  
       
   312 //!						2.		
       
   313 //!							
       
   314 //!
       
   315 //! @SYMTestPriority        High
       
   316 //! @SYMTestStatus          Implemented
       
   317 //----------------------------------------------------------------------------------------------
       
   318 namespace IsrAndDfc
       
   319 	{
       
   320 	// need long transfer, so that 1st request is still queued
       
   321 	// when the second one is queued
       
   322 	// TODO pause is the better way to ensure this
       
   323 	//const TInt size = 2 * KMega;
       
   324 	//TODO have changed size to ensure that the first isr callback request in IsrBeforeDfc
       
   325 	//will only have one fragment
       
   326 	const TInt size = 0x40000;
       
   327 	TDmaTransferArgs dfcTransfer(0, size, size, KDmaMemAddr);
       
   328 	TDmaTransferArgs isrTransfer(size, 2 * size, size, KDmaMemAddr, KDmaSyncAuto, KDmaRequestCallbackFromIsr);
       
   329 
       
   330 	const TResultSet success = TResultSet();
       
   331 	TResultSet queueFailure = TResultSet().
       
   332 			RequestResult(TRequestResults().QueueResult(KErrGeneral)).
       
   333 			CallbackRecord(TCallbackRecord::Empty()).
       
   334 			PostTransferResult(1);
       
   335 
       
   336 	namespace DfcBeforeIsr
       
   337 		{
       
   338 		const TDmaTransferArgs transferArgArray[] = {
       
   339 			dfcTransfer,
       
   340 			isrTransfer
       
   341 		};
       
   342 
       
   343 		const TResultSet expected[] =
       
   344 			{
       
   345 			success,
       
   346 			queueFailure
       
   347 			};
       
   348 		CMultiTransferTest dfcBeforeIsr =
       
   349 			CMultiTransferTest(_L("DFC cb req before ISR cb req "), 1, transferArgArray, expected, ARRAY_LENGTH(transferArgArray))
       
   350 				.SetPreTransferTest(&KPreTransferIncrBytes)
       
   351 				.SetPostTransferTest(&KCompareSrcDst);
       
   352 		TTestCase testCase(&dfcBeforeIsr, EFalse, hwDesWanted_skip);
       
   353 		}
       
   354 
       
   355 	namespace IsrBeforeDfc
       
   356 		{
       
   357 		const TDmaTransferArgs transferArgArray[] = {
       
   358 			isrTransfer,
       
   359 			dfcTransfer
       
   360 		};
       
   361 
       
   362 		TResultSet isrSuccess = TResultSet(success).CallbackRecord(isrCallback);
       
   363 		const TResultSet expected[] =
       
   364 			{
       
   365 			isrSuccess,
       
   366 			queueFailure
       
   367 			};
       
   368 		CMultiTransferTest dfcBeforeIsr =
       
   369 			CMultiTransferTest(_L("ISR cb req before DFC cb req "), 1, transferArgArray, expected, ARRAY_LENGTH(transferArgArray))
       
   370 				.SetPreTransferTest(&KPreTransferIncrBytes)
       
   371 				.SetPostTransferTest(&KCompareSrcDst);
       
   372 		TTestCase testCase(&dfcBeforeIsr, EFalse, hwDesWanted_skip);
       
   373 		}
       
   374 
       
   375 	}
       
   376 
       
   377 //----------------------------------------------------------------------------------------------
       
   378 //! @SYMTestCaseID      PBASE-DMA-FUNC-xxx
       
   379 //! @SYMTestType        CIT
       
   380 //! @SYMPREQ            REQ
       
   381 //! @SYMTestCaseDesc    DMA 2D transfer test
       
   382 //!
       
   383 //! @SYMTestActions     
       
   384 //!						1.
       
   385 //!						2.	
       
   386 //!
       
   387 //!
       
   388 //! @SYMTestExpectedResults 
       
   389 //!						1.  
       
   390 //!						2.		
       
   391 //!							
       
   392 //!
       
   393 //! @SYMTestPriority        High
       
   394 //! @SYMTestStatus          Implemented
       
   395 //----------------------------------------------------------------------------------------------
       
   396 namespace _2D_Test
       
   397 	{
       
   398 	// Image @ 0x0 with 640x480 pixels and 24 bits/pixel.
       
   399 
       
   400 	TDmaTransferConfig src(
       
   401 		0, /*iAddr*/
       
   402 		3, /*iElementSize*/
       
   403 		6, /*iElementsPerFrame*/
       
   404 		4, /*iFramesPerTransfer*/
       
   405 		0, /*iElementSkip*/
       
   406 		0, /*iFrameSkip*/
       
   407 		KDmaMemAddr /*iFlags*/
       
   408 		);
       
   409 
       
   410 	TDmaTransferConfig dst(
       
   411 		0x708000, /*iAddr*/
       
   412 		3, /*iElementSize*/
       
   413 		640, /*iElementsPerFrame*/
       
   414 		480, /*iFramesPerTransfer*/
       
   415 		1437, /*iElementSkip*/
       
   416 		-920166, /*iFrameSkip*/
       
   417 		KDmaMemAddr /*iFlags*/
       
   418 		);
       
   419 
       
   420 	TDmaTransferArgs transferArgs2D(src, dst);
       
   421 
       
   422 	TResultSet expectedResults; //all KErrNone
       
   423 
       
   424 	//source buffer is currently filled with increasing values
       
   425 	//instead of an image, but the test is still valid
       
   426 	CSingleTransferTest transfer2d(_L("2D Transfer"), 1, transferArgs2D, expectedResults, 0, &KCompare2D);
       
   427 
       
   428 	TTestCase testCase2d(&transfer2d, EFalse, cap_2DRequired, capAboveV1);
       
   429 	}
       
   430 
       
   431 //----------------------------------------------------------------------------------------------
       
   432 //! @SYMTestCaseID      KBASE-DMA-2565
       
   433 //! @SYMTestType        CIT
       
   434 //! @SYMPREQ            REQ
       
   435 //! @SYMTestCaseDesc    DMA Fragmentation count test
       
   436 //!
       
   437 //! @SYMTestActions     
       
   438 //!						1.
       
   439 //!						2.	
       
   440 //!
       
   441 //!
       
   442 //! @SYMTestExpectedResults 
       
   443 //!						1.  
       
   444 //!						2.		
       
   445 //!							
       
   446 //!
       
   447 //! @SYMTestPriority        High
       
   448 //! @SYMTestStatus          Implemented
       
   449 //----------------------------------------------------------------------------------------------
       
   450 namespace FragmentationCount
       
   451 	{
       
   452 	TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   453 
       
   454 	const TRequestResults requestResult(KErrNone, 128);
       
   455 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   456 	CSingleTransferTest test1(_L("Fragmentation Count - 128 fragments"), 1, transferArgs, expectedResults, KKilo);
       
   457 	TTestCase testCase(&test1, EFalse);
       
   458 
       
   459 	const TRequestResults requestResult2(KErrNone, 4);
       
   460 	const TResultSet expectedResults2(KErrNone, requestResult2, KErrNone, threadCallback);
       
   461 	CSingleTransferTest test2(_L("Fragmentation Count - 4 fragments"), 1, transferArgs, expectedResults2, 32*KKilo);
       
   462 	TTestCase testCase2(&test2, EFalse);
       
   463 	}
       
   464 
       
   465 //----------------------------------------------------------------------------------------------
       
   466 //! @SYMTestCaseID      KBASE-DMA-2584,KBASE-DMA-2585
       
   467 //! @SYMTestType        CIT
       
   468 //! @SYMPREQ            REQ
       
   469 //! @SYMTestCaseDesc    DMA Benchmark tests
       
   470 //!
       
   471 //! @SYMTestActions     
       
   472 //!						1.
       
   473 //!						2.	
       
   474 //!
       
   475 //!
       
   476 //! @SYMTestExpectedResults 
       
   477 //!						1.  
       
   478 //!						2.		
       
   479 //!							
       
   480 //!
       
   481 //! @SYMTestPriority        High
       
   482 //! @SYMTestStatus          Implemented
       
   483 //-----------------------------------------------------------------------------------------------
       
   484 namespace Benchmark
       
   485 	{
       
   486 	const TInt bmIters = 10;
       
   487 	namespace Frag
       
   488 		{
       
   489 		const TInt size = 1 * KMega;
       
   490 		TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   491 
       
   492 		TTestCase testCase_256k(new (ELeave) CDmaBmFragmentation(_L("1 Mb transfer - 256k frag size"), bmIters, transferArgs, 256 * KKilo), EFalse);
       
   493 		TTestCase testCase_8k(new (ELeave) CDmaBmFragmentation(_L("1 Mb transfer - 8k frag size"), bmIters, transferArgs, 8 * KKilo), EFalse);
       
   494 		}
       
   495 
       
   496 	namespace Transfer
       
   497 		{
       
   498 		namespace _4Bytes
       
   499 			{
       
   500 			const TInt size = 4;
       
   501 			TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   502 
       
   503 			CDmaBmTransfer bmTest(_L("4 bytes"), bmIters, transferArgs, 0);
       
   504 			TTestCase testCase(&bmTest, EFalse);
       
   505 			}
       
   506 		namespace _128K
       
   507 			{
       
   508 			const TInt size = 128 * KKilo;
       
   509 			TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   510 
       
   511 			TTestCase testCase_128(new (ELeave) CDmaBmTransfer(_L("128 K - 128K frag size"), bmIters, transferArgs, 128 * KKilo), EFalse);
       
   512 			TTestCase testCase_16(new (ELeave) CDmaBmTransfer(_L("128 K - 16k frag size"), bmIters, transferArgs, 16 * KKilo), EFalse);
       
   513 			TTestCase testCase_4(new (ELeave) CDmaBmTransfer(_L("128 K - 4k frag size"), bmIters, transferArgs, 4 * KKilo), EFalse);
       
   514 			TTestCase testCase_1(new (ELeave) CDmaBmTransfer(_L("128 K - 1k frag size"), bmIters, transferArgs, 1 * KKilo), EFalse);
       
   515 			}
       
   516 		namespace _4Mb
       
   517 			{
       
   518 			const TInt size = 4 * KMega;
       
   519 			TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   520 
       
   521 			CDmaBmTransfer bmTest(_L("4 Mb"), bmIters, transferArgs, 0);
       
   522 			TTestCase testCase(&bmTest, EFalse);
       
   523 			}
       
   524 		}
       
   525 
       
   526 	/**
       
   527 	Compare time taken between queing and callback of 4 byte
       
   528 	request with both DFC and ISR callback
       
   529 	The new API calls are used
       
   530 	*/
       
   531 	namespace CompareIsrDfcCb
       
   532 		{
       
   533 		const TInt iterations = 50;
       
   534 
       
   535 		namespace Dfc
       
   536 			{
       
   537 			TResultSet expected = TResultSet(threadCallback).
       
   538 				PostTransferResult(KErrUnknown);
       
   539 
       
   540 			namespace _4Bytes
       
   541 				{
       
   542 				const TInt size = 4;
       
   543 				TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   544 				CDmaBmTransfer bmTest = CDmaBmTransfer(_L("4 bytes DFC cb"), iterations, transferArgs, 0).
       
   545 					UseNewDmaApi(ETrue).
       
   546 					ExpectedResults(expected);
       
   547 				TTestCase testCase(&bmTest, EFalse);
       
   548 				}
       
   549 			namespace _4K
       
   550 				{
       
   551 				const TInt size = 4 * KKilo;
       
   552 				TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
   553 				CDmaBmTransfer bmTest = CDmaBmTransfer(_L("4K DFC cb"), iterations, transferArgs, 0).
       
   554 					UseNewDmaApi(ETrue).
       
   555 					ExpectedResults(expected);
       
   556 				TTestCase testCase(&bmTest, EFalse);
       
   557 				}
       
   558 			}
       
   559 
       
   560 		namespace Isr
       
   561 			{
       
   562 			TResultSet expected = TResultSet(isrCallback).
       
   563 				PostTransferResult(KErrUnknown);
       
   564 
       
   565 			namespace _4Bytes
       
   566 				{
       
   567 				const TInt size = 4;
       
   568 				TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr, KDmaSyncAuto, KDmaRequestCallbackFromIsr);
       
   569 				CDmaBmTransfer bmTest = CDmaBmTransfer(_L("4 bytes Isr cb"), iterations, transferArgs, 0).
       
   570 					UseNewDmaApi(ETrue).
       
   571 					ExpectedResults(expected);
       
   572 				TTestCase testCase(&bmTest, EFalse);
       
   573 				}
       
   574 			namespace _4K
       
   575 				{
       
   576 				const TInt size = 4 * KKilo;
       
   577 				TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr, KDmaSyncAuto, KDmaRequestCallbackFromIsr);
       
   578 				CDmaBmTransfer bmTest = CDmaBmTransfer(_L("4K Isr cb"), iterations, transferArgs, 0).
       
   579 					UseNewDmaApi(ETrue).
       
   580 					ExpectedResults(expected);
       
   581 				TTestCase testCase(&bmTest, EFalse);
       
   582 				}
       
   583 			}
       
   584 		}
       
   585 	}
       
   586 
       
   587 //----------------------------------------------------------------------------------------------
       
   588 //! @SYMTestCaseID      KBASE-DMA-2560
       
   589 //! @SYMTestType        CIT
       
   590 //! @SYMPREQ            REQ
       
   591 //! @SYMTestCaseDesc    TestNewStyleFragment using CSingleTransferTest
       
   592 //!						Test Scenario 1 - DstAddr > SrcAddr & TransferSize=32K & Location is 
       
   593 //!						address of a memory buffer
       
   594 //! @SYMTestActions     
       
   595 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   596 //!							
       
   597 //!							SrcAddr		 = 4 * KKilo;
       
   598 //!							desAddr		 = 64 * KKilo;
       
   599 //!							transferSize = 32 * KKilo;	
       
   600 //!							iFlags		 = KDmaMemAddr;
       
   601 //!
       
   602 //!						2.	Setup expected result.
       
   603 //!						3.	Create single transfer test and run test
       
   604 //!
       
   605 //! @SYMTestExpectedResults 
       
   606 //!						1.  TransfeArgs set up in DMA framework
       
   607 //!						2.	Expected results set up in DMA framework					
       
   608 //!						3.	Fragment request completes and KErrNone returned
       
   609 //!
       
   610 //! @SYMTestPriority        High
       
   611 //! @SYMTestStatus          Implemented
       
   612 //----------------------------------------------------------------------------------------------
       
   613 namespace TestNewStyleFragment_1
       
   614 	{	
       
   615 	const TInt srcAddr = 4 * KKilo;
       
   616 	const TInt desAddr = 64 * KKilo;
       
   617 
       
   618 	const TInt transferSize =  32 * KKilo;
       
   619 	
       
   620 	TDmaTransferArgs transferArgs( srcAddr, desAddr, transferSize, KDmaMemAddr);
       
   621 
       
   622 	const TRequestResults requestResult(KErrNone, 32); 
       
   623 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   624 
       
   625 	CSingleTransferTest testscenario_1(_L("TestNewStyleFragment - Test Scenario 1"), 1, transferArgs, expectedResults,KKilo);
       
   626 
       
   627 	TTestCase testCase(&testscenario_1, EFalse, capAboveV1);
       
   628 	TTestCase testCaseConcurrent(&testscenario_1, ETrue, capAboveV1);
       
   629 	}
       
   630 
       
   631 //----------------------------------------------------------------------------------------------
       
   632 //! @SYMTestCaseID      KBASE-DMA-2560
       
   633 //! @SYMTestType        CIT
       
   634 //! @SYMPREQ            REQ
       
   635 //! @SYMTestCaseDesc    TestNewStyleFragment using CSingleTransferTest
       
   636 //!						Test Scenario 2 -  SrcAddr	== DstAddr   					
       
   637 //!		
       
   638 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   639 //!							
       
   640 //!							SrcAddr	 = 4 * KKilo;
       
   641 //!							desAddr	 = 4 * KKilo;
       
   642 //!							transferSize = 32 * KKilo;	
       
   643 //!							iFlags		 = KDmaMemAddr;
       
   644 //!
       
   645 //!						2.	Setup expected result.
       
   646 //!						3.	Create single transfer test and run test
       
   647 //!
       
   648 //! @SYMTestExpectedResults 
       
   649 //!
       
   650 //!						1.  TransfeArgs set up in DMA framework
       
   651 //!						2.	Expected results set up in DMA framework					
       
   652 //!						3.	Fragment passes and KErrNone returned
       
   653 //!
       
   654 //! @SYMTestPriority        High
       
   655 //! @SYMTestStatus          Implemented
       
   656 //----------------------------------------------------------------------------------------------
       
   657 namespace TestNewStyleFragment_2
       
   658 	{
       
   659 	const TInt srcAddr = 4 * KKilo;
       
   660 	const TInt desAddr = 4 * KKilo;
       
   661 	const TInt transferSize =  32 * KKilo;
       
   662 
       
   663 	TDmaTransferArgs transferArgs(srcAddr,desAddr, transferSize, KDmaMemAddr);
       
   664 	const TRequestResults requestResult(KErrNone, 32); 
       
   665 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   666 
       
   667 	CSingleTransferTest testscenario_2(_L("TestNewStyleFragment - Test Scenario 2"), 1, transferArgs, expectedResults,KKilo);
       
   668 
       
   669 	TTestCase testCase(&testscenario_2, EFalse, capAboveV1);
       
   670 	TTestCase testCaseConcurrent(&testscenario_2, ETrue, capAboveV1);
       
   671 	}
       
   672 
       
   673 //----------------------------------------------------------------------------------------------
       
   674 //! @SYMTestCaseID      KBASE-DMA-2560
       
   675 //! @SYMTestType        CIT
       
   676 //! @SYMPREQ            REQ
       
   677 //! @SYMTestCaseDesc    TestNewStyleFragment using CSingleTransferTest
       
   678 //!						Test Scenario 3 -  TransferSize=0   
       
   679 //!
       
   680 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   681 //!							
       
   682 //!							SrcAddr		 = 32 * KKilo;
       
   683 //!							desAddr		 = 64 * KKilo;
       
   684 //!							transferSize = 0	
       
   685 //!							iFlags		 = KDmaMemAddr;
       
   686 //!
       
   687 //!						2.	Setup expected result.
       
   688 //!						3.	Create single transfer test and run test
       
   689 //!
       
   690 //!
       
   691 //! @SYMTestExpectedResults 
       
   692 //!
       
   693 //!						1.  TransfeArgs set up in DMA framework
       
   694 //!						2.	Expected results set up in DMA framework			
       
   695 //!						3.	Fragment request fails and KErrArgument returned
       
   696 //!
       
   697 //! @SYMTestPriority        High
       
   698 //! @SYMTestStatus          Implemented
       
   699 //----------------------------------------------------------------------------------------------
       
   700 namespace TestNewStyleFragment_3
       
   701 	{
       
   702 	const TInt srcAddr = 32 * KKilo;
       
   703 	const TInt desAddr = 64 * KKilo;
       
   704 	const TInt transferSize = 0;
       
   705 	
       
   706 	TDmaTransferArgs transferArgs( srcAddr, desAddr, transferSize,KDmaMemAddr);
       
   707 	const TRequestResults requestResult(KErrArgument, 0); 
       
   708 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   709 
       
   710 	CSingleTransferTest testscenario_3(_L("TestNewStyleFragment - Test Scenario 3"), 1, transferArgs, expectedResults);
       
   711 
       
   712 	TTestCase testCase(&testscenario_3, EFalse, capAboveV1);
       
   713 	TTestCase testCaseConcurrent(&testscenario_3, ETrue, capAboveV1);
       
   714 	}
       
   715 
       
   716 //----------------------------------------------------------------------------------------------
       
   717 //! @SYMTestCaseID      KBASE-DMA-2560
       
   718 //! @SYMTestType        CIT
       
   719 //! @SYMPREQ            REQ
       
   720 //! @SYMTestCaseDesc    TestNewStyleFragment using CSingleTransferTest
       
   721 //!						Test Scenario 4 -  TransferSize=1Byte   
       
   722 //!
       
   723 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   724 //!							
       
   725 //!							SrcAddr		 = 32K;
       
   726 //!							desAddr		 = 64K;
       
   727 //!							transferSize = 1 byte	
       
   728 //!							iFlags		 = KDmaMemAddr;
       
   729 //!
       
   730 //!						2.	Setup expected result.
       
   731 //!						3.	Create single transfer test and run test
       
   732 //!
       
   733 //! @SYMTestExpectedResults 
       
   734 //!
       
   735 //!						1.  TransfeArgs set up in DMA framework
       
   736 //!						2.	Expected results set up in DMA framework			
       
   737 //!						3.	Fragment request completes and KErrNone returned
       
   738 //!
       
   739 //! @SYMTestPriority        High
       
   740 //! @SYMTestStatus          Implemented
       
   741 //----------------------------------------------------------------------------------------------
       
   742 namespace TestNewStyleFragment_4
       
   743 	{	
       
   744 	const TInt srcAddr = 32 * KKilo;
       
   745 	const TInt desAddr = 64 * KKilo;
       
   746 	const TInt transferSize = 1;
       
   747 	
       
   748 	TDmaTransferArgs transferArgs(srcAddr, desAddr, transferSize, KDmaMemAddr);
       
   749 	const TRequestResults requestResult(KErrNone, 1);
       
   750 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   751 
       
   752 	CSingleTransferTest testscenario_4(_L("TestNewStyleFragment - Test Scenario 4"), 1, transferArgs, expectedResults);
       
   753 
       
   754 	TTestCase testCase(&testscenario_4, EFalse, capAboveV1);
       
   755 	TTestCase testCaseConcurrent(&testscenario_4, ETrue, capAboveV1);
       
   756 	}
       
   757 
       
   758 //----------------------------------------------------------------------------------------------
       
   759 //! @SYMTestCaseID      KBASE-DMA-2560
       
   760 //! @SYMTestType        CIT
       
   761 //! @SYMPREQ            REQ
       
   762 //! @SYMTestCaseDesc    TestNewStyleFragment using CSingleTransferTest
       
   763 //!						Test Scenario 5 -  TransferSize=128KB    
       
   764 //!
       
   765 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   766 //!							
       
   767 //!							SrcAddr		 = 16K;
       
   768 //!							desAddr		 = 2MB;
       
   769 //!							transferSize = 1MB;
       
   770 //!							iFlags		 = KDmaMemAddr;
       
   771 //!
       
   772 //!						2.	Setup expected result.
       
   773 //!						3.	Create single transfer test and run test
       
   774 //!
       
   775 //! @SYMTestExpectedResults 
       
   776 //!
       
   777 //!						1.  TransfeArgs set up in DMA framework
       
   778 //!						2.	Expected results set up in DMA framework			
       
   779 //!						3.	Fragment request completes and KErrNone returned
       
   780 //!
       
   781 //! @SYMTestPriority        High
       
   782 //! @SYMTestStatus          Implemented
       
   783 //----------------------------------------------------------------------------------------------
       
   784 namespace TestNewStyleFragment_5
       
   785 	{
       
   786 	
       
   787 	const TInt srcAddr		= 16 * KKilo;
       
   788 	const TInt desAddr		= 2 * KMega;	
       
   789 	const TInt transferSize = 1 * KMega;
       
   790 
       
   791 	TDmaTransferArgs transferArgs(srcAddr, desAddr, transferSize, KDmaMemAddr);
       
   792 	const TRequestResults requestResult(KErrNone); 
       
   793 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   794 
       
   795 	CSingleTransferTest testscenario_5(_L("TestNewStyleFragment - Test Scenario 5"), 1, transferArgs, expectedResults);
       
   796 
       
   797 	TTestCase testCase(&testscenario_5, EFalse, capAboveV1);
       
   798 	TTestCase testCaseConcurrent(&testscenario_5, ETrue, capAboveV1);
       
   799 	}
       
   800 
       
   801 //----------------------------------------------------------------------------------------------
       
   802 //! @SYMTestCaseID      KBASE-DMA-2560
       
   803 //! @SYMTestType        CIT
       
   804 //! @SYMPREQ            REQ
       
   805 //! @SYMTestCaseDesc    TestNewStyleFragment using CSingleTransferTest
       
   806 //!						Test Scenario 6 -  TransferSize=3MB   
       
   807 //!
       
   808 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   809 //!							
       
   810 //!							SrcAddr		 = 16K;
       
   811 //!							desAddr		 = 4MB;
       
   812 //!							transferSize = 3MB 	
       
   813 //!							iFlags		 = KDmaMemAddr;
       
   814 //!
       
   815 //!						2.	Setup expected result.
       
   816 //!						3.	Create single transfer test and run test
       
   817 //!
       
   818 //! @SYMTestExpectedResults 
       
   819 //!
       
   820 //!						1.  TransfeArgs set up in DMA framework
       
   821 //!						2.	Expected results set up in DMA framework			
       
   822 //!						3.	Fragment request completes and KErrNone returned
       
   823 //!
       
   824 //! @SYMTestPriority        High
       
   825 //! @SYMTestStatus          Implemented
       
   826 //----------------------------------------------------------------------------------------------
       
   827 namespace TestNewStyleFragment_6
       
   828 	{
       
   829 	const TInt srcAddr = 16 * KKilo;
       
   830 	const TInt desAddr = 4 * KMega;
       
   831 	const TInt transferSize = 3 * KMega;
       
   832 
       
   833 	TDmaTransferArgs transferArgs(srcAddr, desAddr, transferSize, KDmaMemAddr);
       
   834 	const TRequestResults requestResult(KErrNone); 
       
   835 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   836 
       
   837 	CSingleTransferTest testscenario_6(_L("TestNewStyleFragment - Test Scenario 6"), 1, transferArgs, expectedResults);
       
   838 
       
   839 	TTestCase testCase(&testscenario_6, EFalse, capAboveV1);
       
   840 	TTestCase testCaseConcurrent(&testscenario_6, ETrue, capAboveV1);
       
   841 	}
       
   842 
       
   843 //----------------------------------------------------------------------------------------------
       
   844 //! @SYMTestCaseID      KBASE-DMA-2561
       
   845 //! @SYMTestType        CIT
       
   846 //! @SYMPREQ            REQ
       
   847 //! @SYMTestCaseDesc    TestOldstyleFragment using CSingleTransferTest
       
   848 //!						Test Scenario 1 - DstAddr > SrcAddr & TransferSize=32K & Location is 
       
   849 //!						address of a memory buffer
       
   850 //!
       
   851 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   852 //!							
       
   853 //!							SrcAddr		 = 4 * KKilo;
       
   854 //!							desAddr		 = 64 * KKilo;
       
   855 //!							transferSize = 32 * KKilo;	
       
   856 //!							iFlags		 = KDmaMemAddr;
       
   857 
       
   858 //!						2.	Setup expected result.
       
   859 //!						3.	Create single transfer test and run test
       
   860 //!
       
   861 //! @SYMTestExpectedResults 
       
   862 //!
       
   863 //!						1.  TransfeArgs set up in DMA framework
       
   864 //!						2.	Expected results set up in DMA framework					
       
   865 //!						3.	Fragment request completes and KErrNone returned
       
   866 //!
       
   867 //! @SYMTestPriority        High
       
   868 //! @SYMTestStatus          Implemented
       
   869 //----------------------------------------------------------------------------------------------
       
   870 namespace TestOldStyleFragment_1
       
   871 	{	
       
   872 	const TInt srcAddr = 4 * KKilo;
       
   873 	const TInt desAddr = 64 * KKilo;
       
   874 	const TInt transferSize =  32 * KKilo;
       
   875 	
       
   876 	TDmaTransferArgs transferArgs( srcAddr, desAddr, transferSize, KDmaMemAddr);
       
   877 
       
   878 	const TRequestResults requestResult(KErrNone,32); 
       
   879 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   880 
       
   881 	CSingleTransferTest testscenario_1 = CSingleTransferTest(_L("TestOldStyleFragment - Test Scenario 1"), 1, transferArgs, expectedResults,KKilo).
       
   882 		UseNewDmaApi(EFalse);
       
   883 
       
   884 	TTestCase testCase(&testscenario_1, EFalse, capAboveV1);
       
   885 	TTestCase testCaseConcurrent(&testscenario_1, ETrue, capAboveV1);
       
   886 	}
       
   887 
       
   888 //----------------------------------------------------------------------------------------------
       
   889 //! @SYMTestCaseID      KBASE-DMA-2561
       
   890 //! @SYMTestType        CIT
       
   891 //! @SYMPREQ            REQ
       
   892 //! @SYMTestCaseDesc    TestOldstyleFragment using CSingleTransferTest
       
   893 //!						Test Scenario 2 - DstAddr == SrcAddr
       
   894 //!
       
   895 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   896 //!							
       
   897 //!							SrcAddr	 = 4 * KKilo;
       
   898 //!							desAddr	 = 4 * KKilo;
       
   899 //!							transferSize = 4 * KKilo
       
   900 //!							iFlags		 = KDmaMemAddr;
       
   901 //!
       
   902 //!						2.	Setup expected result.
       
   903 //!						3.	Create single transfer test and run test
       
   904 //!
       
   905 //! @SYMTestExpectedResults 
       
   906 //!
       
   907 //!						1.  TransfeArgs set up in DMA framework
       
   908 //!						2.	Expected results set up in DMA framework			
       
   909 //!						3.	Fragment passes and KErrNone returned
       
   910 //!
       
   911 //! @SYMTestPriority        High
       
   912 //! @SYMTestStatus          Implemented
       
   913 //----------------------------------------------------------------------------------------------
       
   914 namespace TestOldStyleFragment_2
       
   915 	{
       
   916 	const TInt srcAddr = 4 * KKilo;
       
   917 	const TInt desAddr = 4 * KKilo;
       
   918 	const TInt transferSize =  4 * KKilo;
       
   919 
       
   920 	TDmaTransferArgs transferArgs(srcAddr,desAddr, transferSize, KDmaMemAddr);
       
   921 	const TRequestResults requestResult(KErrNone, 4);  
       
   922 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   923 
       
   924 	CSingleTransferTest testscenario_2 = CSingleTransferTest(_L("TestOldStyleFragment - Test Scenario 2"), 1, transferArgs, expectedResults,KKilo)
       
   925 		.UseNewDmaApi(EFalse);
       
   926 
       
   927 	TTestCase testCase(&testscenario_2, EFalse, capAboveV1);
       
   928 	TTestCase testCaseConcurrent(&testscenario_2, ETrue, capAboveV1);
       
   929 	}
       
   930 
       
   931 //----------------------------------------------------------------------------------------------
       
   932 //! @SYMTestCaseID      KBASE-DMA-2561
       
   933 //! @SYMTestType        CIT
       
   934 //! @SYMPREQ            REQ
       
   935 //! @SYMTestCaseDesc    TestOldstyleFragment using CSingleTransferTest
       
   936 //!						Test Scenario 3 -  TransferSize=0  
       
   937 //!
       
   938 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   939 //!							
       
   940 //!							SrcAddr	 = 32K
       
   941 //!							desAddr	 = 64K;
       
   942 //!							transferSize = 0
       
   943 //!							iFlags		 = KDmaMemAddr;
       
   944 //!
       
   945 //!						2.	Setup expected result.
       
   946 //!						3.	Create single transfer test and run test
       
   947 //!
       
   948 //! @SYMTestExpectedResults 
       
   949 //!
       
   950 //!						1.  TransfeArgs set up in DMA framework
       
   951 //!						2.	Expected results set up in DMA framework			
       
   952 //!						3.	Fragment request Fails and KErrArgument returned
       
   953 //!
       
   954 //! @SYMTestPriority        High
       
   955 //! @SYMTestStatus          Implemented
       
   956 //----------------------------------------------------------------------------------------------
       
   957 namespace TestOldStyleFragment_3
       
   958 	{
       
   959 
       
   960 	const TInt srcAddr = 32 * KKilo;
       
   961 	const TInt desAddr = 64 * KKilo;
       
   962 	const TInt transferSize = 0;
       
   963 	
       
   964 	TDmaTransferArgs transferArgs(srcAddr, desAddr, transferSize,KDmaMemAddr);
       
   965 	const TRequestResults requestResult(KErrArgument, 0); 
       
   966 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
   967 
       
   968 	CSingleTransferTest testscenario_3 = CSingleTransferTest(_L("TestOldStyleFragment - Test Scenario 3"), 1, transferArgs, expectedResults).
       
   969 		UseNewDmaApi(EFalse);
       
   970 
       
   971 	TTestCase testCase(&testscenario_3, EFalse, capAboveV1);
       
   972 	TTestCase testCaseConcurrent(&testscenario_3, ETrue, capAboveV1);
       
   973 	}
       
   974 
       
   975 //----------------------------------------------------------------------------------------------
       
   976 //! @SYMTestCaseID      KBASE-DMA-2561
       
   977 //! @SYMTestType        CIT
       
   978 //! @SYMPREQ            REQ
       
   979 //! @SYMTestCaseDesc    TestOldstyleFragment using CSingleTransferTest
       
   980 //!						Test Scenario 4 -  TransferSize=1Byte   
       
   981 //!
       
   982 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
   983 //!							
       
   984 //!	
       
   985 //!							SrcAddr		 = 32K;
       
   986 //!							desAddr		 = 64K;
       
   987 //!							transferSize = 1 byte	
       
   988 //!							iFlags		 = KDmaMemAddr;
       
   989 //!
       
   990 //!						2.	Setup expected result.
       
   991 //!						3.	Create single transfer test and run test
       
   992 //!
       
   993 //! @SYMTestExpectedResults 
       
   994 //!
       
   995 //!						1.  TransfeArgs set up in DMA framework
       
   996 //!						2.	Expected results set up in DMA framework			
       
   997 //!						3.	Fragment request completes and KErrNone returned
       
   998 //!
       
   999 //! @SYMTestPriority        High
       
  1000 //! @SYMTestStatus          Implemented
       
  1001 //------------------------------------------------------------------------------------------------
       
  1002 namespace TestOldStyleFragment_4
       
  1003 	{	
       
  1004 	const TInt srcAddr = 32 * KKilo;
       
  1005 	const TInt desAddr = 64 * KKilo;
       
  1006 	const TInt transferSize = 1;
       
  1007 	
       
  1008 	TDmaTransferArgs transferArgs( srcAddr, desAddr, transferSize, KDmaMemAddr);
       
  1009 	const TRequestResults requestResult(KErrNone, 1); 
       
  1010 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1011 
       
  1012 	CSingleTransferTest testscenario_4 = CSingleTransferTest(_L("TestOldStyleFragment - Test Scenario 4"), 1, transferArgs, expectedResults).
       
  1013 		UseNewDmaApi(EFalse);
       
  1014 
       
  1015 	TTestCase testCase(&testscenario_4, EFalse, capAboveV1);
       
  1016 	TTestCase testCaseConcurrent(&testscenario_4, ETrue, capAboveV1);
       
  1017 	}
       
  1018 
       
  1019 //----------------------------------------------------------------------------------------------
       
  1020 //! @SYMTestCaseID      KBASE-DMA-2561
       
  1021 //! @SYMTestType        CIT
       
  1022 //! @SYMPREQ            REQ
       
  1023 //! @SYMTestCaseDesc    TestOldstyleFragment using CSingleTransferTest
       
  1024 //!						Test Scenario 5 -  TransferSize=1MB
       
  1025 //!
       
  1026 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
  1027 //!							
       
  1028 //!							SrcAddr		 = 16K;
       
  1029 //!							desAddr		 = 2MB;
       
  1030 //!							transferSize = 1MB	
       
  1031 //!							iFlags		 = KDmaMemAddr;
       
  1032 //!
       
  1033 //!						2.	Setup expected result.
       
  1034 //!						3.	Create single transfer test and run test
       
  1035 //!
       
  1036 //! @SYMTestExpectedResults 
       
  1037 //!
       
  1038 //!						1.  TransfeArgs set up in DMA framework
       
  1039 //!						2.	Expected results set up in DMA framework			
       
  1040 //!						3.	Fragment request completes and KErrNone returned
       
  1041 //!
       
  1042 //! @SYMTestPriority        High
       
  1043 //! @SYMTestStatus          Implemented
       
  1044 //----------------------------------------------------------------------------------------------
       
  1045 namespace TestOldStyleFragment_5
       
  1046 	{
       
  1047 	const TInt srcAddr = 16 * KKilo;	
       
  1048 	const TInt desAddr = 2 * KMega;
       
  1049 	const TInt transferSize = 1 *  KMega;
       
  1050 
       
  1051 	TDmaTransferArgs transferArgs(srcAddr, desAddr, transferSize, KDmaMemAddr);
       
  1052 
       
  1053 	const TRequestResults requestResult(KErrNone); 
       
  1054 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1055 
       
  1056 	CSingleTransferTest testscenario_5 = CSingleTransferTest(_L("TestOldStyleFragment - Test Scenario 5"), 1, transferArgs, expectedResults).
       
  1057 		UseNewDmaApi(EFalse);
       
  1058 
       
  1059 	TTestCase testCase(&testscenario_5, EFalse, capAboveV1);
       
  1060 	TTestCase testCaseConcurrent(&testscenario_5, ETrue, capAboveV1);
       
  1061 	}
       
  1062 
       
  1063 //----------------------------------------------------------------------------------------------
       
  1064 //! @SYMTestCaseID      KBASE-DMA-2561
       
  1065 //! @SYMTestType        CIT
       
  1066 //! @SYMPREQ            REQ
       
  1067 //! @SYMTestCaseDesc    TestOldstyleFragment using CSingleTransferTest
       
  1068 //!						Test Scenario 6 -  TransferSize=3MB     
       
  1069 //!
       
  1070 //!						1.	Set up the arguments for aTransfeArgs using the settings below.
       
  1071 //!							
       
  1072 //!							SrcAddr	 = 16K
       
  1073 //!							desAddr	 = 4MB;
       
  1074 //!							transferSize = 3MB  
       
  1075 //!							iFlags		 = KDmaMemAddr;
       
  1076 //!
       
  1077 //!						2.	Setup expected result.
       
  1078 //!						3.	Create single transfer test and run test
       
  1079 //!
       
  1080 //! @SYMTestExpectedResults 
       
  1081 //!
       
  1082 //!						1.  TransfeArgs set up in DMA framework
       
  1083 //!						2.	Expected results set up in DMA framework			
       
  1084 //!						3.	Fragment request completes and KErrNone returned
       
  1085 //!
       
  1086 //! @SYMTestPriority        High
       
  1087 //! @SYMTestStatus          Implemented
       
  1088 //----------------------------------------------------------------------------------------------
       
  1089 namespace TestOldStyleFragment_6
       
  1090 	{
       
  1091 	const TInt srcAddr = 16 * KKilo;
       
  1092 	const TInt desAddr = 4 * KMega;
       
  1093 	const TInt transferSize = 3 * KMega; 
       
  1094 	TDmaTransferArgs transferArgs(srcAddr, desAddr, transferSize, KDmaMemAddr);
       
  1095 
       
  1096 	const TRequestResults requestResult(KErrNone); 
       
  1097 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1098 
       
  1099 	CSingleTransferTest testscenario_6 = CSingleTransferTest(_L("TestOldStyleFragment - Test Scenario 6"), 1, transferArgs, expectedResults).
       
  1100 		UseNewDmaApi(EFalse);
       
  1101 
       
  1102 	TTestCase testCase(&testscenario_6, EFalse, capAboveV1);
       
  1103 	TTestCase testCaseConcurrent(&testscenario_6, ETrue, capAboveV1);
       
  1104 	}
       
  1105 
       
  1106 //----------------------------------------------------------------------------------------------
       
  1107 //! @SYMTestCaseID      KBASE-DMA-2562
       
  1108 //! @SYMTestType        CIT
       
  1109 //! @SYMPREQ            REQ
       
  1110 //! @SYMTestCaseDesc    TestOldStyleDDmaRequest using CSingleTransferTest
       
  1111 //!						Test Scenario 1 -  aMaxTransferSize=0 
       
  1112 //!
       
  1113 //!						1.	Set up the DDmaRequest using  aMaxTransferSize set to 0. 
       
  1114 //!						2.	Setup expected result.
       
  1115 //!						3.	Create single transfer test and run test
       
  1116 //!
       
  1117 //! @SYMTestExpectedResults 
       
  1118 //!
       
  1119 //!						1.  TransfeArgs set up in DMA framework
       
  1120 //!						2.	Expected results set up in DMA framework			
       
  1121 //!						3.	DDmaRequest constructor behaves as expected and KErrArgument returned
       
  1122 //!
       
  1123 //! @SYMTestPriority        High
       
  1124 //! @SYMTestStatus          Implemented
       
  1125 //------------------------------------------------------------------------------------------------
       
  1126 namespace TestOldStyleDDmaRequest_1
       
  1127 	{
       
  1128 	const TInt desAddr = 4 * KKilo;
       
  1129 	const TInt transferSize = 4 * KKilo;
       
  1130 	TDmaTransferArgs transferArgs(0, desAddr, transferSize, KDmaMemAddr);
       
  1131 
       
  1132 	const TRequestResults requestResult(KErrNone, 0); 
       
  1133 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1134 
       
  1135 	CSingleTransferTest testscenario_1 = CSingleTransferTest(_L("TestOldStyleDDmaRequest - Test Scenario 1"), 1, transferArgs, expectedResults,0).
       
  1136 		UseNewDmaApi(EFalse);
       
  1137 
       
  1138 	TTestCase testCase(&testscenario_1, EFalse, capAboveV1);
       
  1139 	TTestCase testCaseConcurrent(&testscenario_1, ETrue, capAboveV1);
       
  1140 	}
       
  1141 
       
  1142 //!-------------------------------------------------------------------------------------------------
       
  1143 //! @SYMTestCaseID       KBASE-DMA-2562
       
  1144 //! @SYMTestType        CIT
       
  1145 //! @SYMPREQ            REQ
       
  1146 //! @SYMTestCaseDesc    TestOldStyleDDmaRequest using CSingleTransferTest
       
  1147 //!						Test Scenario 2 -  aMaxTransferSize= 65535   
       
  1148 //!
       
  1149 //!						1.	Set up the arguments for DDmaRequest using aMaxTransferSize set to 65535.
       
  1150 //!						2.	Setup expected result.
       
  1151 //!						3.	Create single transfer test and run test
       
  1152 //!
       
  1153 //! @SYMTestExpectedResults 
       
  1154 //!
       
  1155 //!						1.  TransfeArgs set up in DMA framework
       
  1156 //!						2.	Expected results set up in DMA framework			
       
  1157 //!						3.	DDmaRequest constructor behaves as expected and KErrArgument returned
       
  1158 //!
       
  1159 //! @SYMTestPriority        High
       
  1160 //! @SYMTestStatus          Implemented
       
  1161 //---------------------------------------------------------------------------------------------------
       
  1162 namespace TestOldStyleDDmaRequest_2
       
  1163 	{
       
  1164 	const TInt desAddr = 4 * KKilo;
       
  1165 	const TInt transferSize = 4 * KKilo;
       
  1166 	TDmaTransferArgs transferArgs(0, desAddr, transferSize, KDmaMemAddr);
       
  1167 
       
  1168 	const TRequestResults requestResult(KErrNone, 1); 
       
  1169 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1170 
       
  1171 	CSingleTransferTest testscenario_2 = CSingleTransferTest(_L("TestOldStyleDDmaRequest - Test Scenario 2"), 1, transferArgs, expectedResults, 65535).
       
  1172 		UseNewDmaApi(EFalse);
       
  1173 
       
  1174 	TTestCase testCase(&testscenario_2, EFalse, capAboveV1);
       
  1175 	TTestCase testCaseConcurrent(&testscenario_2, ETrue, capAboveV1);
       
  1176 	}
       
  1177 
       
  1178 //----------------------------------------------------------------------------------------------
       
  1179 //! @SYMTestCaseID      KBASE-DMA-2563
       
  1180 //! @SYMTestType        CIT
       
  1181 //! @SYMPREQ            REQ
       
  1182 //! @SYMTestCaseDesc    TestNewStyleDDmaRequest using CSingleTransferTest
       
  1183 //!						Test Scenario 1 -  aMaxTransferSize=0 
       
  1184 //!
       
  1185 //!						1.	Set up the DDmaRequest using  aMaxTransferSize set to 0. 
       
  1186 //!						2.	Setup expected result.
       
  1187 //!						3.	Create single transfer test and run test
       
  1188 //!
       
  1189 //! @SYMTestExpectedResults 
       
  1190 //!
       
  1191 //!						1.  TransfeArgs set up in DMA framework
       
  1192 //!						2.	Expected results set up in DMA framework			
       
  1193 //!						3.	DDmaRequest constructor behaves as expected and KErrArgument returned
       
  1194 //!
       
  1195 //! @SYMTestPriority        High
       
  1196 //! @SYMTestStatus          Implemented
       
  1197 //----------------------------------------------------------------------------------------------
       
  1198 namespace TestNewStyleDDmaRequest_1
       
  1199 	{
       
  1200 	const TInt desAddr = 4 * KKilo;
       
  1201 	const TInt transferSize = 4 * KKilo;
       
  1202 	TDmaTransferArgs transferArgs(0, desAddr, transferSize, KDmaMemAddr);
       
  1203 
       
  1204 	const TRequestResults requestResult(KErrNone, 0); 
       
  1205 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1206 
       
  1207 	CSingleTransferTest testscenario_1(_L("TestNewStyleDDmaRequest - Test Scenario 1"), 1, transferArgs, expectedResults,0);
       
  1208 
       
  1209 	TTestCase testCase(&testscenario_1, EFalse, capAboveV1);
       
  1210 	TTestCase testCaseConcurrent(&testscenario_1, ETrue, capAboveV1);
       
  1211 	}
       
  1212 
       
  1213 //!-------------------------------------------------------------------------------------------------
       
  1214 //! @SYMTestCaseID      KBASE-DMA-2563
       
  1215 //! @SYMTestType        CIT
       
  1216 //! @SYMPREQ            REQ
       
  1217 //! @SYMTestCaseDesc    TestNewStyleDDmaRequest using CSingleTransferTest
       
  1218 //!						Test Scenario 2 -  aMaxTransferSize= 65535   
       
  1219 //!
       
  1220 //!						1.	Set up the arguments for DDmaRequest using aMaxTransferSize set to 65535.
       
  1221 //!						2.	Setup expected result.
       
  1222 //!						3.	Create single transfer test and run test
       
  1223 //!
       
  1224 //! @SYMTestExpectedResults 
       
  1225 //!
       
  1226 //!						1.  TransfeArgs set up in DMA framework
       
  1227 //!						2.	Expected results set up in DMA framework			
       
  1228 //!						3.	DDmaRequest constructor behaves as expected and KErrArgument returned
       
  1229 //!
       
  1230 //! @SYMTestPriority        High
       
  1231 //! @SYMTestStatus          Implemented
       
  1232 //---------------------------------------------------------------------------------------------------
       
  1233 namespace TestNewStyleDDmaRequest_2
       
  1234 	{
       
  1235 	const TInt desAddr = 4 * KKilo;
       
  1236 	const TInt transferSize = 4 * KKilo;
       
  1237 	TDmaTransferArgs transferArgs(0, desAddr, transferSize, KDmaMemAddr);
       
  1238 
       
  1239 	const TRequestResults requestResult(KErrNone, 1); 
       
  1240 	const TResultSet expectedResults(KErrNone, requestResult, KErrNone, threadCallback);
       
  1241 
       
  1242 	CSingleTransferTest testscenario_2(_L("TestNewStyleDDmaRequest - Test Scenario 2"), 1, transferArgs, expectedResults, 65535);
       
  1243 
       
  1244 	TTestCase testCase(&testscenario_2, EFalse, capAboveV1);
       
  1245 	TTestCase testCaseConcurrent(&testscenario_2, ETrue, capAboveV1);
       
  1246 	}
       
  1247 
       
  1248 //----------------------------------------------------------------------------------------------
       
  1249 //! @SYMTestCaseID      PBASE-DMA-FUNC-xxx
       
  1250 //! @SYMTestType        CIT
       
  1251 //! @SYMPREQ            REQ
       
  1252 //! @SYMTestCaseDesc    SmallFrags: This test provokes the failure seen in DEF140598
       
  1253 //!						The test checks that requests with small fragments
       
  1254 //!						do not trigger a spurious missed interrupt clean up
       
  1255 //!
       
  1256 //! @SYMTestExpectedResults 
       
  1257 //!
       
  1258 //!						1.  		
       
  1259 //!						2.	
       
  1260 //!
       
  1261 //! @SYMTestPriority        High
       
  1262 //! @SYMTestStatus          Implemented
       
  1263 //----------------------------------------------------------------------------------------------
       
  1264 namespace SmallFrags
       
  1265 	{
       
  1266 	const TInt size = 32;
       
  1267 	TDmaTransferArgs transferArgs(0, size, size, KDmaMemAddr);
       
  1268 
       
  1269 	const TResultSet expectedResults(threadCallback);
       
  1270 
       
  1271 	TTestCase testCase(
       
  1272 			new (ELeave) CSingleTransferTest(_L("8 * 4byte frags"), 10, transferArgs, expectedResults, 4),
       
  1273 			EFalse, capAboveV1);
       
  1274 	}
       
  1275 
       
  1276 
       
  1277 //TODO TTestCase could automatically be added to aray by ctor
       
  1278 //
       
  1279 //Append new test cases here
       
  1280 static TTestCase* StaticTestArray[] = {
       
  1281 	&Simple_1::testCase,
       
  1282 	&Simple_1::testCaseConcurrent,
       
  1283 	&Simple_2::testCase,
       
  1284 	&Simple_2::testCaseConcurrent,
       
  1285 	&Callback::testCase,
       
  1286 	&Callback::testCaseOldRequest,
       
  1287 	&ISR_Reque::endOnRedo::testCase,
       
  1288 	&ISR_Reque::endOnIsrCb::testCase,
       
  1289 	&ISR_Reque::endOnThreadCb::testCase,
       
  1290 	&ISR_Reque::changeSize::testCase,
       
  1291 #ifdef _DEBUG
       
  1292 	&ISR_Reque::invalidAddresses::testCase, // addresses only checked in UDEB
       
  1293 #endif
       
  1294 	//&ISR_Reque::multipleFragments::testCase, // This error condition is currently caught by a FAULT instead of a return code
       
  1295 	&Multipart::testCase,
       
  1296 	&IsrAndDfc::DfcBeforeIsr::testCase,
       
  1297 	&IsrAndDfc::IsrBeforeDfc::testCase,
       
  1298 	&_2D_Test::testCase2d,
       
  1299 	&FragmentationCount::testCase,
       
  1300 	&FragmentationCount::testCase2,
       
  1301 	&SmallFrags::testCase,
       
  1302 #ifndef _DEBUG
       
  1303 	// Benchmarks are only really meaningful
       
  1304 	// on UREL builds
       
  1305 	&Benchmark::Frag::testCase_256k,
       
  1306 	&Benchmark::Frag::testCase_8k,
       
  1307 	&Benchmark::Transfer::_128K::testCase_128,
       
  1308 	&Benchmark::Transfer::_128K::testCase_16,
       
  1309 	&Benchmark::Transfer::_128K::testCase_4,
       
  1310 	&Benchmark::Transfer::_128K::testCase_1,
       
  1311 	&Benchmark::Transfer::_4Bytes::testCase,
       
  1312 	&Benchmark::Transfer::_4Mb::testCase,
       
  1313 	&Benchmark::CompareIsrDfcCb::Dfc::_4Bytes::testCase,
       
  1314 	&Benchmark::CompareIsrDfcCb::Isr::_4Bytes::testCase,
       
  1315 	&Benchmark::CompareIsrDfcCb::Dfc::_4K::testCase,
       
  1316 	&Benchmark::CompareIsrDfcCb::Isr::_4K::testCase,
       
  1317 #endif
       
  1318 	&TestNewStyleFragment_1::testCase,
       
  1319 	&TestNewStyleFragment_1::testCaseConcurrent,
       
  1320 	&TestNewStyleFragment_2::testCase,
       
  1321 	&TestNewStyleFragment_2::testCaseConcurrent,
       
  1322 	//&TestNewStyleFragment_3::testCase,
       
  1323 	//&TestNewStyleFragment_3::testCaseConcurrent,
       
  1324 	&TestNewStyleFragment_4::testCase,
       
  1325 	&TestNewStyleFragment_4::testCaseConcurrent,
       
  1326 	&TestNewStyleFragment_5::testCase,
       
  1327 	&TestNewStyleFragment_5::testCaseConcurrent,
       
  1328 	&TestNewStyleFragment_6::testCase,
       
  1329 	&TestNewStyleFragment_6::testCaseConcurrent,
       
  1330 	&TestOldStyleFragment_1::testCase,
       
  1331 	&TestOldStyleFragment_1::testCaseConcurrent,
       
  1332 	&TestOldStyleFragment_2::testCase,
       
  1333 	&TestOldStyleFragment_2::testCaseConcurrent,
       
  1334 	//&TestOldStyleFragment_3::testCase,
       
  1335 	//&TestOldStyleFragment_3::testCaseConcurrent,
       
  1336 	&TestOldStyleFragment_4::testCase,
       
  1337 	&TestOldStyleFragment_4::testCaseConcurrent,
       
  1338 	&TestOldStyleFragment_5::testCase,
       
  1339 	&TestOldStyleFragment_5::testCaseConcurrent,
       
  1340 	&TestOldStyleFragment_6::testCase,
       
  1341 	&TestOldStyleFragment_6::testCaseConcurrent,
       
  1342 	&TestOldStyleDDmaRequest_1::testCase,
       
  1343 	&TestOldStyleDDmaRequest_1::testCaseConcurrent,
       
  1344 	&TestOldStyleDDmaRequest_2::testCase,
       
  1345 	&TestOldStyleDDmaRequest_2::testCaseConcurrent,
       
  1346 	&TestNewStyleDDmaRequest_1::testCase,
       
  1347 	&TestNewStyleDDmaRequest_1::testCaseConcurrent,
       
  1348 	&TestNewStyleDDmaRequest_2::testCase,
       
  1349 	&TestNewStyleDDmaRequest_2::testCaseConcurrent,
       
  1350 };
       
  1351 
       
  1352 RPointerArray<TTestCase> TestArray(StaticTestArray, ARRAY_LENGTH(StaticTestArray));