Removed multithtreading (thanks windows)

This commit is contained in:
TraYali 2024-03-19 13:02:41 +01:00
parent e0135b6753
commit d62fda675a
8 changed files with 23 additions and 24 deletions

View file

@ -3,7 +3,7 @@
#include <vector> #include <vector>
#include <memory> #include <memory>
#include <mutex> // #include <mutex>
#include "microinverter.h" #include "microinverter.h"
@ -13,7 +13,7 @@ typedef _modbus modbus_t;
class Dtu { class Dtu {
private: private:
std::shared_ptr<modbus_t*> modbus_context; std::shared_ptr<modbus_t*> modbus_context;
std::mutex modbus_context_mutex; // std::mutex modbus_context_mutex;
std::vector<Microinverter> microinverters; std::vector<Microinverter> microinverters;

View file

@ -3,7 +3,7 @@
#include <vector> #include <vector>
#include <memory> #include <memory>
#include <mutex> // #include <mutex>
#include "port.h" #include "port.h"
@ -13,12 +13,12 @@ typedef _modbus modbus_t;
class Microinverter { class Microinverter {
private: private:
std::shared_ptr<modbus_t*> modbus_context; std::shared_ptr<modbus_t*> modbus_context;
std::mutex *modbus_context_mutex; // std::mutex *modbus_context_mutex;
public: public:
Microinverter(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, long serialNumber); Microinverter(std::shared_ptr<modbus_t*> modbus_context, long serialNumber);
long serialNumber; long serialNumber;

View file

@ -5,7 +5,7 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include <memory> #include <memory>
#include <mutex> // #include <mutex>
#include "portParametersGeneric.h" #include "portParametersGeneric.h"
@ -15,7 +15,7 @@ typedef _modbus modbus_t;
class Port { class Port {
private: private:
std::shared_ptr<modbus_t*> modbus_context; std::shared_ptr<modbus_t*> modbus_context;
std::mutex *modbus_context_mutex; // std::mutex *modbus_context_mutex;
uint16_t portStartAddress; uint16_t portStartAddress;
@ -25,7 +25,7 @@ class Port {
bool currentFixed; bool currentFixed;
public: public:
Port(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, uint16_t portStartAddress); Port(std::shared_ptr<modbus_t*> modbus_context, uint16_t portStartAddress);
std::vector<std::shared_ptr<PortParameter>> parameters; std::vector<std::shared_ptr<PortParameter>> parameters;

View file

@ -4,7 +4,7 @@
#include <stdint.h> #include <stdint.h>
#include <string> #include <string>
#include <memory> #include <memory>
#include <mutex> // #include <mutex>
struct _modbus; struct _modbus;
typedef _modbus modbus_t; typedef _modbus modbus_t;
@ -40,7 +40,7 @@ class PortParameter {
virtual std::string getOutputValue(); virtual std::string getOutputValue();
void updateValue(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, uint16_t portStartAddress); void updateValue(std::shared_ptr<modbus_t*> modbus_context, uint16_t portStartAddress);
}; };
class PortParameterFloat : virtual public PortParameter { class PortParameterFloat : virtual public PortParameter {

View file

@ -17,7 +17,6 @@ Dtu::Dtu(const char *ip_address, int port) {
if (modbus_connect(*this->modbus_context.get()) == -1) { if (modbus_connect(*this->modbus_context.get()) == -1) {
std::cerr << "conn_error"; std::cerr << "conn_error";
modbus_free(*this->modbus_context.get());
this->connected = false; this->connected = false;
} }
else { else {
@ -45,10 +44,10 @@ void Dtu::populateMicroinverters() {
int registerCount; int registerCount;
registerCount = modbus_read_registers(*this->modbus_context.get(), portStartAddress + 0x0021, 1, readArray); registerCount = modbus_read_registers(*this->modbus_context.get(), portStartAddress + 0x0021, 1, readArray);
while(registerCount != -1 && readArray[0] == 0x700) { while(registerCount != -1 && readArray[0] == 0x700) {
Port port{ this->modbus_context, &this->modbus_context_mutex, portStartAddress }; Port port{ this->modbus_context, portStartAddress };
PortParameterMicroinverterSerialNumber portParameterMicroinverterSerialNumber{}; PortParameterMicroinverterSerialNumber portParameterMicroinverterSerialNumber{};
portParameterMicroinverterSerialNumber.updateValue(this->modbus_context, &this->modbus_context_mutex, portStartAddress); portParameterMicroinverterSerialNumber.updateValue(this->modbus_context, portStartAddress);
long serialNumber = portParameterMicroinverterSerialNumber.getValue().first.i; long serialNumber = portParameterMicroinverterSerialNumber.getValue().first.i;
std::pair<bool, Microinverter*> getMicroinverterBySerialNumber = this->getMicroinverterBySerialNumber(serialNumber); std::pair<bool, Microinverter*> getMicroinverterBySerialNumber = this->getMicroinverterBySerialNumber(serialNumber);
@ -56,16 +55,16 @@ void Dtu::populateMicroinverters() {
getMicroinverterBySerialNumber.second->ports.push_back(port); getMicroinverterBySerialNumber.second->ports.push_back(port);
} }
else { else {
Microinverter microinverter{ this->modbus_context, &this->modbus_context_mutex, serialNumber }; Microinverter microinverter{ this->modbus_context, serialNumber };
this->microinverters.push_back(microinverter); this->microinverters.push_back(microinverter);
this->microinverters.back().ports.push_back(port); this->microinverters.back().ports.push_back(port);
} }
portStartAddress += 0x0028; portStartAddress += 0x0028;
this->modbus_context_mutex.lock(); // this->modbus_context_mutex.lock();
registerCount = modbus_read_registers(*this->modbus_context.get(), portStartAddress + 0x0021, 1, readArray); registerCount = modbus_read_registers(*this->modbus_context.get(), portStartAddress + 0x0021, 1, readArray);
this->modbus_context_mutex.unlock(); // this->modbus_context_mutex.unlock();
} }
} }

View file

@ -10,9 +10,9 @@
struct _modbus; struct _modbus;
typedef _modbus modbus_t; typedef _modbus modbus_t;
Microinverter::Microinverter(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, long serialNumber) { Microinverter::Microinverter(std::shared_ptr<modbus_t*> modbus_context, long serialNumber) {
this->modbus_context = modbus_context; this->modbus_context = modbus_context;
this->modbus_context_mutex = modbus_context_mutex; // this->modbus_context_mutex = modbus_context_mutex;
this->serialNumber = serialNumber; this->serialNumber = serialNumber;
} }

View file

@ -9,9 +9,9 @@
#include "port.h" #include "port.h"
#include "portParameters.h" #include "portParameters.h"
Port::Port(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, uint16_t portStartAddress) { Port::Port(std::shared_ptr<modbus_t*> modbus_context, uint16_t portStartAddress) {
this->modbus_context = modbus_context; this->modbus_context = modbus_context;
this->modbus_context_mutex = modbus_context_mutex; // this->modbus_context_mutex = modbus_context_mutex;
this->portStartAddress = portStartAddress; this->portStartAddress = portStartAddress;
@ -71,7 +71,7 @@ void Port::fixCurrent() {
void Port::updateParameters() { void Port::updateParameters() {
std::vector<std::shared_ptr<PortParameter>>::iterator parametersIterator{this->parameters.begin()}; std::vector<std::shared_ptr<PortParameter>>::iterator parametersIterator{this->parameters.begin()};
while (parametersIterator != this->parameters.end()) { while (parametersIterator != this->parameters.end()) {
parametersIterator->get()->updateValue(this->modbus_context, this->modbus_context_mutex, this->portStartAddress); parametersIterator->get()->updateValue(this->modbus_context, this->portStartAddress);
parametersIterator++; parametersIterator++;
} }
this->fixCurrent(); this->fixCurrent();

View file

@ -30,13 +30,13 @@ std::pair<PortParameter::PortParameterValue, PortParameter::PortParameterValueTy
std::string PortParameter::getOutputValue() {} std::string PortParameter::getOutputValue() {}
void PortParameter::updateValue(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, uint16_t portStartAddress) { void PortParameter::updateValue(std::shared_ptr<modbus_t*> modbus_context, uint16_t portStartAddress) {
uint16_t readArray[this->registerSize]; uint16_t readArray[this->registerSize];
int registerCount; int registerCount;
modbus_context_mutex->lock(); // modbus_context_mutex->lock();
registerCount = modbus_read_registers(*modbus_context.get(), portStartAddress + this->parameterAddressOffset, this->registerSize, readArray); registerCount = modbus_read_registers(*modbus_context.get(), portStartAddress + this->parameterAddressOffset, this->registerSize, readArray);
modbus_context_mutex->unlock(); // modbus_context_mutex->unlock();
if(registerCount == -1){ if(registerCount == -1){
this->age++; this->age++;