kernel/eka/include/d32camerasc.inl
author William Roberts <williamr@symbian.org>
Mon, 21 Dec 2009 16:15:43 +0000
changeset 3 9947e075979d
parent 0 a41df078684a
child 4 56f325a607ea
permissions -rw-r--r--
Merge improved comments

// Copyright (c) 2006-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:
// e32\include\d32camerasc.inl
// 
//

inline TVersion RDevCameraSc::VersionRequired()
	{
	const TInt KCameraMajorVersionNumber=1;
	const TInt KCameraMinorVersionNumber=0;
	const TInt KCameraBuildVersionNumber=KE32BuildVersionNumber;
	return TVersion(KCameraMajorVersionNumber,KCameraMinorVersionNumber,KCameraBuildVersionNumber);
	}

#ifndef __KERNEL_MODE__


inline RDevCameraSc::RDevCameraSc()
: RBusLogicalChannel()
	{
	iCameraCaps = NULL;
	iCapsSize = 0;
	}

inline TInt RDevCameraSc::Open(TInt aUnit)
	{
	TInt r=DoCreate(KDevCameraScName,VersionRequired(),aUnit,NULL,NULL,EOwnerThread);
	if (KErrNone == r)
		{
		// Obtain the Capability structure size then allocate memory for it on client side
		r=iCapsSize=DoControl(EControlCapsSize);		
		if (KErrNone > r)
			{
			iCapsSize = 0;
			return r;
			}

		TAny* capsBufPtr = User::Alloc(iCapsSize);
		if(NULL == capsBufPtr)
			{
			iCapsSize = 0;
			return KErrNoMemory;
			}

		TPtr8 capsPtr((TUint8*)capsBufPtr, iCapsSize, iCapsSize);
		// Fill the Capability structure
		r = DoControl(EControlCaps,(TAny*)&capsPtr);
		if (KErrNone > r)
			{
			iCapsSize = 0;
			return r;
			}
		iCameraCaps = (TCameraCapsV02*) capsPtr.Ptr();
		}

	return r;
	}

inline void RDevCameraSc::Close()
	{
	if (iCameraCaps != NULL)
		{
		User::Free(iCameraCaps);
		iCameraCaps = NULL;
		}
	iCapsSize = 0;
	RBusLogicalChannel::Close();
	}

inline TInt RDevCameraSc::Caps(TDes8& aCapsBuf)
	{
	if (aCapsBuf.MaxLength() < iCapsSize)
		{
		return KErrArgument;
		}

	TPtrC8 ptr ((TUint8*)iCameraCaps, iCapsSize);
	aCapsBuf = ptr;
	return KErrNone;
	}

inline TPtrC8 RDevCameraSc::Caps()
	{
	TPtrC8 ptr((TUint8*)iCameraCaps, iCapsSize);
	return ptr;
	}

inline TInt RDevCameraSc::SetBufConfigChunkCreate(TDevCamCaptureMode aCaptureMode, TInt aNumBuffers, RChunk& aChunk)
	{return(aChunk.SetReturnedHandle(DoControl(EControlSetBufConfigChunkCreate,(TAny*)aCaptureMode,(TAny*)aNumBuffers)));}

inline TInt RDevCameraSc::SetBufConfigChunkOpen(TDevCamCaptureMode aCaptureMode, const TDesC8& aBufferConfigBuf, RChunk& aChunk)
	{
	SSetBufConfigChunkOpenInfo info = {&aBufferConfigBuf, aChunk.Handle()};
	return(DoControl(EControlSetBufConfigChunkOpen,(TAny*)aCaptureMode,&info));
	}

inline TInt RDevCameraSc::ChunkClose(TDevCamCaptureMode aCaptureMode)
	{return(DoControl(EControlChunkClose,(TAny*)aCaptureMode));}

inline TInt RDevCameraSc::SetCamConfig(TDevCamCaptureMode aCaptureMode,const TDesC8& aConfigBuf)
	{return(DoControl(EControlSetCamConfig,(TAny*)aCaptureMode,(TAny*)&aConfigBuf));}

