view src/aci2/mfw/mfw_cam.c @ 516:1ed9de6c90bd

src/g23m-gsm/sms/sms_for.c: bogus malloc removed The new error handling code that was not present in TCS211 blob version contains a malloc call that is bogus for 3 reasons: 1) The memory allocation in question is not needed in the first place; 2) libc malloc is used instead of one of the firmware's proper ways; 3) The memory allocation is made inside a function and then never freed, i.e., a memory leak. This bug was caught in gcc-built FreeCalypso fw projects (Citrine and Selenite) because our gcc environment does not allow any use of libc malloc (any reference to malloc produces a link failure), but this code from TCS3.2 is wrong even for Magnetite: if this code path is executed repeatedly over a long time, the many small allocations made by this malloc call without a subsequent free will eventually exhaust the malloc heap provided by the TMS470 environment, malloc will start returning NULL, and the bogus code will treat it as an error. Because the memory allocation in question is not needed at all, the fix entails simply removing it.
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 22 Jul 2018 06:04:49 +0000
parents 93999a60b835
children
line wrap: on
line source

/*
+--------------------------------------------------------------------+
| PROJECT:	MMI-Framework (8417)		$Workfile::	mfw_cam.c	    $|
| $Author::	NDH							$Revision::	1			    $|
| CREATED:	21.05.04		     		$Modtime::	21.05.04 14:58	$|
| STATE  :	code														 |
+--------------------------------------------------------------------+

   MODULE  : MFW_CAM

   PURPOSE : This module contains Camera Interface functions.

   HISTORY:

       Nov 29, 2005 REF: MMI-SPR-33833(OMAPS00055207)- x0035544
       MMI making Riviera calls without using proper header files. So added appropriate header files.
       
    	Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg
	Description: Locosto: MIgration to New LCD APIs
	Solution: Migrated to New APIs by replacing the old driver APIs with
	corresponding New LCD APIs

   	Sep 13, 2005    REF: SPR 33992 xdeepadh	
	Description: Image viewer cannot open file when saved in high quality	
	Solution: The quality factor has been rearranged to support saving	the images within 64KBlimit.

 	Aug 22 2005, xpradipg - LOCOSTO-ENH-31154
 	Description:	Application to test camera
 	Solution:	Implemented the camera application with following functionalities
 			preview, snapshot and image saving.

*/


/*
** Include Files
*/

#define ENTITY_MFW
/* includes */
#include <string.h>


#include "typedefs.h"
#include "vsi.h"
#include "pei.h"
#include "custom.h"
#include "gsm.h"

#include "message.h" /* included for aci_cmh.h .... */
#include "prim.h" /* included for aci_cmh.h .... */
#include "aci_cmh.h" /* included for mfw_sat.h, included for MmiDummy.h, included for MmiMenu.h */


#include "mfw_mfw.h"
#include "mfw_win.h"
#include "mfw_cam.h"

//#include "img/img_api.h" //included for img_message.h
//#include "img/img_message.h"

#include "mks/mks_api.h"

//#include "r2d/lcd_messages_ti.h"
//#include "r2d/lcd_messages.h"
#include "r2d/r2d.h"
//#include "cama/cama_cfg.h"
//#include "cama/cama_i.h"
#include "cama/camil_api.h"
#include "cama/camil_i.h"
//#include "gil/gil_gpf.h"
#include "ffs/ffs_api.h"
#include "mfw_ffs.h"

#if (BOARD == 71)
#define ISAMPLE
#endif
//x0035544 29 Nov, 2005 MMI-SPR-55207
#ifndef NEPTUNE_BOARD //x0035544 Sudha - Guarded the below header file for Neptune.
#include "rv/rv_general.h"
#endif

#include "dspl.h"


/*Variable declarations*/

//Variable to track the different Camera states.
UBYTE camera_state = CAMERA_STATE_IDLE;

//Variable to store the quality factor.
static UBYTE quality_factor = QUALITY_STANDARD;

T_CAMA_VIEWFINDER_PARAMETERS viewfinder_parameters;  //For Future Use, when viewfinder parameters can be configured.

//File name for the jpeg image to be saved in FFS.
extern char new_filename[CT_FILE_NAME_LENGTH];

//Flag to check whether viewfinder parameter configuration has changed.
UBYTE configure_flag = FALSE;

//Riviera Callback Functions for CAMIL API
static void mfw_cam_save_image_cb(void *parameter);
static void mfw_cam_get_viewfinder_param_cb(void *parameter);
static void mfw_cam_set_viewfinder_param_cb(void *parameter);
static void mfw_cam_set_viewfinder_mode_cb(void *parameter);
static void mfw_cam_enable_viewfinder_mode_cb(void *parameter);
static void mfw_cam_disable_viewfinder_mode_cb(void *parameter);

