omxil/omxilcomponentcommon/src/common/omxilprocessingfunction.h
author hgs
Mon, 23 Aug 2010 21:48:44 +0100
changeset 47 481b3bce574a
parent 0 40261b775718
child 16 eedf2dcd43c6
permissions -rw-r--r--
2010wk32_04

// 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
*/

#ifndef OMXILPROCESSINGFUNCTION_H
#define OMXILPROCESSINGFUNCTION_H

#include <e32base.h>

#include <openmax/il/khronos/v1_x/OMX_Core.h>
#include <openmax/il/khronos/v1_x/OMX_Types.h>
#include <openmax/il/khronos/v1_x/OMX_Other.h>

#include "omxilfsm.h"

// Forward declarations
class MOmxILCallbackNotificationIf;

/**
   Base class for component-specific implementations of the Processing Function
   abstraction. Component implementations realize within a Processing Function
   object the codec specific logic. Component implementations may choose
   whether to implement the Processing Function functionality in an additional
   independent thread or in-context with the framework. The interface is
   designed to generalize the notification of the OpenMAX IL commands, OpenMAX
   IL state changes and input/output buffer arrivals to the codec
   itself. Implementations of this interface are intended to communicate with
   the entity in charge of the egress component communication, the Callback
   Manager.
 */
class COmxILProcessingFunction : public CBase
	{

public:

	IMPORT_C ~COmxILProcessingFunction();

	/**
	   Framework notification of a state transition in the component.

	   @param aNewState The new state.

	   @return OMX_ERRORTYPE
	 */
	virtual OMX_ERRORTYPE StateTransitionIndication(
		COmxILFsm::TStateIndex aNewState) = 0;

	/**
	   Framework notification of a buffer flushing command.

	   @param aPortIndex The port that is being flushed.

	   @param aDirection The direction of the port that is being flushed.

	   @return OMX_ERRORTYPE
	 */
	virtual OMX_ERRORTYPE BufferFlushingIndication(
		TUint32 aPortIndex,
		OMX_DIRTYPE aDirection) = 0;

	/**
	   Framework notification of an OpenMAX IL Param structure change.

	   @param aParamIndex The index of the param structure that has changed.

	   @param apComponentParameterStructure The param structure.

	   @return OMX_ERRORTYPE
	 */
	virtual OMX_ERRORTYPE ParamIndication(
		OMX_INDEXTYPE aParamIndex,
		const TAny* apComponentParameterStructure) = 0;

	/**
	   Framework notification of an OpenMAX IL Config structure change.

	   @param aConfigIndex The index of the config structure that has changed.

	   @param apComponentConfigStructure The config structure.

	   @return OMX_ERRORTYPE
	 */
	virtual OMX_ERRORTYPE ConfigIndication(
		OMX_INDEXTYPE aConfigIndex,
		const TAny* apComponentConfigStructure) = 0;

	/**
	   Framework notification of a buffer arrival.

	   @param apBufferHeader The header of the buffer to be processed.

	   @param aDirection The direction of the port that has received the
	   buffer.

	   @return OMX_ERRORTYPE
	 */
	virtual OMX_ERRORTYPE BufferIndication(
		OMX_BUFFERHEADERTYPE* apBufferHeader,
		OMX_DIRTYPE aDirection) = 0;

	/**
	   Framework notification of a buffer removal. Here the Processing Function
	   object is being notified that a buffer needs to be removed from its
	   internal queues. At present, a synchronous implementation of this method
	   is assumed. Buffer removal notifications may be originated by the
	   framework in the following scenarios:

	   -# After an OMX_FreeBuffer call has been received from the IL Client or
	   from another component.

	   -# After a port flushing command has been received from the IL Client
	   AND the port is tunnelled and buffer supplier.

	   -# After a transition OMX_StateExecuting/OMX_StatePause -> OMX_StateIdle
            has been requested by the IL Client AND the port associated to the
            buffer is tunnelled and buffer supplier.

	   -# After a port disable command has been received from the IL Client AND
            the port associated to the buffer is tunnelled and buffer supplier.

	   @param apBufferHeader The buffer header to be removed from internal
	   queues.

	   @param aDirection The direction of the port associated to the buffer.

	   @return OMX_BOOL Etrue if the Processing Function has successfully
	    removed the buffer header from its internal queues, EFalse otherwise.
	 */
	virtual OMX_BOOL BufferRemovalIndication(
		OMX_BUFFERHEADERTYPE* apBufferHeader,
		OMX_DIRTYPE aDirection) = 0;

	IMPORT_C virtual OMX_ERRORTYPE ComponentRoleIndication(
		TUint aComponentRoleIndex);

	/**
	   Framework notification of a buffer arrival on a OMX_PortDomainOther;
	   normally the interested component would just extract the buffer and 
	   let the port manager returns the buffer to the buffer supplier
	   component via callback immediately.

	   @param apBufferHeader 	The header of the buffer to be processed.
	   @param aDirection 		The direction of the port that has received
	   							the buffer.
	   @return OMX_ERRORTYPE
	 */
	IMPORT_C virtual OMX_ERRORTYPE MediaTimeIndication(const OMX_TIME_MEDIATIMETYPE& );
	
protected:

	IMPORT_C COmxILProcessingFunction(
		MOmxILCallbackNotificationIf& aCallbacks);

protected:

	MOmxILCallbackNotificationIf& iCallbacks;

	};

#endif // OMXILPROCESSINGFUNCTION_H