FreeCalypso > hg > fc-magnetite
view src/ui3/mfw/mfw_fm.h @ 624:012028896cfb
FFS dev.c, Leonardo target: Fujitsu MB84VF5F5F4J2 #if 0'ed out
The FFS code we got from TI/Openmoko had a stanza for "Fujitsu MB84VF5F5F4J2
stacked device", using a fake device ID code that would need to be patched
manually into cfgffs.c (suppressing and overriding autodetection) and using
an FFS base address in the nCS2 bank, indicating that this FFS config was
probably meant for the MCP version of Leonardo which allows for 16 MiB flash
with a second bank on nCS2.
We previously had this FFS config stanza conditionalized under
CONFIG_TARGET_LEONARDO because the base address contained therein is invalid
for other targets, but now that we actually have a Leonardo build target in
FC Magnetite, I realize that the better approach is to #if 0 out this stanza
altogether: it is already non-functional because it uses a fake device ID
code, thus it is does not add support for more Leonardo board variants,
instead it is just noise.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 22 Dec 2019 21:24:29 +0000 |
parents | e8ddbb0837ed |
children |
line wrap: on
line source
/* ========================================================= * Texas Instruments OMAP(TM) Platform Software * (c) Copyright Texas Instruments, Incorporated. All Rights Reserved. * * Use of this software is controlled by the terms and conditions found * in the license agreement under which this software has been supplied. * ========================================================== */ /*========================================================== * @file mfw_FileManager.h * * This provides the functionality of File Manager Applications. * It supports file/folder related operations on FFS and MMC * * @path \bmi\condat\ms\src\mfw * * @rev 00.01 */ /* ========================================================== */ /*=========================================================== *! *! Revision History *! =================================== Apr 06, 2007 DRT: OMAPS00124874 x0039928 Description: MM: Renaming process of an Imy file is incorrect Solution: Seperate enum values for different audio files is added. Mar 28, 2007 ER: OMAPS00106188 x0039928 Description: Align Midi application menu choices and audio Player menu choices *! 10-Apr-2006 mf: Modified x0020906. Change required per SRxxxx *! to provide File Manager Functionality. *! *! *! 17-Jan-2006 mf: Revisions appear in reverse chronological order; *! that is, newest first. The date format is dd-Mon-yyyy. * =========================================================== */ #ifndef DEF_MFW_FILEMANAGER #define DEF_MFW_FILEMANAGER //Includes for Image Services #include "msl/inc/msl_imgthmb.h" #include "msl/inc/msl_imgview.h" //Includes for Audio Services #include "as/as_api.h" #include "as/as_message.h" /******************************************************************************* Interface constants *******************************************************************************/ #define FM_MAX_EXT_LENGTH 5 #define FM_MAX_OBJ_NAME_LENGTH 200// 45 #ifdef FF_MMI_UNICODE_SUPPORT /* x0083025 OMAPS00156759 * Changed from 250 to 100 because to much memory is being taken when unicode * is enabled (2 bytes per char) and system would eventually crash */ #define FM_MAX_DIR_PATH_LENGTH 100 #else #define FM_MAX_DIR_PATH_LENGTH 250 #endif #define FM_MAX_OBJ_DATE_LENGTH 15 #define FM_MAX_OBJ_TIME_LENGTH 15 #define FM_COPY_BUFFER_SIZE 1000 #define FM_MAX_OBJ 20 #define E_FM_THMB_INIT (T_MFW_EVENT)0x00000001 #define E_FM_THMB_DEINIT (T_MFW_EVENT)0x00000010 #define E_FM_THMB_GEN (T_MFW_EVENT)0x00000100 #define E_FM_IMG_INIT (T_MFW_EVENT)0x00001000 #define E_FM_IMG_DEINIT (T_MFW_EVENT)0x00010000 #define E_FM_IMG_DRAW (T_MFW_EVENT)0x00100000 #define E_FM_AUDIO_STOP (T_MFW_EVENT)0x01000000 #define E_FM_AUDIO_PROG (T_MFW_EVENT)0x10000000 #define E_FM_ALL_SERVICES (T_MFW_EVENT)0xFFFFFFFF //Image typedef enum { FM_UCP_ERROR_FATAL = -8, FM_UCP_ERROR_NONFATAL, FM_UCP_ERROR_UNKNOWN, FM_UCP_ERROR_INVALID_ARGUMENT, FM_UCP_ERROR_BAD_STREAM, FM_UCP_ERROR_NO_MEM, FM_UCP_ERROR_READ_FAILED, FM_UCP_ERROR, FM_UCP_NONE = 0, FM_UCP_NO_ERROR, FM_UCP_THMB_INIT, FM_UCP_THMB_GEN, FM_UCP_THMB_DEINIT, FM_UCP_THMBIMG_INIT, FM_UCP_THMBIMG_DRAW, FM_UCP_THMBIMG_DEINIT, FM_UCP_QCIFIMG_INIT, FM_UCP_QCIFIMG_DRAW, FM_UCP_QCIFIMG_DEINIT }T_FM_IMG_STATE; typedef struct { T_FM_IMG_STATE state; T_FM_IMG_STATE cmd; int ipMsl; }T_FM_IMG; typedef struct { BOOL thumbnail; }T_FM_OBJ_IMAGE; #define MFW_FM_ZOOM_LOW 1024 #define MFW_FM_ZOOM_MAX (8 * MFW_FM_ZOOM_LOW) typedef enum { MFW_FM_ROTATE_0 = 0, MFW_FM_ROTATE_90, MFW_FM_ROTATE_180, MFW_FM_ROTATE_270, MFW_FM_ROTATE_MAX }T_FM_IMG_ROTATE; //Audio typedef enum { FM_AUD_ERROR_NOTALLOWED = -12, FM_AUD_ERROR_AUDIO, FM_AUD_ERROR_DENIED, FM_AUD_ERROR_PLAYER, FM_AUD_ERROR_FFS, FM_AUD_ERROR_MSGING, FM_AUD_ERROR_NOTREADY, FM_AUD_ERROR_INVALIDPARAM, FM_AUD_ERROR_INTERNAL, FM_AUD_ERROR_MEM, FM_AUD_ERROR_NOTSUPPORTED, FM_AUD_ERROR = -1 , FM_AUD_NO_ERROR, FM_AUD_NONE, FM_AUD_PLAY, FM_AUD_FORWARD, FM_AUD_REWIND, FM_AUD_PAUSE, FM_AUD_STOP, }T_FM_AUD_STATE; #define FM_AUD_MIDI_CHANNEL_MONO 1 #define FM_AUD_MIDI_CHANNEL_STEREO 2 #define FM_AUD_MP3_CHANNEL_MONO 0 #define FM_AUD_MP3_CHANNEL_STEREO 1 #define FM_AUD_AAC_CHANNEL_MONO 0 #define FM_AUD_AAC_CHANNEL_STEREO 1 #define FM_MFW_QCIF_WIDTH 176 #define FM_MFW_QCIF_HEIGHT 144 #define FM_MFW_PREVIEW_WIDTH 48 #define FM_MFW_PREVIEW_HEIGHT 48 typedef struct { T_FM_AUD_STATE state; }T_FM_AUD; typedef struct { BOOL hidden; }T_FM_OBJ_AUDIO; typedef enum { FM_IMAGE=0, FM_AUDIO }T_FM_APP_TYPE; //Misc typedef enum { FM_INVALID=-1, FM_NOR_FLASH, FM_NORMS_FLASH, FM_NAND_FLASH, FM_T_FLASH }T_FM_DEVICE_TYPE; typedef enum { FM_NONE=-1, FM_OPEN, FM_BACK, FM_COPY, FM_MOVE, FM_OPTIONS_FILE, FM_OPTIONS_FOLDER, FM_IMGVIEW, FM_RENAME, FM_DELETE, FM_NEWDIR, FM_REMOVE }T_FM_OPERATION_TYPE; typedef enum { OBJECT_TYPE_NONE=-1, OBJECT_TYPE_FILE, OBJECT_TYPE_AUDIO, OBJECT_TYPE_AUDIO_MIDI, OBJECT_TYPE_AUDIO_MP3, OBJECT_TYPE_AUDIO_AAC, OBJECT_TYPE_IMAGE, OBJECT_TYPE_FOLDER, OBJECT_TYPE_IMAGE_FOLDER, OBJECT_TYPE_AUDIO_FOLDER, OBJECT_TYPE_AUDIO_XMF, /* Apr 06, 2007 DRT: OMAPS00124874 x0039928 */ OBJECT_TYPE_AUDIO_IMY, OBJECT_TYPE_AUDIO_MMF, OBJECT_TYPE_AUDIO_MXMF, OBJECT_TYPE_AUDIO_SMS, OBJECT_TYPE_AUDIO_WAV }T_FM_OBJ_TYPE; typedef enum { FM_COPY_ERROR = -1, FM_COPY_NONE, FM_COPY_START, FM_COPY_PROGRESS, FM_COPY_DONE }T_FM_COPY_STATE; typedef enum { FM_STATE_NONE=0, FM_STATE_ERROR }T_MFW_FM_STATE; typedef enum { FM_NO_ERROR=0, FM_DIR_DOESNOTEXISTS, FM_FILE_EXISTS, FM_FILE_DOESNOTEXISTS, FM_READDIR_ERROR, FM_RENAME_ERROR, FM_DELETE_ERROR, FM_DELETE_DIRNOTEMPTY, FM_DIR_EXISTS, FM_FORMAT_ERROR }T_MFW_FM_STATUS; typedef struct { UINT32 aud_tt; UINT16 aud_pt; }T_MFW_AUD_PARA; typedef union { T_FM_AUD aud; T_FM_IMG img; }T_FM_DIRTYPE_INFO; typedef union { T_FM_IMG_STATE img_state; T_FM_AUD_STATE aud_state; } T_MFW_FM_PARA; typedef union { T_FM_OBJ_AUDIO audio; T_FM_OBJ_IMAGE image; }T_FM_OBJ_DATA; typedef struct { char name[FM_MAX_OBJ_NAME_LENGTH]; #ifdef FF_MMI_UNICODE_SUPPORT T_WCHAR name_uc[FM_MAX_OBJ_NAME_LENGTH]; #endif T_FM_OBJ_TYPE type; }T_FM_OBJ; typedef struct { char name[15]; }T_FM_OBJ_ITEM; typedef struct { int size; char date[FM_MAX_OBJ_DATE_LENGTH]; char time[FM_MAX_OBJ_TIME_LENGTH]; }T_FM_OBJ_PROPERTIES; typedef struct { T_FM_OBJ *obj_list[FM_MAX_OBJ]; T_FM_OBJ_PROPERTIES *obj_properties[FM_MAX_OBJ]; T_FM_OBJ_DATA *obj_data[FM_MAX_OBJ]; UBYTE num_objs; char dir_name[FM_MAX_OBJ_NAME_LENGTH]; char dir_path[FM_MAX_DIR_PATH_LENGTH]; T_FM_OBJ_TYPE dir_type; int depth; int startIndex; int currentIndex; T_FM_DIRTYPE_INFO dirinfo; }T_FM_CURDIR; typedef struct { T_FM_OBJ *obj_list[FM_MAX_OBJ]; UBYTE num_objs; char dir_name[FM_MAX_OBJ_NAME_LENGTH]; char dir_path[FM_MAX_DIR_PATH_LENGTH]; T_FM_OBJ_TYPE dir_type; int currentIndex; int depth; }T_FM_DESTDIR; typedef struct { T_MFW_EVENT emask; /* events of interest */ T_MFW_EVENT event; /* current event */ T_MFW_CB handler; T_MFW_FM_PARA para; } T_MFW_FM; typedef struct { T_RFS_FD sourceFileID; // int sourceFileID; #ifdef FF_MMI_UNICODE_SUPPORT T_WCHAR *sourceFile; #else char *sourceFile; #endif T_FM_DEVICE_TYPE source_type; int sourceFileSize; T_RFS_FD destFileID; // int destFileID; #ifdef FF_MMI_UNICODE_SUPPORT T_WCHAR *destinationFile; #else char *destinationFile; #endif T_FM_DEVICE_TYPE destination_type; char *buf; T_RFS_SIZE buf_size; int bytesRead; T_FM_COPY_STATE state; }T_MFW_FM_COPYMOVE_STRUCT; #define THUMB "thumbnail" #define NORDIR "/mmi/" #define NORDIR_IMG "jpeg" #define NORDIR_AUD "tones" #define NORMSDIR "/" #define NORMSDIR_IMG "jpeg" #define NORMSDIR_AUD "tones" #define NANDDIR "/" #define NANDDIR_IMG "jpeg" #define NANDDIR_AUD "tones" #define TFLASHDIR "/" #define TFLASHDIR_IMG "jpeg" #define TFLASHDIR_AUD "tones" void mfw_fm_readProperties(char *dir_path, char *dir_name, UBYTE num_objs, T_FM_OBJ **obj_list, T_FM_OBJ_PROPERTIES **obj_properties,T_FM_DEVICE_TYPE source, T_FM_APP_TYPE app); void mfw_fm_readFileFolders(char *dir_path, char *dir_name, UBYTE num_objs, T_FM_OBJ **obj_list, T_FM_DEVICE_TYPE source); T_MFW_FM_STATUS mfw_fm_create_rootdir(T_FM_DEVICE_TYPE source); T_MFW_HND mfw_fm_create(T_MFW_HND hWin, T_MFW_EVENT event, T_MFW_CB cbfunc); T_MFW_RES mfw_fm_delete(T_MFW_HND hnd); T_MFW_FM_STATUS mfw_fm_format(T_FM_DEVICE_TYPE source) ; #ifdef FF_MMI_UNICODE_SUPPORT T_MFW_FM_STATUS mfw_fm_rename(T_WCHAR* old_filename, T_WCHAR* new_filename, T_FM_DEVICE_TYPE source); T_MFW_FM_STATUS mfw_fm_remove(T_WCHAR* objname,T_FM_DEVICE_TYPE source); #else T_MFW_FM_STATUS mfw_fm_rename(char* old_filename, char * new_filename, T_FM_DEVICE_TYPE source); T_MFW_FM_STATUS mfw_fm_remove(char* objname,T_FM_DEVICE_TYPE source); #endif T_MFW_FM_STATUS mfw_fm_rename_image(char * path, char * dirname, char* old_filename, char * new_filename,T_FM_DEVICE_TYPE source); T_MFW_FM_STATUS mfw_fm_remove_image(char * path, char * dirname, char* objname,T_FM_DEVICE_TYPE source) ; T_MFW_FM_STATUS mfw_fm_newdir(char *dirname, T_FM_DEVICE_TYPE source); T_MFW_FM_STATUS mfw_fm_createRootDir(T_FM_DEVICE_TYPE source); T_FM_COPY_STATE mfw_fm_copy_start(T_MFW_FM_COPYMOVE_STRUCT *data) ; T_FM_COPY_STATE mfw_fm_copy_continue(T_MFW_FM_COPYMOVE_STRUCT *data) ; void mfw_fm_getMemStat(int *nfree, int *nused,T_FM_DEVICE_TYPE source); //Image T_FM_IMG_STATE mfw_fm_imgThmb_create(void); T_FM_IMG_STATE mfw_fm_imgThmb_init(void); T_FM_IMG_STATE mfw_fm_imgThmb_destroy(void); T_FM_IMG_STATE mfw_fm_imgThmb_deinit(void); T_FM_IMG_STATE mfw_fm_imgThmb_pause(void); T_FM_IMG_STATE mfw_fm_imgThmb_generate(void); T_FM_IMG_STATE mfw_fm_imgThmb_setparams(char * inFilepath, char* inFilename, int width,int height,T_FM_DEVICE_TYPE source); T_FM_IMG_STATE mfw_fm_imgThmb_setcallback(void); T_FM_IMG_STATE mfw_fm_imgViewer_create(void); T_FM_IMG_STATE mfw_fm_imgViewer_init(void); T_FM_IMG_STATE mfw_fm_imgViewer_destroy(void); T_FM_IMG_STATE mfw_fm_imgViewer_deinit(void); T_FM_IMG_STATE mfw_fm_imgViewer_pause(void); T_FM_IMG_STATE mfw_fm_imgViewer_view(void); T_FM_IMG_STATE mfw_fm_imgViewer_setparams(char * inFilepath, char* inFilename, int width,int height); T_FM_IMG_STATE mfw_fm_imgViewer_setcallback(void); void mfw_fm_thmb_mslcb( U32 tCMd,U32 tStatus); void mfw_fm_view_mslcb( U32 tCMd,U32 tStatus); T_MFW_FM_STATUS mfw_fm_checkThumbnail( char * obj,T_FM_DEVICE_TYPE source); T_FM_IMG_STATE mfw_fm_imgViewer_setConfigs(char *filename,int width, int height,int xoffset, int yoffset,U32 zFactor,int rotation_degree, T_FM_DEVICE_TYPE source); T_FM_IMG_STATE mfw_fm_imgViewer_setImageProperty( char * filepath, char *filename, int width, int height,int xoffset, int yoffset,T_FM_DEVICE_TYPE source); void mfw_fm_thmb_mslcb( U32 tCMd,U32 tStatus); void mfw_fm_view_mslcb( U32 tCMd,U32 tStatus); //Audio T_FM_AUD_STATE mfw_fm_audStop(void); #ifdef FF_MMI_UNICODE_SUPPORT T_FM_AUD_STATE mfw_fm_audPlay(T_WCHAR * file_name, T_FM_OBJ_TYPE file_type, BOOL play_bar); #else T_FM_AUD_STATE mfw_fm_audPlay(char * file_name, T_FM_OBJ_TYPE file_type, BOOL play_bar); #endif T_FM_OBJ_TYPE mfw_fm_aud_get_type(char * file_name); T_FM_AUD_STATE mfw_fm_audPause(void); T_FM_AUD_STATE mfw_fm_audResume(void); T_MFW_FM_STATUS mfw_fm_readDir(char *dir_path, char *dir_name, UBYTE *num_objs, T_FM_OBJ **obj_list, T_FM_DEVICE_TYPE source, T_FM_APP_TYPE app); /* OMAPS00151698, x0056522 */ void mfw_fm_audPlay_cb(void *parameter); /*********************************/ #if 0 typedef UINT16 T_RFS_MODE; #define RFS_IXUSR 0x0100 // Execute permission for the user #define RFS_IWUSR 0x0200 // Write permission for the user #define RFS_IRUSR 0x0400 // Read permission for the user #define RFS_IRWXU 0x0700 // Read Write permission mask (default) for the user #define RFS_IXGRP 0x0010 // Execute permission for group #define RFS_IWGRP 0x0020 // Write permission for group #define RFS_IRGRP 0x0040 // Read permission for group #define RFS_IRWXG 0x0070 // Read Write permission mask (default) for group #define RFS_IXOTH 0x0001 // Execute permission for others #define RFS_IWOTH 0x0002 // Write permission for others #define RFS_IROTH 0x0004 // Read permission for others #define RFS_IRWXO 0x0007 // Read Write permission mask (default) for others typedef INT32 T_RFS_RET; #define RFS_EOK 0 #define RFS_ENODEVICE -1 #define RFS_EAGAIN -2 #define RFS_ENOSPACE -3 #define RFS_EFSFULL -4 #define RFS_EBADNAME -5 #define RFS_ENOENT -6 #define RFS_EEXISTS -7 #define RFS_EACCES -8 #define RFS_ENAMETOOLONG -9 #define RFS_EINVALID -10 #define RFS_ENOTEMPTY -11 #define RFS_EFBIG -12 #define RFS_ENOTAFILE -13 #define RFS_ENUMFD -14 #define RFS_EBADFD -15 #define RFS_EBADDIR -16 #define RFS_EBADOP -17 #define RFS_ELOCKED -18 #define RFS_EMOUNT -19 #define RFS_EDEVICE -20 #define RFS_EBUSY -21 #define RFS_ENOTADIR -22 #define RFS_EMAGIC -23 #define RFS_EMEMORY -24 #define RFS_EMSGSEND -25 #define RFS_ENOTALLOWED -26 #define RFS_ENOTSUPPORTED -27 #define RFS_EEMPTY -28 #define RFS_EINTERNALERROR -29 #define RFS_CORRUPT_LFN -30 #define RFS_E_FILETOOBIG -31 typedef union { T_RFS_FS_STAT file_system; T_RFS_MP_STAT mount_point; T_RFS_FILE_DIR_STAT file_dir; } T_RFS_STAT; /* Defines the DIR type. This represents a directory stream, which is an ordered * sequence of all the di-rectory entries (files) in a particular directory. */ typedef struct { UINT32 opendir_ino; // inode of directory that was opened UINT32 lastread_ino; // last inode of the read direcoty entry UINT8 mpt_idx; // mount point where the directory is located UINT8 fscore_nmb; // file system type } T_RFS_DIR; typedef enum { FFS_ATTRIB_READWRITE = FFS_ATTRIB_READWRITE_MASK, FFS_ATTRIB_READONLY = FFS_ATTRIB_READONLY_MASK, FFS_ATTRIB_HIDDEN = FFS_ATTRIB_HIDDEN_MASK, FFS_ATTRIB_SYSTEM = FFS_ATTRIB_SYSTEM_MASK, FFS_ATTRIB_SUBDIR = FFS_ATTRIB_SUBDIR_MASK, FFS_ATTRIB_ARCHIVE = FFS_ATTRIB_ARCHIVE_MASK, FFS_ATTRIB_INVALID }T_FFS_ATTRIB_TYPE; /**********************************/ #endif #endif