Merge branch 'feature/buffer-configuration' into develop

This commit is contained in:
Maxwell
2020-03-10 10:09:59 +02:00
4 changed files with 34 additions and 10 deletions
+17 -2
View File
@@ -18,10 +18,25 @@ run_interval=120
# reading compared to measurement tools. Normally this will remain '1'
amperage_factor=1.0
# This allos you to modify the wattage in case the inverter is giving an incorrect
# This allows you to modify the wattage in case the inverter is giving an incorrect
# reading compared to measurement tools. Normally this will remain '1'
watt_factor=1.01
# The following settings allow you to modify runtime buffers.
# N.B. These values may not be applicable to all inverter types, as such you will
# need to run docker exec -it voltronic-mqtt bash -c '/opt/inverter-cli/bin/inverter_poller -d -1'
# or simply inverter_poller -d -1 to check for warnings or errors
# mentioned in https://github.com/ned-kelly/docker-voltronic-homeassistant/issues/5
# This allows you to modify the buffersize for the qpiri command
# as mentioned in https://github.com/ned-kelly/docker-voltronic-homeassistant/issues/5
qpiri=97
# This allows you to modify the buffersize for the qpiws command
qpiws=36
# This allows you to modify the buffersize for the qmod command
qmod=5
# This allows you to modify the buffersize for the qpigs command
qpigs=110
+8 -5
View File
@@ -9,13 +9,16 @@
#include <fcntl.h>
#include <termios.h>
cInverter::cInverter(std::string devicename, int qpiri) {
cInverter::cInverter(std::string devicename, int qpiri, int qpiws, int qmod, int qpigs) {
device = devicename;
status1[0] = 0;
status2[0] = 0;
warnings[0] = 0;
mode = 0;
qpiri = qpiri;
qpiws = qpiws;
qmod = qmod;
qpigs = qpigs;
}
string *cInverter::GetQpigsStatus() {
@@ -154,13 +157,13 @@ bool cInverter::query(const char *cmd, int replysize) {
void cInverter::poll() {
int n,j;
extern const int qpiri;
extern const int qpiri, qpiws, qmod, qpigs;
while (true) {
// Reading mode
if (!ups_qmod_changed) {
if (query("QMOD", 5)) {
if (query("QMOD", qmod)) {
SetMode(buf[1]);
ups_qmod_changed = true;
}
@@ -168,7 +171,7 @@ void cInverter::poll() {
// reading status (QPIGS)
if (!ups_qpigs_changed) {
if (query("QPIGS", 110)) {
if (query("QPIGS", qpigs)) {
m.lock();
strcpy(status1, (const char*)buf+1);
m.unlock();
@@ -188,7 +191,7 @@ void cInverter::poll() {
// Get any device warnings...
if (!ups_qpiws_changed) {
if (query("QPIWS", 36)) {
if (query("QPIWS", qpiws)) {
m.lock();
strcpy(warnings, (const char*)buf+1);
m.unlock();
+1 -1
View File
@@ -23,7 +23,7 @@ class cInverter {
uint16_t cal_crc_half(uint8_t *pin, uint8_t len);
public:
cInverter(std::string devicename, int qpiri);
cInverter(std::string devicename, int qpiri, int qpiws, int qmod, int qpigs);
void poll();
void runMultiThread() {
std::thread t1(&cInverter::poll, this);
+8 -2
View File
@@ -43,7 +43,7 @@ string devicename;
int runinterval;
float ampfactor;
float wattfactor;
int qpiri;
int qpiri, qpiws, qmod, qpigs;
// ---------------------------------------
@@ -93,6 +93,12 @@ void getSettingsFile(string filename) {
attemptAddSetting(&wattfactor, linepart2);
else if(linepart1 == "qpiri")
attemptAddSetting(&qpiri, linepart2);
else if(linepart1 == "qpiws")
attemptAddSetting(&qpiws, linepart2);
else if(linepart1 == "qmod")
attemptAddSetting(&qmod, linepart2);
else if(linepart1 == "qpigs")
attemptAddSetting(&qpigs, linepart2);
else
continue;
}
@@ -174,7 +180,7 @@ int main(int argc, char* argv[]) {
}
bool ups_status_changed(false);
ups = new cInverter(devicename,qpiri);
ups = new cInverter(devicename,qpiri,qpiws,qmod,qpigs);
// Logic to send 'raw commands' to the inverter..
if (!rawcmd.empty()) {