//Local function prototypes
void mfw_cam_set_viewfinder_param(T_CAMA_VIEWFINDER_PARAMETERS param);
void mfw_cam_set_viewfinder_param_color(UBYTE blackandwhite);
void mfw_cam_set_viewfinder_param_zoom(UBYTE zoom);

extern  void display_saved_image(BOOL);

/*
** Public function Definitions
*/

/*******************************************************************************

 $Function:		mfw_cam_init

 $Description:		This function initialises the camil interface.

 $Returns:		None

 $Arguments:		None

*******************************************************************************/
void mfw_cam_init(void)
{
	T_FFS_DIR  dir;
 	T_FFS_RET ffsResult;
   	TRACE_EVENT("mfw_cam_init()");

        ffsResult = ffs_opendir(JPEG_CONTENT_DIR,&dir);                    
        if(EFFS_NOTFOUND == ffsResult)
        	{
        		//Directory does not exsists, create it and initialize the table and write it to FFS
			ffsResult = ffs_mkdir(JPEG_CONTENT_DIR);
			if(EFFS_OK == ffsResult)
			{
				TRACE_EVENT("Create Dir Passed"); 
    			}
    			else
       			 TRACE_EVENT("Create Dir Failed");    
        	}
	// Initialize CAMIL interface.
	if (camil_init() != RV_OK)
	{
	    // @todo : use correct return code for error cases !
	    return ;
	}

}

/*******************************************************************************

 $Function:     mfw_cam_get_viewfinder_param_cb

 $Description: Callback to get the viewfinder parameters.

 $Returns: None 

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_get_viewfinder_param_cb(void *parameter)
{
	viewfinder_parameters = ((T_CAMA_MSG *)parameter)->body.viewfinder_parameters;
}

/*******************************************************************************

 $Function:		mfw_cam_exit

 $Description:		This function will tidy up any resources used by the Mfw Camera Module
 				on Power Down

 $Returns:		None

 $Arguments:		None

*******************************************************************************/
void mfw_cam_exit(void)
{

	TRACE_EVENT("mfw_cam_exit()");

	/* nothing to do here... RAM will be automatically cleaned, and the flash wasn't modified */
}

/*******************************************************************************

 $Function:     mfw_cam_enable_sensor_dummy_cb

 $Description: dummy callback functions used to disable the camera

 $Returns: None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_enable_sensor_dummy_cb(void *parameter)
{
	TRACE_EVENT("mfw_cam_enable_sensor_dummy_cb()");
//Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg
//replaced the flag with the function call, to migrate to the new Lcd APIs	
	dspl_control(DSPL_ACCESS_ENABLE);
}


/*******************************************************************************

 $Function:     mfw_cam_disable_sensor

 $Description:Disables the camera - Called by the MMI

 $Returns: Execution status

 $Arguments: None
*******************************************************************************/
SHORT mfw_cam_disable_sensor(void)
{
	TRACE_EVENT("mfw_cam_disable_sensor()");
   	camil_enable_camera(FALSE, mfw_cam_enable_sensor_dummy_cb);

   return 1;
}


/*******************************************************************************

 $Function:     mfw_cam_enable_camera_cb

 $Description: Callback for Enabling camera.

 $Returns:  None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_enable_camera_cb(void *parameter)
{

	TRACE_EVENT("mfw_cam_enable_camera_cb()");
	//Set the camera state to viewfinder.
   camera_state = CAMERA_STATE_VIEWFINDER;
    //Disable R2D refresh to stabilize lcd display of viewfinder
//Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg
//replaced the flag with the function call, to migrate to the new Lcd APIs
	dspl_control(DSPL_ACCESS_DISABLE);
	//Set the viewfinder parameters
   mfw_cam_set_viewfinder_param(viewfinder_parameters);
}


/*******************************************************************************

 $Function:     mfw_cam_launch_viewfinder_dma

 $Description:launch camera in viewfinder mode

 $Returns:Execution status

 $Arguments: None

*******************************************************************************/
SHORT mfw_cam_launch_viewfinder_dma(void)
{
      TRACE_EVENT("mfw_cam_launch_viewfinder_dma()");
 	camil_enable_camera (TRUE, mfw_cam_enable_camera_cb);
   return 1;
}

