Skip to content

Commit

Permalink
Merge pull request #477 from pennam/stm32h7-ota
Browse files Browse the repository at this point in the history
STM32H7 OTA code cleanup
  • Loading branch information
pennam authored Jun 10, 2024
2 parents b93768d + 8143741 commit c6b3c77
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 71 deletions.
76 changes: 30 additions & 46 deletions src/ota/implementation/OTASTM32H7.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,21 +11,15 @@
#include "AIoTC_Config.h"
#if defined(BOARD_STM32H7) && OTA_ENABLED
#include "OTASTM32H7.h"

#include "utility/watchdog/Watchdog.h"
#include <STM32H747_System.h>

static bool findProgramLength(DIR * dir, uint32_t & program_length);

const char STM32H7OTACloudProcess::UPDATE_FILE_NAME[] = "/fs/UPDATE.BIN";

STM32H7OTACloudProcess::STM32H7OTACloudProcess(MessageStream *ms, Client* client)
: OTADefaultCloudProcessInterface(ms, client)
, decompressed(nullptr)
, _bd_raw_qspi(nullptr)
, _program_length(0)
, _bd(nullptr)
, _fs(nullptr) {
, _fs(nullptr)
, _filename("/" + String(STM32H747OTA::FOLDER) + "/" + String(STM32H747OTA::NAME)) {

}

Expand All @@ -44,7 +38,6 @@ OTACloudProcessInterface::State STM32H7OTACloudProcess::resume(Message* msg) {

void STM32H7OTACloudProcess::update() {
OTADefaultCloudProcessInterface::update();
watchdog_reset(); // FIXME this should npot be performed here
}

int STM32H7OTACloudProcess::writeFlash(uint8_t* const buffer, size_t len) {
Expand All @@ -65,10 +58,13 @@ OTACloudProcessInterface::State STM32H7OTACloudProcess::startOTA() {
}

// this could be useless, since we are writing over it
remove(UPDATE_FILE_NAME);
remove(_filename.c_str());

decompressed = fopen(UPDATE_FILE_NAME, "wb");
decompressed = fopen(_filename.c_str(), "wb");

if(decompressed == nullptr) {
return ErrorOpenUpdateFileFail;
}
// start the download if the setup for ota storage is successful
return OTADefaultCloudProcessInterface::startOTA();
}
Expand All @@ -78,18 +74,20 @@ OTACloudProcessInterface::State STM32H7OTACloudProcess::flashOTA() {
fclose(decompressed);
decompressed = nullptr;

uint32_t updateLength = 0;

/* Schedule the firmware update. */
if(!storageOpen()) {
if(!findProgramLength(updateLength)) {
return OtaStorageOpenFail;
}

storageClean();

// this sets the registries in RTC to load the firmware from the storage selected at the next reboot
STM32H747::writeBackupRegister(RTCBackup::DR0, 0x07AA);
STM32H747::writeBackupRegister(RTCBackup::DR1, storage);
STM32H747::writeBackupRegister(RTCBackup::DR2, data_offset);
STM32H747::writeBackupRegister(RTCBackup::DR3, _program_length);
STM32H747::writeBackupRegister(RTCBackup::DR0, STM32H747OTA::MAGIC);
STM32H747::writeBackupRegister(RTCBackup::DR1, STM32H747OTA::STORAGE_TYPE);
STM32H747::writeBackupRegister(RTCBackup::DR2, STM32H747OTA::PARTITION);
STM32H747::writeBackupRegister(RTCBackup::DR3, updateLength);

return Reboot;
}
Expand All @@ -106,7 +104,7 @@ OTACloudProcessInterface::State STM32H7OTACloudProcess::reboot() {
void STM32H7OTACloudProcess::reset() {
OTADefaultCloudProcessInterface::reset();

remove(UPDATE_FILE_NAME);
remove(_filename.c_str());

storageClean();
}
Expand Down Expand Up @@ -156,14 +154,9 @@ bool STM32H7OTACloudProcess::storageInit() {
}
}

if (storage == portenta::QSPI_FLASH_FATFS) {
_fs = new mbed::FATFileSystem("fs");
err_mount = _fs->mount(_bd_raw_qspi);
} else if (storage == portenta::QSPI_FLASH_FATFS_MBR) {
_bd = new mbed::MBRBlockDevice(_bd_raw_qspi, data_offset);
_fs = new mbed::FATFileSystem("fs");
err_mount = _fs->mount(_bd);
}
_bd = new mbed::MBRBlockDevice(_bd_raw_qspi, STM32H747OTA::PARTITION);
_fs = new mbed::FATFileSystem(STM32H747OTA::FOLDER);
err_mount = _fs->mount(_bd);

if (!err_mount) {
return true;
Expand All @@ -172,43 +165,34 @@ bool STM32H7OTACloudProcess::storageInit() {
return false;
}

bool STM32H7OTACloudProcess::storageOpen() {
bool STM32H7OTACloudProcess::findProgramLength(uint32_t & program_length) {
DIR * dir = NULL;
if ((dir = opendir("/fs")) != NULL)
{
if (findProgramLength(dir, _program_length))
{
closedir(dir);
return true;
}
closedir(dir);
}
struct dirent * entry = NULL;
String dirName = "/" + String(STM32H747OTA::FOLDER);
bool found = false;

return false;
}
if ((dir = opendir(dirName.c_str())) == NULL) {
return false;
}

bool findProgramLength(DIR * dir, uint32_t & program_length) {
struct dirent * entry = NULL;
while ((entry = readdir(dir)) != NULL) {
if (strcmp(entry->d_name, "UPDATE.BIN") == 0) { // FIXME use constants
if (strcmp(entry->d_name, STM32H747OTA::NAME) == 0) {
struct stat stat_buf;
stat("/fs/UPDATE.BIN", &stat_buf);
stat(_filename.c_str(), &stat_buf);
program_length = stat_buf.st_size;
return true;
found = true;
}
}

return false;
closedir(dir);
return found;
}

// extern uint32_t __stext = ~0;
extern uint32_t __etext;
extern uint32_t _sdata;
extern uint32_t _edata;

void* STM32H7OTACloudProcess::appStartAddress() {
return (void*)0x8040000;
// return &__stext;
}

uint32_t STM32H7OTACloudProcess::appSize() {
Expand Down
38 changes: 13 additions & 25 deletions src/ota/implementation/OTASTM32H7.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,20 +21,17 @@
#include "WiFi.h" /* WiFi from ArduinoCore-mbed */
#include <SocketHelpers.h>

#define APOTA_QSPI_FLASH_FLAG (1 << 2)
#define APOTA_SDCARD_FLAG (1 << 3)
#define APOTA_RAW_FLAG (1 << 4)
#define APOTA_FATFS_FLAG (1 << 5)
#define APOTA_LITTLEFS_FLAG (1 << 6)
#define APOTA_MBR_FLAG (1 << 7)

namespace portenta {
enum StorageType {
QSPI_FLASH_FATFS = APOTA_QSPI_FLASH_FLAG | APOTA_FATFS_FLAG,
QSPI_FLASH_FATFS_MBR = APOTA_QSPI_FLASH_FLAG | APOTA_FATFS_FLAG | APOTA_MBR_FLAG,
SD_FATFS = APOTA_SDCARD_FLAG | APOTA_FATFS_FLAG,
SD_FATFS_MBR = APOTA_SDCARD_FLAG | APOTA_FATFS_FLAG | APOTA_MBR_FLAG,
};
namespace STM32H747OTA {
/* External QSPI flash + MBR + FatFs */
static const uint32_t constexpr STORAGE_TYPE = ((1 << 2) | (1 << 5) | (1 << 7));
/* Default OTA partition */
static const uint32_t constexpr PARTITION = 2;
/* OTA Magic number */
static const uint32_t constexpr MAGIC = 0x07AA;
/* OTA download folder name */
static const char constexpr FOLDER[] = "ota";
/* OTA update filename */
static const char constexpr NAME[] = "UPDATE.BIN";
}

class STM32H7OTACloudProcess: public OTADefaultCloudProcessInterface {
Expand Down Expand Up @@ -67,23 +64,14 @@ class STM32H7OTACloudProcess: public OTADefaultCloudProcessInterface {
bool appFlashClose() { return true; };
private:
bool storageInit();
bool storageOpen();

bool findProgramLength(uint32_t & program_length);
void storageClean();

FILE* decompressed;
// static const char UPDATE_FILE_NAME[];
mbed::BlockDevice* _bd_raw_qspi;
uint32_t _program_length;

mbed::BlockDevice* _bd;
mbed::FATFileSystem* _fs;

mbed::MBRBlockDevice* cert_bd_qspi;
mbed::FATFileSystem* cert_fs_qspi;

const portenta::StorageType storage=portenta::QSPI_FLASH_FATFS_MBR;
const uint32_t data_offset=2;

static const char UPDATE_FILE_NAME[];
String _filename;
};

0 comments on commit c6b3c77

Please # to comment.