graphicstest/uibench/src/tgraphicsresource.cpp
author Matt Plumtree <matt.plumtree@nokia.com>
Fri, 23 Apr 2010 17:57:02 +0100
branchNewGraphicsArchitecture
changeset 39 a4b63488e0b0
parent 0 5d03bc08d59c
permissions -rw-r--r--
Revise some of the compositor performance improvements to improve correctness. Implement pixel blending using a variation of Jim Blinn's no-division blending algorithm. Move transparency type simplification further up the composition code. Remove some unnecessary fields. Output to YUV implementation needs revision as it is actually converting from YUV (copy of source conversion code).

// Copyright (c) 2005-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
 @test
 @internalComponent - Internal Symbian test code 
*/

#include "tgraphicsresource.h"
#include "tdirectgditestbase.h"
#ifndef SYMBIAN_GRAPHICS_EGL_SGIMAGELITE
#include <graphics/sgimage_sw.h>
#endif

#ifndef SYMBIAN_GRAPHICS_EGL_SGIMAGELITE
const TInt KIterationsToTest = 1000;
#endif

CTGraphicsResource::CTGraphicsResource()
	{
	SetTestStepName(KTGraphicsResource);
	
#ifndef SYMBIAN_GRAPHICS_EGL_SGIMAGELITE
	iImageInfo.iCpuAccess = ESgCpuAccessReadWrite;
	iImageInfo.iUsage = ESgUsageDirectGdiSource;
	iImageInfo.iPixelFormat = EUidPixelFormatRGB_565;
	iImageInfo.iShareable = ETrue;
	
	Mem::FillZ(iImageData, KMaxArraySize * sizeof(TUint16));
	TEST(KErrNone == SgDriver::Open());
#endif
	}

CTGraphicsResource::~CTGraphicsResource()
	{	
#ifndef SYMBIAN_GRAPHICS_EGL_SGIMAGELITE
	TInt temp = SgDriver::ResourceCount();
	SgDriver::Close();
#endif
	}

/**
Override of base class pure virtual
Our implementation only gets called if the base class doTestStepPreambleL() did
not leave. That being the case, the current test result value will be EPass.

@return - TVerdict code
*/
TVerdict CTGraphicsResource::doTestStepL()
	{
#ifdef SYMBIAN_GRAPHICS_EGL_SGIMAGELITE
    INFO_PRINTF1(_L("CTGraphicsResource can only be run with RSgImage legacy"));
    return TestStepResult();
#else
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0089"));
	SmallImageCreationSimpleL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0090"));
	LargeImageCreationSimpleL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0091"));
	ImageDuplicateL();	
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0092"));
	ImageDuplicateHandleL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0093"));
	ImageMapL();
	RecordTestResultL();
    CloseTMSGraphicsStep();
	return TestStepResult();
#endif	
	}

#ifndef SYMBIAN_GRAPHICS_EGL_SGIMAGELITE
/**
Helper function.
Creates and destroys images of the same size KIterationsToTest times.

@param aWidth The width of the created bitmaps.
@param aHeight  The height of the created bitmaps.
@param aTestDescription The description of the test.
*/
void CTGraphicsResource::ImageCreationSimpleL(const TInt aWidth, const TInt aHeight, const TDesC& aTestDescription)
	{
	iImageInfo.iSizeInPixels = TSize(aWidth, aHeight);
	TInt sizeInBytes = aWidth*aHeight*2;
	RSgImage image;
	
	iProfiler->InitResults();	
	for(TInt count=KIterationsToTest; count>=0; --count)
		{
		TInt err = image.Create(iImageInfo, NULL, 0);
		TESTL(err == KErrNone);
		MSgImage_Sw* data;
		TESTNOERRORL(image.GetInterface(data));
		Mem::Fill(data->DataAddress(), sizeInBytes, 0xFF);
		image.Close();
		iProfiler->MarkResultSetL();
		}	
	iProfiler->ResultsAnalysis(aTestDescription, TDisplayModeMapping::MapPixelFormatToDisplayMode(iImageInfo.iPixelFormat), 0, 0, KIterationsToTest);
	}

/**
@SYMTestCaseID
GRAPHICS-UI-BENCH-0089

@SYMPREQ PREQ39

@SYMREQ REQ9236 
@SYMREQ REQ9237

@SYMTestCaseDesc
The test determines how long it takes to create and destroy small simple RSgImage objects.

@SYMTestActions
Compare the results over time, and before and after changes to image construction and destruction code.

@SYMTestExpectedResults
Test should pass and display total test time and time per image
*/
void CTGraphicsResource::SmallImageCreationSimpleL()
	{
	ImageCreationSimpleL(32, 32, _L("Small-RSgImage-Create-64K-Simple"));
	}

/**
@SYMTestCaseID
GRAPHICS-UI-BENCH-0090

@SYMPREQ PREQ39

@SYMREQ REQ9236 
@SYMREQ REQ9237

@SYMTestCaseDesc
The test determines how long it takes to create and destroy large simple RSgImage objects.

@SYMTestActions
Compare the results over time, and before and after changes to image construction and destruction code.

@SYMTestExpectedResults
Test should pass and display total test time and time per image
*/
void CTGraphicsResource::LargeImageCreationSimpleL()
	{
	ImageCreationSimpleL(500, 500, _L("Large-RSgImage-Create-64K-Simple"));
	}