/*******************************************************************************

 $Function:     mfw_cam_take_snapshot_cb

 $Description: Callback for Camera  take snapshot function.

 $Returns: None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_take_snapshot_cb(void *parameter)
{

  TRACE_EVENT("mfw_cam_take_snapshot_cb()");
	//Set the camera state to Snapshot
	camera_state = CAMERA_STATE_SNAPSHOT;
}

/*******************************************************************************

 $Function:     mfw_cam_take_snapshot

 $Description:take a snapshot

 $Returns:Execution status

 $Arguments:		None

*******************************************************************************/
SHORT mfw_cam_take_snapshot(void)
{
   TRACE_EVENT("mfw_cam_take_snapshot()");   
//Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg
//replaced the flag with the function call, to migrate to the new Lcd APIs
	dspl_control(DSPL_ACCESS_DISABLE);
	camil_take_snapshot(mfw_cam_take_snapshot_cb);
  return 1;
}

/*******************************************************************************

 $Function:     mfw_camera_test_save_snapshot_cb

 $Description:save snapshot in phone memory

 $Returns:Execution status

 $Arguments: None

*******************************************************************************/
SHORT mfw_cam_save_snapshot(void)
{
//Sep 13, 2005    REF: SPR 33992 xdeepadh
//The fullpath will be included.
	char filename[CT_FULL_PATH_LENGTH];

	TRACE_EVENT("mfw_cam_save_snapshot()");
	sprintf(filename,"%s/%s%d.jpg",JPEG_CONTENT_DIR, new_filename,(int)FFS_flashData.camera_file_counter);
	TRACE_EVENT_P1("filename to be saved is %s",filename);
	if(camil_save_image((UINT16)mfw_cam_get_quality_factor(),filename,mfw_cam_save_image_cb) == RV_OK)
	{
		TRACE_EVENT("mfw_cam_save_snapshot() passed");	
		FFS_flashData.camera_file_counter++;
		flash_write();
		return MFW_CAM_OK;   	
	}  
	else  	
	{
		TRACE_EVENT("mfw_cam_save_snapshot() failed");  	
		return MFW_CAM_FAILED;  
	}
}

/*******************************************************************************

 $Function:     mfw_cam_save_image_cb

 $Description: Callback for save image

 $Returns:None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_save_image_cb(void *parameter)
{
	T_RV_RET status;
	TRACE_EVENT("mfw_cam_save_image_cb()");
	camera_state = CAMERA_STATE_VIEWFINDER;
//Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipgn
//replaced the flag with the function call, to migrate to the new Lcd APIs
	dspl_control(DSPL_ACCESS_ENABLE);
	if( ((T_CAMA_MSG*)parameter)->status != RV_OK)
	{
		TRACE_EVENT("ERROR SAVING IMAGE");
		display_saved_image(FALSE);
	}
	else
	{
		TRACE_EVENT("IMAGE SAVED");
		display_saved_image(TRUE);
	}
}

/*******************************************************************************

 $Function:     mfw_cam_set_quality_factor
		
 $Description: Set the quality factor .This will be used while saving the jpeg image in ffs.
		
 $Returns: None
	
 $Arguments: factor-quality factor to be used to save the image.

*******************************************************************************/
void mfw_cam_set_quality_factor(UBYTE factor)
{
	TRACE_EVENT("mfw_cam_set_quality_factor()");
	quality_factor = factor;
}

/*******************************************************************************

 $Function:     mfw_cam_get_quality_factor

 $Description: This function returns the quality factor.

 $Returns: The quality factor

 $Arguments: None

*******************************************************************************/

UBYTE mfw_cam_get_quality_factor()
{
	TRACE_EVENT("mfw_cam_get_quality_factor()");
	return quality_factor;
}


/*******************************************************************************

 $Function:     mfw_cam_set_color

 $Description:

 $Returns:

 $Arguments: 

*******************************************************************************/
void mfw_cam_set_color(UBYTE factor)
{
	TRACE_EVENT("mfw_cam_set_color()");
}
/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_param_cb

 $Description: Callback for the Viewfinder set parameters.

 $Returns:None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_set_viewfinder_param_cb(void *parameter)
{
 TRACE_EVENT("mfw_cam_set_viewfinder_param_cb()");
 
	configure_flag = FALSE;
	/* start frame loop */
	camil_set_viewfinder_mode(mfw_cam_set_viewfinder_mode_cb);
}

/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_param_color_cb

 $Description: Callback for Viewfinder set Parameters

 $Returns: None 

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_set_viewfinder_param_color_cb(void *parameter)
{
  TRACE_EVENT("mfw_cam_set_viewfinder_param_color_cb()");
}