inline void RDevCameraSc::GetCamConfig(TDevCamCaptureMode aCaptureMode, TDes8& aConfigBuf)
	{DoControl(EControlGetCamConfig,(TAny*)aCaptureMode,(TAny*)&aConfigBuf);}

inline void RDevCameraSc::GetBufferConfig(TDevCamCaptureMode aCaptureMode, TDes8& aConfigBuf)
	{DoControl(EControlGetBufferConfig,(TAny*)aCaptureMode,(TAny*)&aConfigBuf);}

inline TInt RDevCameraSc::SetCaptureMode(TDevCamCaptureMode aCaptureMode)
	{return(DoControl(EControlSetCaptureMode,(TAny*)aCaptureMode));}

inline TInt RDevCameraSc::Start()
	{return(DoControl(EControlStart));}

inline TInt RDevCameraSc::Stop()
	{return(DoControl(EControlStop));}

inline void RDevCameraSc::NotifyNewImage(TRequestStatus& aStatus)
	{DoRequest(ERequestNotifyNewImage,aStatus);}

inline void RDevCameraSc::NotifyNewImageCancel()
	{DoCancel(1<<ERequestNotifyNewImage);}

inline void RDevCameraSc::NotifyNewImageCancel(const TRequestStatus& aStatus)
	{DoControl(EControlNotifyNewImageSpecificCancel,(TAny*)&aStatus);}

inline TInt RDevCameraSc::ReleaseBuffer(TInt aBufferId)
	{return(DoControl(EControlReleaseBuffer,(TAny*)aBufferId));}

inline TInt RDevCameraSc::BufferIdToOffset(TDevCamCaptureMode aCaptureMode, TInt aId, TInt& aOffset)
	{
	// search criteria
	TDevCamBufferModeAndIdBuf databuf;
	TDevCamBufferModeAndId &data = databuf();
	data.iCaptureMode = aCaptureMode;
	data.iId = aId;

	return (DoControl(EControlBufferIdToOffset,(TAny*)&databuf,(TAny*)&aOffset));
	}

inline TInt RDevCameraSc::CapsSize()
	{return(iCapsSize);}

inline TInt RDevCameraSc::FrameSizeCaps(TDevCamCaptureMode aCaptureMode, TUidPixelFormat aUidPixelFormat, TDes8& aFrameSizeCapsBuf)
	{
	SFrameSizeCapsInfo info = {aUidPixelFormat, aCaptureMode};
	return(DoControl(EControlFrameSizeCaps, (TAny*)&aFrameSizeCapsBuf, &info));
	}
	
inline TInt RDevCameraSc::SetDynamicAttribute(TDevCamDynamicAttributes aAttribute, TUint aValue)
	{
	TInt r = KErrNone;
	
	// Are we not supported?
	TInt misc = 0;
	switch (aAttribute)
		{
		case ECamAttributeBrightness:
			{
			misc = KCamMiscBrightness;
			break;
			}
		case ECamAttributeContrast:
			{
			misc = KCamMiscContrast;
			break;
			}
		case ECamAttributeColorEffect:
			{
			misc = KCamMiscColorEffect;
			break;
			}
		default:
			{
			r = KErrBadName;
			}
		}

	if (KErrNone != r)
		{
		return r;
		}

	if (!(iCameraCaps->iCapsMisc & misc))
		{
		r = KErrNotSupported;
		}

	else
		{
		TDynamicRange &range = iCameraCaps->iDynamicRange[aAttribute];
		// Not within range?
		if (aValue < range.iMin || aValue > range.iMax)
			{
			r = KErrArgument;
			}
		else
			{
			r = DoControl(EControlSetDynamicAttribute,(TAny*)aAttribute, (TAny*)aValue);
			}
		}

	return r;
	}

#endif	// __KERNEL_MODE__