omxil_generic/omxilcomplib/src/omxilutil.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 25 Aug 2010 12:40:50 +0300
changeset 0 0e4a32b9112d
permissions -rw-r--r--
Revision: 201033

// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
//


/**
 @file
 @internalComponent
*/


#include <openmax/il/common/omxilutil.h>
#include <openmax/il/common/omxilspecversion.h>

/**
   This method checks that the size of an OpenMAX IL data structure is
   correct. It also checks that the OpenMAX IL version stated in the structure
   is the same as the one returned by TOmxILSpecVersion() (at the time of
   writting this is 1.1.1). In this version of the component framework,
   backward compatibility in not supported for OpenMAX IL structures.

   @param apHeader An OpenMAX IL data structure.

   @param aSize sizeof(OMXIL structure)

   @return OMX_ErrorVersionMismatch if the version is not
   1.1.1. OMX_ErrorBadParameter if versions are the same but the nSize is
   different. OMX_ErrorNone otherwise
 */
EXPORT_C OMX_ERRORTYPE
TOmxILUtil::CheckOmxStructSizeAndVersion(OMX_PTR apHeader, OMX_U32 aSize)
	{

	if (!apHeader || aSize == 0)
		{
		return OMX_ErrorBadParameter;
		}

#ifdef _OMXIL_COMMON_SPEC_VERSION_CHECKS_ON

	OMX_U32* const pStructSize =
		reinterpret_cast<OMX_U32*>(apHeader);

    // In an OpenMAX IL structure the nSize and nVersion fields are used to
    // detect the difference in spec versions.
	OMX_VERSIONTYPE* const pOmxVersion =
		reinterpret_cast<OMX_VERSIONTYPE*>(
			pStructSize + (sizeof(OMX_U32)/sizeof(OMX_U32)));

	if ( (TOmxILSpecVersion() != *pOmxVersion)&&(TOmxILVersion(OMX_VERSION_MAJOR, OMX_VERSION_MINOR, 1, OMX_VERSION_STEP) != *pOmxVersion) )

		{
		return OMX_ErrorVersionMismatch;
		}

	// If the spec versions are the same, then the struct sizes must be the
	// same too...
	if (*pStructSize != aSize)
		{
		return OMX_ErrorBadParameter;
		}

#endif // _OMXIL_COMMON_SPEC_VERSION_CHECKS_ON

	return OMX_ErrorNone;

	}

/**
   This method simply resets the following fields in the OMX IL 1.1.x buffer header:
   nFilledLen
   hMarkTargetComponent
   pMarkData
   nTickCount
   nTimeStamp
   nFlags

   @param apBufferHeader An OpenMAX IL buffer header structure.

 */
EXPORT_C void
TOmxILUtil::ClearBufferContents(
	OMX_BUFFERHEADERTYPE* apBufferHeader)
	{

	if (!apBufferHeader)
		{
		return;
		}

	apBufferHeader->nFilledLen			 = 0;
	apBufferHeader->hMarkTargetComponent = 0;
	apBufferHeader->pMarkData			 = 0;
	apBufferHeader->nTickCount			 = 0;
	apBufferHeader->nTimeStamp			 = 0;
	apBufferHeader->nFlags				 = 0;

	}