/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_param

 $Description: This function sets the Viewfinder Parameters.
 			The camera will be started in the viewfinder mode.

 $Returns: None

 $Arguments: param- Viewfinder Parameters

*******************************************************************************/

void mfw_cam_set_viewfinder_param(T_CAMA_VIEWFINDER_PARAMETERS param)
    {
	TRACE_EVENT("mfw_cam_set_viewfinder_param()");
	if(configure_flag)
	{
		camil_set_viewfinder_parameters(&param, mfw_cam_set_viewfinder_param_cb);
	}
	else
	{
	 	TRACE_EVENT("mfw_cam_set_viewfinder_param- no param chnaged.");
		/* start frame loop */
		camil_set_viewfinder_mode(mfw_cam_set_viewfinder_mode_cb);
	}
}

/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_param_color

 $Description: Sets the Viewfinder Parameter.

 $Returns: None

 $Arguments: blackandwhite- Viewfinder parameter

*******************************************************************************/

void mfw_cam_set_viewfinder_param_color(UBYTE blackandwhite)
{
	TRACE_EVENT("mfw_cam_set_viewfinder_param_color()");
	viewfinder_parameters.black_and_white = blackandwhite;
	//Configurations have changed. Set the configure_flag to TRUE.
	configure_flag = TRUE;
	//Set the Viewfinder parameters .
	//camil_set_viewfinder_parameters(&viewfinder_parameters, mfw_cam_set_viewfinder_param_color_cb);
}


/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_param_zoom

 $Description:	Sets the Viewfinder Parameter.

 $Returns: None

 $Arguments: zoom- Viewfinder parameter

*******************************************************************************/

void mfw_cam_set_viewfinder_param_zoom(UBYTE zoom)
{
	TRACE_EVENT("mfw_cam_set_viewfinder_param_zoom()");
	viewfinder_parameters.zoom = zoom;
	//Configurations have chnaged. Set the configure_flag to TRUE.
	configure_flag = TRUE;
	//Set the Viewfinder parameters .
	//camil_set_viewfinder_parameters(&viewfinder_parameters, mfw_cam_set_viewfinder_param_color_cb);
}



/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_mode_cb

 $Description: Callback for Setting Viewfinder.

 $Returns: None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_set_viewfinder_mode_cb(void *parameter)
{
	TRACE_EVENT("mfw_cam_set_viewfinder_mode_cb()");
	//added the refresh disable and state setting
	//Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg
	//replaced the flag with the function call, to migrate to the new Lcd APIs
	dspl_control(DSPL_ACCESS_DISABLE);
	camera_state = CAMERA_STATE_VIEWFINDER;
}


/*******************************************************************************

 $Function:     mfw_cam_set_viewfinder_mode

 $Description: This function disables and reenables camera and sets the viewfinder mode.

 $Returns:None

 $Arguments: None

*******************************************************************************/
#ifdef ISAMPLE
void  mfw_cam_set_viewfinder_mode(void)
{
   	TRACE_EVENT("mfw_cam_set_viewfinder_mode()");
   	camera_state  =  CAMERA_STATE_VIEWFINDER;
   	camil_set_viewfinder_mode(mfw_cam_set_viewfinder_mode_cb);
}

#else  //For ESAMPLE
void  mfw_cam_set_viewfinder_mode(void)
{
	TRACE_EVENT("mfw_cam_set_viewfinder_mode()");
	camil_enable_camera(FALSE, mfw_cam_disable_viewfinder_mode_cb);
}
#endif

/*******************************************************************************

 $Function:     mfw_cam_enable_viewfinder_mode_cb

 $Description: Callback for camil_enable_camera

 $Returns:None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_enable_viewfinder_mode_cb(void *parameter)
{
	TRACE_EVENT("mfw_cam_enable_viewfinder_mode_cb()");

	//Disable R2D refresh (to be sure)
//Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg
//replaced the flag with the function call, to migrate to the new Lcd APIs
	dspl_control(DSPL_ACCESS_DISABLE);
	camil_set_viewfinder_mode(mfw_cam_set_viewfinder_mode_cb);
}

/*******************************************************************************

 $Function:     mfw_cam_disable_viewfinder_mode_cb

 $Description: Callback for disabling camera

 $Returns:None

 $Arguments: Callback Parameter

*******************************************************************************/
static void mfw_cam_disable_viewfinder_mode_cb(void *parameter)
{
	TRACE_EVENT("mfw_cam_disable_viewfinder_mode_cb()");
	camil_enable_camera(TRUE, mfw_cam_enable_viewfinder_mode_cb);
}