Compare commits
2 commits
0dfe79e21d
...
9405b3d8b8
Author | SHA1 | Date | |
---|---|---|---|
|
9405b3d8b8 | ||
|
664c61026e |
3 changed files with 84 additions and 13 deletions
|
@ -82,7 +82,7 @@ void HAL_SPI_MspInit(SPI_HandleTypeDef* spiHandle)
|
||||||
GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15;
|
GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15;
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_MEDIUM;
|
||||||
GPIO_InitStruct.Alternate = GPIO_AF5_SPI2;
|
GPIO_InitStruct.Alternate = GPIO_AF5_SPI2;
|
||||||
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
||||||
|
|
||||||
|
|
|
@ -93,10 +93,16 @@ PB11.Signal=GPIO_Output
|
||||||
PB12.GPIOParameters=GPIO_Label
|
PB12.GPIOParameters=GPIO_Label
|
||||||
PB12.GPIO_Label=DisplayCS
|
PB12.GPIO_Label=DisplayCS
|
||||||
PB12.Signal=GPIO_Output
|
PB12.Signal=GPIO_Output
|
||||||
|
PB13.GPIOParameters=GPIO_Speed
|
||||||
|
PB13.GPIO_Speed=GPIO_SPEED_FREQ_MEDIUM
|
||||||
PB13.Mode=Full_Duplex_Master
|
PB13.Mode=Full_Duplex_Master
|
||||||
PB13.Signal=SPI2_SCK
|
PB13.Signal=SPI2_SCK
|
||||||
|
PB14.GPIOParameters=GPIO_Speed
|
||||||
|
PB14.GPIO_Speed=GPIO_SPEED_FREQ_MEDIUM
|
||||||
PB14.Mode=Full_Duplex_Master
|
PB14.Mode=Full_Duplex_Master
|
||||||
PB14.Signal=SPI2_MISO
|
PB14.Signal=SPI2_MISO
|
||||||
|
PB15.GPIOParameters=GPIO_Speed
|
||||||
|
PB15.GPIO_Speed=GPIO_SPEED_FREQ_MEDIUM
|
||||||
PB15.Mode=Full_Duplex_Master
|
PB15.Mode=Full_Duplex_Master
|
||||||
PB15.Signal=SPI2_MOSI
|
PB15.Signal=SPI2_MOSI
|
||||||
PinOutPanel.RotationAngle=0
|
PinOutPanel.RotationAngle=0
|
||||||
|
|
|
@ -3,12 +3,14 @@
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "semphr.h"
|
#include "semphr.h"
|
||||||
#include "spi.h"
|
#include "spi.h"
|
||||||
|
#include "stm32l1xx_hal_flash_ex.h"
|
||||||
#include "task.h"
|
#include "task.h"
|
||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
#include "BME68x-Sensor-API/bme68x.h"
|
#include "BME68x-Sensor-API/bme68x.h"
|
||||||
#include "BSEC/bsec_interface.h"
|
#include "BSEC/bsec_interface.h"
|
||||||
|
#include "SSD1306_SPI.hpp"
|
||||||
#include "oled-driver/Renderer.hpp"
|
#include "oled-driver/Renderer.hpp"
|
||||||
|
|
||||||
extern QueueHandle_t spiMutex;
|
extern QueueHandle_t spiMutex;
|
||||||
|
@ -51,8 +53,10 @@ float iaq, rawTemperature, pressure, rawHumidity, gasResistance, stabStatus, run
|
||||||
uint8_t iaqAccuracy, staticIaqAccuracy, co2Accuracy, breathVocAccuracy, compGasAccuracy,
|
uint8_t iaqAccuracy, staticIaqAccuracy, co2Accuracy, breathVocAccuracy, compGasAccuracy,
|
||||||
gasPercentageAcccuracy;
|
gasPercentageAcccuracy;
|
||||||
|
|
||||||
// uint8_t bsecState[BSEC_MAX_STATE_BLOB_SIZE];
|
uint8_t bsecState[BSEC_MAX_STATE_BLOB_SIZE];
|
||||||
// uint8_t workBuffer[BSEC_MAX_WORKBUFFER_SIZE];
|
uint8_t workBuffer[BSEC_MAX_WORKBUFFER_SIZE];
|
||||||
|
|
||||||
|
constexpr uintptr_t EepromAddress = FLASH_EEPROM_BASE;
|
||||||
|
|
||||||
void setChipSelect(bool state)
|
void setChipSelect(bool state)
|
||||||
{
|
{
|
||||||
|
@ -310,33 +314,94 @@ void printBmeSensorData()
|
||||||
{
|
{
|
||||||
renderer.clearAll();
|
renderer.clearAll();
|
||||||
|
|
||||||
snprintf(buffer, MaximumChars,
|
const auto MaxTextWidth = renderer.getLineWidth("1000hPa");
|
||||||
"%d°C, %luhPa, %d%%\nIAQ: %d, Accuracy: %d\nCO2: %dppm\n%d, %d, %d - %lukOhm",
|
|
||||||
|
snprintf(buffer, MaximumChars, "%d°C\n%luhPa\n%d%%\nAcc: %d",
|
||||||
static_cast<int>(temperature), //
|
static_cast<int>(temperature), //
|
||||||
bmeData[numberOfData - 1].pressure / 100, //
|
bmeData[numberOfData - 1].pressure / 100, //
|
||||||
static_cast<int>(humidity), //
|
static_cast<int>(humidity), //
|
||||||
static_cast<int>(iaq), //
|
iaqAccuracy);
|
||||||
iaqAccuracy, //
|
renderer.print({128, 0}, buffer, Renderer::Alignment::Right);
|
||||||
static_cast<int>(co2Equivalent), //
|
renderer.drawVerticalLine(OledWidth - MaxTextWidth - 2, 0, OledPages - 1);
|
||||||
bmeData[numberOfData - 1].status, //
|
|
||||||
bmeData[numberOfData - 1].gas_index, //
|
|
||||||
bmeData[numberOfData - 1].gas_wait, //
|
|
||||||
bmeData[numberOfData - 1].gas_resistance / 1000);
|
|
||||||
|
|
||||||
renderer.print({0, 0}, buffer);
|
if (iaqAccuracy == 0)
|
||||||
|
snprintf(buffer, MaximumChars, "IAQ:---\n---ppm\n");
|
||||||
|
else
|
||||||
|
snprintf(buffer, MaximumChars, "IAQ:%d\n%dppm\n",
|
||||||
|
static_cast<int>(iaq), //
|
||||||
|
static_cast<int>(co2Equivalent));
|
||||||
|
|
||||||
|
renderer.print({0, 0}, buffer, Renderer::Alignment::Left, 2);
|
||||||
renderer.render();
|
renderer.render();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void readStateFromEeprom()
|
||||||
|
{
|
||||||
|
|
||||||
|
uint8_t sizeOfData = *reinterpret_cast<uint8_t *>(EepromAddress);
|
||||||
|
|
||||||
|
if (sizeOfData != BSEC_MAX_STATE_BLOB_SIZE)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Existing state in EEPROM
|
||||||
|
for (uint8_t i = 0; i < BSEC_MAX_STATE_BLOB_SIZE; i++)
|
||||||
|
{
|
||||||
|
bsecState[i] = *reinterpret_cast<uint8_t *>(EepromAddress + i + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
bsec_set_state(bsecState, BSEC_MAX_STATE_BLOB_SIZE, workBuffer, sizeof(workBuffer));
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeStateToEeprom()
|
||||||
|
{
|
||||||
|
if (iaqAccuracy != 3)
|
||||||
|
return;
|
||||||
|
|
||||||
|
uint32_t numberSerializedState = BSEC_MAX_STATE_BLOB_SIZE;
|
||||||
|
|
||||||
|
auto status = bsec_get_state(0, bsecState, BSEC_MAX_STATE_BLOB_SIZE, workBuffer,
|
||||||
|
BSEC_MAX_STATE_BLOB_SIZE, &numberSerializedState);
|
||||||
|
|
||||||
|
if (status != BSEC_OK)
|
||||||
|
return;
|
||||||
|
|
||||||
|
HAL_FLASHEx_DATAEEPROM_Unlock();
|
||||||
|
|
||||||
|
// write size
|
||||||
|
HAL_FLASHEx_DATAEEPROM_Program(FLASH_TYPEPROGRAMDATA_BYTE, EepromAddress,
|
||||||
|
BSEC_MAX_STATE_BLOB_SIZE);
|
||||||
|
|
||||||
|
for (uint8_t i = 0; i < BSEC_MAX_STATE_BLOB_SIZE; i++)
|
||||||
|
{
|
||||||
|
HAL_FLASHEx_DATAEEPROM_Program(FLASH_TYPEPROGRAMDATA_BYTE, EepromAddress + i + 1,
|
||||||
|
bsecState[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
HAL_FLASHEx_DATAEEPROM_Lock();
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
extern "C" void sensorTask(void *)
|
extern "C" void sensorTask(void *)
|
||||||
{
|
{
|
||||||
initDisplay();
|
initDisplay();
|
||||||
bmeSensorInit();
|
bmeSensorInit();
|
||||||
|
readStateFromEeprom();
|
||||||
|
|
||||||
|
uint16_t counter = 0;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
bmeRun();
|
bmeRun();
|
||||||
bsecRun();
|
bsecRun();
|
||||||
printBmeSensorData();
|
printBmeSensorData();
|
||||||
|
|
||||||
|
if (counter++ >= 100)
|
||||||
|
{
|
||||||
|
initDisplay();
|
||||||
|
counter = 0;
|
||||||
|
writeStateToEeprom();
|
||||||
|
}
|
||||||
|
|
||||||
|
vTaskDelay(pdMS_TO_TICKS(10));
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue