mirror of
https://github.com/jomjol/AI-on-the-edge-device.git
synced 2026-01-27 04:40:39 +03:00
219 lines
7.4 KiB
C++
219 lines
7.4 KiB
C++
#include "sdcard_check.h"
|
|
#include <string.h>
|
|
#include <stdio.h>
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
#include <unistd.h>
|
|
#include <inttypes.h>
|
|
#include <sys/stat.h>
|
|
|
|
#include "esp_rom_crc.h"
|
|
#include "ClassLogFile.h"
|
|
|
|
static const char *TAG = "SDCARD";
|
|
|
|
int SDCardCheckRW(void)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_INFO, TAG, "Basic R/W check started...");
|
|
int iCRCMessage = 0;
|
|
|
|
FILE *pFile = fopen("/sdcard/sdcheck.txt", "w");
|
|
if (pFile == NULL)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Basic R/W check: (E1) No able to open file to write");
|
|
return -1;
|
|
}
|
|
else
|
|
{
|
|
std::string sMessage = "This message is used for a SD-Card basic check!";
|
|
iCRCMessage = esp_rom_crc16_le(0, (uint8_t *)sMessage.c_str(), sMessage.length());
|
|
if (fwrite(sMessage.c_str(), sMessage.length(), 1, pFile) == 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Basic R/W check: (E2) Not able to write file");
|
|
fclose(pFile);
|
|
unlink("/sdcard/sdcheck.txt");
|
|
return -2;
|
|
}
|
|
fclose(pFile);
|
|
}
|
|
|
|
pFile = fopen("/sdcard/sdcheck.txt", "r");
|
|
if (pFile == NULL)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Basic R/W check: (E3) Not able to open file to read back");
|
|
unlink("/sdcard/sdcheck.txt");
|
|
return -3;
|
|
}
|
|
else
|
|
{
|
|
char cReadBuf[50];
|
|
if (fgets(cReadBuf, sizeof(cReadBuf), pFile) == 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Basic R/W check: (E4) Not able to read file back");
|
|
fclose(pFile);
|
|
unlink("/sdcard/sdcheck.txt");
|
|
return -4;
|
|
}
|
|
else
|
|
{
|
|
if (esp_rom_crc16_le(0, (uint8_t *)cReadBuf, strlen(cReadBuf)) != iCRCMessage)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Basic R/W check: (E5) Read back, but wrong CRC");
|
|
fclose(pFile);
|
|
unlink("/sdcard/sdcheck.txt");
|
|
return -5;
|
|
}
|
|
}
|
|
fclose(pFile);
|
|
}
|
|
|
|
if (unlink("/sdcard/sdcheck.txt") != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Basic R/W check: (E6) Unable to delete the file");
|
|
return -6;
|
|
}
|
|
|
|
LogFile.WriteToFile(ESP_LOG_INFO, TAG, "Basic R/W check successful");
|
|
return 0;
|
|
}
|
|
|
|
bool SDCardCheckFolderFilePresence()
|
|
{
|
|
struct stat sb;
|
|
bool bRetval = true;
|
|
|
|
LogFile.WriteToFile(ESP_LOG_INFO, TAG, "Folder/file presence check started...");
|
|
/* check if folder exists: config */
|
|
if (stat("/sdcard/config", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: Folder /config not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if folder exists: html */
|
|
if (stat("/sdcard/html", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: Folder /html not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if folder exists: firmware */
|
|
if (stat("/sdcard/firmware", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: Folder /firmware not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if folder exists: img_tmp */
|
|
if (stat("/sdcard/img_tmp", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: Folder /img_tmp not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if folder exists: log */
|
|
if (stat("/sdcard/log", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: Folder /log not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if folder exists: demo */
|
|
if (stat("/sdcard/demo", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: Folder /demo not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: wlan.ini */
|
|
if ((stat("/sdcard/wlan.ini", &sb) != 0) && (stat("/sdcard/network.ini", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /wlan.ini not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: config.ini */
|
|
if (stat("/sdcard/config/config.ini", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /config/config.ini not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: index.html */
|
|
if ((stat("/sdcard/html/index.html", &sb) != 0) && (stat("/sdcard/html/index.html.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/index.html not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: overview.html */
|
|
if ((stat("/sdcard/html/overview.html", &sb) != 0) && (stat("/sdcard/html/overview.html.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/overview.html not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: ota.html */
|
|
if ((stat("/sdcard/html/ota_page.html", &sb) != 0) && (stat("/sdcard/html/ota_page.html.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/ota.html not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: log.html */
|
|
if ((stat("/sdcard/html/log.html", &sb) != 0) && (stat("/sdcard/html/log.html.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/log.html not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: common.js */
|
|
if ((stat("/sdcard/html/common.js", &sb) != 0) && (stat("/sdcard/html/common.js.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/common.js not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: readconfigcommon.js */
|
|
if ((stat("/sdcard/html/readconfigcommon.js", &sb) != 0) && (stat("/sdcard/html/readconfigcommon.js.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/readconfigcommon.js not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: readconfigparam.js */
|
|
if ((stat("/sdcard/html/readconfigparam.js", &sb) != 0) && (stat("/sdcard/html/readconfigparam.js.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/readconfigparam.js not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: jquery-3.6.0.min.js */
|
|
if ((stat("/sdcard/html/jquery-3.6.0.min.js", &sb) != 0) && (stat("/sdcard/html/jquery-3.6.0.min.js.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/jquery-3.6.0.min.js not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: firework.js */
|
|
if ((stat("/sdcard/html/firework.js", &sb) != 0) && (stat("/sdcard/html/firework.js.gz", &sb) != 0))
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/firework.js not found");
|
|
bRetval = false;
|
|
}
|
|
|
|
/* check if file exists: version.txt */
|
|
if (stat("/sdcard/html/version.txt", &sb) != 0)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Folder/file check: File /html/version.txt not found");
|
|
// bRetval = false;
|
|
}
|
|
|
|
if (bRetval)
|
|
{
|
|
LogFile.WriteToFile(ESP_LOG_INFO, TAG, "Folder/file presence check successful");
|
|
}
|
|
|
|
return bRetval;
|
|
}
|