Trying to make less calls to dtu, making it "multithreaded"
This commit is contained in:
parent
9c3ed916b5
commit
ad4ff13be0
7 changed files with 37 additions and 32 deletions
|
|
@ -6,12 +6,11 @@
|
|||
|
||||
PortParameterMicroinverterSerialNumber::PortParameterMicroinverterSerialNumber() : PortParameterInt("microinverterSerialNumber", 0x0001, 6), PortParameter("microinverterSerialNumber", 0x0001, 6) {}
|
||||
|
||||
void PortParameterMicroinverterSerialNumber::setValueFromRegisters(uint16_t *readArray, int registerCount) {
|
||||
void PortParameterMicroinverterSerialNumber::setValueFromRegisters(uint16_t *readArray, int readArraySize) {
|
||||
uint16_t readValue;
|
||||
std::string readValueString = "";
|
||||
registerCount = std::ceil(registerCount/2);
|
||||
for (int i{0}; i < registerCount; i++) {
|
||||
readValue = readArray[i];
|
||||
for (int i{0}; i < std::ceil(this->registerSize/2) && (this->parameterAddressOffset + i) < readArraySize; i++) {
|
||||
readValue = readArray[this->parameterAddressOffset + i];
|
||||
std::stringstream readValueStringStream;
|
||||
readValueStringStream << std::hex << readValue;
|
||||
readValueString.append(readValueStringStream.str());
|
||||
|
|
@ -21,9 +20,9 @@ void PortParameterMicroinverterSerialNumber::setValueFromRegisters(uint16_t *rea
|
|||
|
||||
PortParameterPortNumber::PortParameterPortNumber() : PortParameterInt("portNumber", 0x0007, 1), PortParameter("portNumber", 0x0007, 1) {}
|
||||
|
||||
void PortParameterPortNumber::setValueFromRegisters(uint16_t *readArray, int registerCount) {
|
||||
if (registerCount > 0) {
|
||||
this->value.i = readArray[0];
|
||||
void PortParameterPortNumber::setValueFromRegisters(uint16_t *readArray, int readArraySize) {
|
||||
if(readArraySize > this->parameterAddressOffset) {
|
||||
this->value.i = readArray[this->parameterAddressOffset];
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -20,7 +20,7 @@ PortParameter::PortParameter(std::string name, uint16_t parameterAddressOffset,
|
|||
|
||||
PortParameter::~PortParameter() {}
|
||||
|
||||
void PortParameter::setValueFromRegisters(uint16_t *readArray, int registerCount) {}
|
||||
void PortParameter::setValueFromRegisters(uint16_t *readArray, int readArraySize) {}
|
||||
|
||||
std::pair<PortParameter::PortParameterValue, PortParameter::PortParameterValueType> PortParameter::getValue() {
|
||||
return std::pair<PortParameter::PortParameterValue, PortParameter::PortParameterValueType>(this->value, this->valueType);
|
||||
|
|
@ -28,14 +28,7 @@ std::pair<PortParameter::PortParameterValue, PortParameter::PortParameterValueTy
|
|||
|
||||
std::string PortParameter::getOutputValue() {}
|
||||
|
||||
void PortParameter::updateValue(std::shared_ptr<modbus_t*> modbus_context, std::mutex *modbus_context_mutex, uint16_t portStartAddress) {
|
||||
uint16_t readArray[this->registerSize];
|
||||
int registerCount;
|
||||
|
||||
modbus_context_mutex->lock();
|
||||
registerCount = modbus_read_registers(*modbus_context.get(), portStartAddress + this->parameterAddressOffset, this->registerSize, readArray);
|
||||
modbus_context_mutex->unlock();
|
||||
|
||||
void PortParameter::updateValue(uint16_t *readArray, int readArraySize, int registerCount) {
|
||||
if(registerCount == -1){
|
||||
this->age++;
|
||||
}
|
||||
|
|
@ -53,7 +46,7 @@ PortParameterFloat::PortParameterFloat(std::string name, int decimalPlaces, uint
|
|||
this->value.f = 0;
|
||||
}
|
||||
|
||||
void PortParameterFloat::setValueFromRegisters(uint16_t *readArray, int registerCount) {
|
||||
void PortParameterFloat::setValueFromRegisters(uint16_t *readArray, int readArraySize) {
|
||||
float temp = readArray[0];
|
||||
temp = temp / std::pow(10, this->decimalPlaces);
|
||||
this->value.f = temp;
|
||||
|
|
@ -69,12 +62,11 @@ PortParameterInt::PortParameterInt(std::string name, uint16_t parameterAddressOf
|
|||
this->value.i = 0;
|
||||
}
|
||||
|
||||
void PortParameterInt::setValueFromRegisters(uint16_t *readArray, int registerCount) {
|
||||
void PortParameterInt::setValueFromRegisters(uint16_t *readArray, int readArraySize) {
|
||||
uint16_t readValue;
|
||||
std::string readValueString = "";
|
||||
registerCount = std::ceil(registerCount/2);
|
||||
for (int i{0}; i < registerCount; i++) {
|
||||
readValue = readArray[i];
|
||||
for (int i{0}; i < std::ceil(this->registerSize/2) && (this->parameterAddressOffset + i) < readArraySize; i++) {
|
||||
readValue = readArray[this->parameterAddressOffset + i];
|
||||
readValueString.append(std::to_string(readValue));
|
||||
}
|
||||
this->value.i = std::stol(readValueString);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue