kernel/eka/include/d32camerasc.inl
changeset 4 56f325a607ea
parent 0 a41df078684a
--- a/kernel/eka/include/d32camerasc.inl	Mon Dec 21 16:14:42 2009 +0000
+++ b/kernel/eka/include/d32camerasc.inl	Wed Dec 23 11:43:31 2009 +0000
@@ -49,7 +49,7 @@
 		TAny* capsBufPtr = User::Alloc(iCapsSize);
 		if(NULL == capsBufPtr)
 			{
-			iCapsSize = 0;
+			Close();
 			return KErrNoMemory;
 			}
 
@@ -157,61 +157,66 @@
 	SFrameSizeCapsInfo info = {aUidPixelFormat, aCaptureMode};
 	return(DoControl(EControlFrameSizeCaps, (TAny*)&aFrameSizeCapsBuf, &info));
 	}
-	
-inline TInt RDevCameraSc::SetDynamicAttribute(TDevCamDynamicAttributes aAttribute, TUint aValue)
+
+//
+//
+//
+inline TInt RDevCameraSc::CheckAttributeSupported(TDevCamDynamicAttribute aAttribute)
 	{
-	TInt r = KErrNone;
+	TUint mask = 0;
 	
-	// Are we not supported?
-	TInt misc = 0;
 	switch (aAttribute)
 		{
 		case ECamAttributeBrightness:
-			{
-			misc = KCamMiscBrightness;
+			mask = KCamMiscBrightness;
 			break;
-			}
+			
 		case ECamAttributeContrast:
-			{
-			misc = KCamMiscContrast;
+			mask = KCamMiscContrast;
+			break;
+			
+		case ECamAttributeColorEffect:
+			mask = KCamMiscColorEffect;
 			break;
-			}
-		case ECamAttributeColorEffect:
+			
+		default:
+			return KErrNotSupported;
+		}
+	
+	// Check that the attribute is supported by the hardware.
+	return (iCameraCaps->iCapsMisc & mask ? KErrNone : KErrNotSupported);
+	}
+	
+//
+//
+//
+inline TInt RDevCameraSc::SetDynamicAttribute(TDevCamDynamicAttribute aAttribute, TUint aValue)
+	{
+	TInt err = CheckAttributeSupported(aAttribute);
+	if (err == KErrNone)
+		{
+		err = KErrArgument;
+		TDynamicRange &range = iCameraCaps->iDynamicRange[aAttribute];
+		if ((aValue >= range.iMin) && (aValue <= range.iMax))
 			{
-			misc = KCamMiscColorEffect;
-			break;
-			}
-		default:
-			{
-			r = KErrBadName;
+			err = DoControl(EControlSetDynamicAttribute, (TAny*)aAttribute, (TAny*)aValue);
 			}
 		}
 
-	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;
+	return err;
 	}
 
+//
+//
+//
+inline TInt RDevCameraSc::GetDynamicAttribute(TDevCamDynamicAttribute aAttribute, TUint& aValue)
+	{
+	TInt err = CheckAttributeSupported(aAttribute);
+	if (err == KErrNone)
+		{
+		err = DoControl(EControlGetDynamicAttribute, (TAny*)aAttribute, (TAny*)&aValue);
+		}
+		
+	return err;
+	}
 #endif	// __KERNEL_MODE__