/**
@SYMTestCaseID
GRAPHICS-UI-BENCH-0091

@SYMPREQ PREQ39

@SYMREQ REQ9236 
@SYMREQ REQ9237

@SYMTestCaseDesc
Tests how long it takes to duplicate an RSgImage.

@SYMTestActions
Compare the results over time, and before and after changes to bitmap duplication code.

@SYMTestExpectedResults
Test should pass and display total test time and time per image.
*/
void CTGraphicsResource::ImageDuplicateL()
	{
	//prepare an image to duplicate
	iImageInfo.iSizeInPixels = TSize(300, 300);
	
	RSgImage image;
	TInt err = image.Create(iImageInfo, iImageData, KImageDataStride);
	TESTL(err == KErrNone);
	
	iProfiler->InitResults();
	for(TInt count=KIterationsToTest; count>=0; --count)
		{
		RSgImage image2;
		err = image2.Create(iImageInfo, image);
		TESTL(err == KErrNone);
		image2.Close();
		iProfiler->MarkResultSetL();
		}	
	iProfiler->ResultsAnalysis(_L("RSgImage-Duplicate           "), TDisplayModeMapping::MapPixelFormatToDisplayMode(iImageInfo.iPixelFormat), 0, 0, KIterationsToTest);	
	
	image.Close();
	}

/**
@SYMTestCaseID
GRAPHICS-UI-BENCH-0092

@SYMPREQ PREQ39

@SYMREQ REQ9236 
@SYMREQ REQ9237

@SYMTestCaseDesc
Tests how long it takes to duplicate an image handle.

@SYMTestActions
Compare the results over time, and before and after changes to image duplication code.

@SYMTestExpectedResults
Test should pass and display total test time and time per image.
*/
void CTGraphicsResource::ImageDuplicateHandleL()
	{
	//prepare an image to duplicate
	iImageInfo.iSizeInPixels = TSize(300, 300);
	
	RSgImage image;
	TInt err = image.Create(iImageInfo, iImageData, KImageDataStride);
	TESTL(err == KErrNone);
	TSgDrawableId id = image.Id();	
	
	iProfiler->InitResults();
	for(TInt count=KIterationsToTest; count>=0; --count)
		{
		RSgImage image2;
		err = image2.Open(id);
		TESTL(KErrNone == err);
		image2.Close();
		iProfiler->MarkResultSetL();
		}	
	iProfiler->ResultsAnalysis(_L("RSgImage-Duplicate-Handle"), TDisplayModeMapping::MapPixelFormatToDisplayMode(iImageInfo.iPixelFormat), 0, 0, KIterationsToTest);	
	
	image.Close();
	}

/**
@SYMTestCaseID
GRAPHICS-UI-BENCH-0093

@SYMPREQ PREQ39

@SYMREQ REQ9236 
@SYMREQ REQ9237

@SYMTestCaseDesc
Measure performance of Map() and Unmap() of an RSgImage.

@SYMTestActions
Compare the results over time, and before and after changes to image mapping code.

@SYMTestExpectedResults
Test should pass and display total test time and time per image.
*/
void CTGraphicsResource::ImageMapL()
	{
	//prepare an image
	iImageInfo.iSizeInPixels = TSize(300, 300);
	
	RSgImage image;
	TInt err = image.Create(iImageInfo, iImageData, KImageDataStride);
	TESTL(err == KErrNone);
	
	const TAny* dataAddressRead;
	TAny* dataAddressWrite;
	TInt dataStride;
	
	iProfiler->InitResults();
	for(TInt count=KIterationsToTest; count>=0; --count)
		{
		err = image.MapReadOnly(dataAddressRead, dataStride);
		TESTL(err == KErrNone);
		image.Unmap();
		iProfiler->MarkResultSetL();
		}	
	iProfiler->ResultsAnalysis(_L("RSgImage-MapReadOnly          "), TDisplayModeMapping::MapPixelFormatToDisplayMode(iImageInfo.iPixelFormat), 0, 0, KIterationsToTest);	
	
	iProfiler->InitResults();
	for(TInt count=KIterationsToTest; count>=0; --count)
		{
		err = image.MapWriteOnly(dataAddressWrite, dataStride);
		TESTL(err == KErrNone);
		image.Unmap();
		iProfiler->MarkResultSetL();
		}	
	iProfiler->ResultsAnalysis(_L("RSgImage-MapWriteOnly          "), TDisplayModeMapping::MapPixelFormatToDisplayMode(iImageInfo.iPixelFormat), 0, 0, KIterationsToTest);
	
	iProfiler->InitResults();
	for(TInt count=KIterationsToTest; count>=0; --count)
		{
		err = image.MapReadWrite(dataAddressWrite, dataStride);
		TESTL(err == KErrNone);
		image.Unmap();
		iProfiler->MarkResultSetL();
		}	
	iProfiler->ResultsAnalysis(_L("RSgImage-MapReadWrite              "), TDisplayModeMapping::MapPixelFormatToDisplayMode(iImageInfo.iPixelFormat), 0, 0, KIterationsToTest);
	
	image.Close();
	}
#endif