#include #include #include #include #include #include "sys_filesys.h" #include "sys_mempool.h" #include "FileDB.h" #include "gpio.h" #include #include #include "sys_fastboot.h" #include "PrjCfg.h" #include "DxHunting.h" #include #if HUNTING_CAMERA_MCU == ENABLE #include "PrjInc.h" #include "wdt.h" #include #endif #if (HUNTING_CAMERA_MODEL == ENABLE) #include "IOCfg.h" #include "sf_sd_common.h" #define GPIO_CARD_INSERT_LEVEL (FALSE) // low active #define MAX_OPENED_FILE_NUM 10 static THREAD_HANDLE task_hdl, task_hdl2; static void card_insert_job(void) { UINT32 uiPoolAddr; int ret; FILE_TSK_INIT_PARAM Param = {0}; FS_HANDLE StrgDXH; printf("filesys_init b\r\n"); memset(&Param, 0, sizeof(FILE_TSK_INIT_PARAM)); #if defined(_EMBMEM_EMMC_) StrgDXH = (FS_HANDLE)sdio3_getStorageObject(STRG_OBJ_FAT1); #else StrgDXH = (FS_HANDLE)sdio_getStorageObject(STRG_OBJ_FAT1); #endif uiPoolAddr = mempool_filesys; Param.FSParam.WorkBuf = uiPoolAddr; Param.FSParam.WorkBufSize = (POOL_SIZE_FILESYS); // support exFAT Param.FSParam.bSupportExFAT = TRUE; //Param.pDiskErrCB = (FileSys_CB)Card_InitCB; strncpy(Param.FSParam.szMountPath, "/mnt/sd", sizeof(Param.FSParam.szMountPath) - 1); //only used by FsLinux Param.FSParam.szMountPath[sizeof(Param.FSParam.szMountPath) - 1] = '\0'; Param.FSParam.MaxOpenedFileNum = MAX_OPENED_FILE_NUM; if (FST_STA_OK != FileSys_Init(FileSys_GetOPS_uITRON())) { DBG_WRN("FileSys_Init failed\r\n"); } ret = FileSys_OpenEx('A', StrgDXH, &Param); if (FST_STA_OK != ret) { DBG_WRN("FileSys_Open err %d\r\n", ret); } // call the function to wait init finish FileSys_WaitFinishEx('A'); FileSys_SetParamEx('A', FST_PARM_UPDATE_FSINFO , TRUE); #if USE_RTOS_MMC_CHECK SF_RtosStrgRegister(0, ret); #endif #if HUNTING_CAMERA_MCU == ENABLE if(TRUE == sf_check_card_full()) { DBG_WRN("ERR card full\r\n"); fastboot_set_done(BOOT_INIT_FILESYSOK); } else { fastboot_set_done(BOOT_INIT_FILESYSOK); //sf_log_confg(); //sf_log_open(); } #endif printf("filesys_init e\r\n"); } static void card_insert_job2(void) { #if FS_MULTI_STRG_FUNC UINT32 uiPoolAddr; int ret; FILE_TSK_INIT_PARAM Param = {0}; FS_HANDLE StrgDXH2; UINT32 start_sector = 8192 ; /* linux cmd fdisk can list partition info */ UINT32 totoal_sectors = 0; StrgDXH2 = (FS_HANDLE)sdio2_getStorageObject(STRG_OBJ_FAT1); STORAGE_OBJ* pStrg = sdio2_getStorageObject(STRG_OBJ_FAT1); printf("filesys2_init b\r\n"); memset(&Param, 0, sizeof(FILE_TSK_INIT_PARAM)); pStrg->Open(); pStrg->GetParam(STRG_GET_DEVICE_PHY_SECTORS, (UINT32)&totoal_sectors, 0); if (totoal_sectors == 0) { DBG_WRN("totoal_sectors couldn't be zero\n"); } pStrg->SetParam(STRG_SET_PARTITION_SECTORS, start_sector, totoal_sectors - start_sector); uiPoolAddr = mempool_filesys + POOL_SIZE_FILESYS; Param.FSParam.WorkBuf = uiPoolAddr; Param.FSParam.WorkBufSize = (POOL_SIZE_FILESYS); // support exFAT Param.FSParam.bSupportExFAT = FALSE; //Param.pDiskErrCB = (FileSys_CB)Card_InitCB; strncpy(Param.FSParam.szMountPath, "/mnt/sd2", sizeof(Param.FSParam.szMountPath) - 1); //only used by FsLinux Param.FSParam.szMountPath[sizeof(Param.FSParam.szMountPath) - 1] = '\0'; Param.FSParam.MaxOpenedFileNum = MAX_OPENED_FILE_NUM; DBG_WRN("Open B:\n"); ret = FileSys_OpenEx('B', StrgDXH2, &Param); if (FST_STA_OK != ret) { printf("FileSys_Open err %d\r\n", ret); } FileSys_WaitFinishEx('B'); FileSys_SetParamEx('B', FST_PARM_UPDATE_FSINFO , TRUE); #if USE_RTOS_MMC_CHECK SF_RtosStrgRegister(1, ret); #endif #if SF_AGEING_TEST == ENABLE sf_check_emmc_full(); fastboot_set_done(BOOT_INIT_FILESYSOK_2); #else fastboot_set_done(BOOT_INIT_FILESYSOK_2); #endif printf("filesys2_init e\r\n"); #endif } #if !defined(_EMBMEM_EMMC_) static void card_remove_job(void) { FileSys_WaitFinishEx('A'); FileSys_CloseEx('A', FST_TIME_INFINITE); } #endif static void sys_detect_card_task(void) { #if defined(_EMBMEM_EMMC_) THREAD_ENTRY(); card_insert_job(); THREAD_RETURN(0); #else UINT32 old_detect; UINT32 card_det_tsk_run = 1; THREAD_ENTRY(); // force 1st time card detect old_detect = !GPIO_CARD_INSERT_LEVEL; //coverity[no_escape] while (card_det_tsk_run) { UINT32 curr_detect; curr_detect= gpio_getPin(GPIO_CARD_DETECT); if (old_detect != curr_detect) { if (curr_detect == GPIO_CARD_INSERT_LEVEL) { printf("%s: Card Insert\r\n", __func__); card_insert_job(); card_det_tsk_run = 0; } else { printf("%s: Card Remove\r\n", __func__); card_remove_job(); } } old_detect = curr_detect; vTaskDelay(pdMS_TO_TICKS(1000)); } //#if USE_RTOS_MMC_CHECK //SF_RtosStrgUnInit(); //#endif THREAD_RETURN(0); #endif } static void sys_detect_card_task2(void) { THREAD_ENTRY(); card_insert_job2(); THREAD_RETURN(0); } #endif void filesys_init(void) { #if 0 UINT32 uiPoolAddr; int ret; FILE_TSK_INIT_PARAM Param = {0}; FS_HANDLE StrgDXH; printf("filesys_init b\r\n"); memset(&Param, 0, sizeof(FILE_TSK_INIT_PARAM)); StrgDXH = (FS_HANDLE)sdio_getStorageObject(STRG_OBJ_FAT1); uiPoolAddr = mempool_filesys; Param.FSParam.WorkBuf = uiPoolAddr; Param.FSParam.WorkBufSize = (POOL_SIZE_FILESYS); // support exFAT Param.FSParam.bSupportExFAT = TRUE; //Param.pDiskErrCB = (FileSys_CB)Card_InitCB; strncpy(Param.FSParam.szMountPath, "/mnt/sd", sizeof(Param.FSParam.szMountPath) - 1); //only used by FsLinux Param.FSParam.szMountPath[sizeof(Param.FSParam.szMountPath) - 1] = '\0'; #endif FileSys_InstallID(FileSys_GetOPS_uITRON()); #if (HUNTING_CAMERA_MODEL == ENABLE) if(DrvGPIO_GetHuntingWorkMode() != HUNTING_NORMAL_MODE){ task_hdl = vos_task_create(sys_detect_card_task, 0, "SysDetectCard", 12, 4096); vos_task_resume(task_hdl); task_hdl2 = vos_task_create(sys_detect_card_task2, 0, "SysDetectCard2", 12, 4096); vos_task_resume(task_hdl2); } #endif #if USE_RTOS_MMC_CHECK SF_RtosStrgInit(); #endif #if 0 if (FST_STA_OK != FileSys_Init(FileSys_GetOPS_uITRON())) { printf("FileSys_Init failed\r\n"); } ret = FileSys_OpenEx('A', StrgDXH, &Param); if (FST_STA_OK != ret) { printf("FileSys_Open err %d\r\n", ret); } // call the function to wait init finish FileSys_WaitFinishEx('A'); printf("filesys_init e\r\n"); #endif FileDB_InstallID(); } #if HUNTING_CAMERA_MCU == ENABLE static int SF_SX_TIMER_DET_SYSTEM_ERROR_ID = -1; _ALIGNED(64) static CHAR gLogFile_Buff[LOGFILE_BUFFER_SIZE]= {0}; void sfSystem_DetErr(void); SX_TIMER_ITEM(sfSystem_DetErr, sfSystem_DetErr,50, FALSE) void sfSystem_DetErr(void) { } void sf_log_confg(void) { #if (LOGFILE_FUNC==ENABLE) UIMenuStoreInfo *puiPara = sf_ui_para_get(); if(puiPara->DebugMode) { LOGFILE_CFG cfg = {0}; cfg.ConType = LOGFILE_CON_UART|LOGFILE_CON_STORE; cfg.TimeType = LOGFILE_TIME_TYPE_DATETIME; cfg.LogBuffAddr = (UINT32)gLogFile_Buff; cfg.LogBuffSize = sizeof(gLogFile_Buff); LogFile_Config(&cfg); SF_SX_TIMER_DET_SYSTEM_ERROR_ID = SxTimer_AddItem(&Timer_sfSystem_DetErr); } #endif } void sf_log_open(void) { #if (LOGFILE_FUNC==ENABLE) UIMenuStoreInfo *puiPara = sf_ui_para_get(); if ((puiPara->DebugMode) && SxTimer_GetFuncActive(SF_SX_TIMER_DET_SYSTEM_ERROR_ID) == 0) { LOGFILE_OPEN logOpenParm = {0}; UINT32 maxFileNum = 32; UINT32 maxFileSize = 0x100000; // 1MB CHAR rootDir[LOGFILE_ROOT_DIR_MAX_LEN + 1] = "A:\\LOG\\"; #if defined(_CPU2_LINUX_) CHAR rootDir2[LOGFILE_ROOT_DIR_MAX_LEN + 1] = "A:\\Novatek\\LOG2\\"; #endif CHAR sysErrRootDir[LOGFILE_ROOT_DIR_MAX_LEN + 1] = "A:\\SYS\\"; logOpenParm.maxFileNum = maxFileNum; logOpenParm.maxFileSize = maxFileSize; logOpenParm.isPreAllocAllFiles = FALSE; logOpenParm.isSaveLastTimeSysErrLog = wdt_getResetNum()>0 ? TRUE : FALSE; logOpenParm.lastTimeSysErrLogBuffAddr = mempool_logfile; logOpenParm.lastTimeSysErrLogBuffSize = POOL_SIZE_LOGFILE; logOpenParm.isZeroFile = TRUE; strncpy(logOpenParm.rootDir, rootDir, LOGFILE_ROOT_DIR_MAX_LEN); #if defined(_CPU2_LINUX_) strncpy(logOpenParm.rootDir2, rootDir2, LOGFILE_ROOT_DIR_MAX_LEN); #endif strncpy(logOpenParm.sysErrRootDir, sysErrRootDir, LOGFILE_ROOT_DIR_MAX_LEN); LogFile_Open(&logOpenParm); //start scan SxTimer_SetFuncActive(SF_SX_TIMER_DET_SYSTEM_ERROR_ID, TRUE); sf_para_print(); } #endif } #endif