Removed multithtreading (thanks windows)
This commit is contained in:
parent
e0135b6753
commit
d62fda675a
8 changed files with 23 additions and 24 deletions
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
|
||||||
|
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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();
|
||||||
|
|
|
||||||
|
|
@ -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++;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue