mirror of https://github.com/lumapu/ahoy.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
3.7 KiB
108 lines
3.7 KiB
//-----------------------------------------------------------------------------
|
|
// 2022 Ahoy, https://www.mikrocontroller.net/topic/525778
|
|
// Creative Commons - http://creativecommons.org/licenses/by-nc-sa/3.0/de/
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#ifndef __HM_SYSTEM_H__
|
|
#define __HM_SYSTEM_H__
|
|
|
|
#include "hmInverter.h"
|
|
#ifndef NO_RADIO
|
|
#include "hmRadio.h"
|
|
#endif
|
|
|
|
|
|
template <class RADIO, class BUFFER, uint8_t MAX_INVERTER=3, class INVERTERTYPE=Inverter<float>>
|
|
class HmSystem {
|
|
public:
|
|
typedef RADIO RadioType;
|
|
RadioType Radio;
|
|
typedef BUFFER BufferType;
|
|
BufferType BufCtrl;
|
|
//DevControlCmdType DevControlCmd;
|
|
|
|
HmSystem() {
|
|
mNumInv = 0;
|
|
}
|
|
~HmSystem() {
|
|
// TODO: cleanup
|
|
}
|
|
|
|
void setup(config_t *config) {
|
|
DPRINTLN(DBG_VERBOSE, F("hmSystem.h:setup"));
|
|
Radio.setup(config, &BufCtrl);
|
|
}
|
|
|
|
INVERTERTYPE *addInverter(const char *name, uint64_t serial, uint16_t chMaxPwr[]) {
|
|
DPRINTLN(DBG_VERBOSE, F("hmSystem.h:addInverter"));
|
|
if(MAX_INVERTER <= mNumInv) {
|
|
DPRINT(DBG_WARN, F("max number of inverters reached!"));
|
|
return NULL;
|
|
}
|
|
INVERTERTYPE *p = &mInverter[mNumInv];
|
|
p->id = mNumInv;
|
|
p->serial.u64 = serial;
|
|
memcpy(p->chMaxPwr, chMaxPwr, (4*2));
|
|
DPRINT(DBG_VERBOSE, "SERIAL: " + String(p->serial.b[5], HEX));
|
|
DPRINTLN(DBG_VERBOSE, " " + String(p->serial.b[4], HEX));
|
|
if(p->serial.b[5] == 0x11) {
|
|
switch(p->serial.b[4]) {
|
|
case 0x21: p->type = INV_TYPE_1CH; break;
|
|
case 0x41: p->type = INV_TYPE_2CH; break;
|
|
case 0x61: p->type = INV_TYPE_4CH; break;
|
|
default:
|
|
DPRINT(DBG_ERROR, F("unknown inverter type: 11"));
|
|
DPRINTLN(DBG_ERROR, String(p->serial.b[4], HEX));
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
DPRINTLN(DBG_ERROR, F("inverter type can't be detected!"));
|
|
|
|
p->init();
|
|
uint8_t len = (uint8_t)strlen(name);
|
|
strncpy(p->name, name, (len > MAX_NAME_LENGTH) ? MAX_NAME_LENGTH : len);
|
|
|
|
if(NULL == p->assign) {
|
|
DPRINT(DBG_ERROR, F("no assignment for type found!"));
|
|
return NULL;
|
|
}
|
|
else {
|
|
mNumInv ++;
|
|
return p;
|
|
}
|
|
}
|
|
|
|
INVERTERTYPE *findInverter(uint8_t buf[]) {
|
|
DPRINTLN(DBG_VERBOSE, F("hmSystem.h:findInverter"));
|
|
INVERTERTYPE *p;
|
|
for(uint8_t i = 0; i < mNumInv; i++) {
|
|
p = &mInverter[i];
|
|
if((p->serial.b[3] == buf[0])
|
|
&& (p->serial.b[2] == buf[1])
|
|
&& (p->serial.b[1] == buf[2])
|
|
&& (p->serial.b[0] == buf[3]))
|
|
return p;
|
|
}
|
|
return NULL;
|
|
}
|
|
|
|
INVERTERTYPE *getInverterByPos(uint8_t pos, bool check = true) {
|
|
DPRINTLN(DBG_VERBOSE, F("hmSystem.h:getInverterByPos"));
|
|
if((mInverter[pos].initialized && mInverter[pos].serial.u64 != 0ULL) || false == check)
|
|
return &mInverter[pos];
|
|
else
|
|
return NULL;
|
|
}
|
|
|
|
uint8_t getNumInverters(void) {
|
|
DPRINTLN(DBG_VERBOSE, F("hmSystem.h:getNumInverters"));
|
|
return mNumInv;
|
|
}
|
|
|
|
private:
|
|
INVERTERTYPE mInverter[MAX_INVERTER];
|
|
uint8_t mNumInv;
|
|
};
|
|
|
|
#endif /*__HM_SYSTEM_H__*/
|
|
|