#ifndef __HM_SYSTEM_H__ #define __HM_SYSTEM_H__ #include "hmInverters.h" #include "hmRadio.h" template class HmSystem { public: typedef RADIO RadioType; RadioType Radio; typedef BUFFER BufferType; BufferType BufCtrl; HmSystem() { mNumInv = 0; } ~HmSystem() { // TODO: cleanup } void setup() { Radio.setup(&BufCtrl); } inverter_t *addInverter(const char *name, uint64_t serial, uint8_t type) { if(MAX_INVERTER <= mNumInv) { DPRINT("max number of inverters reached!"); return NULL; } inverter_t *p = &mInverter[mNumInv]; p->id = mNumInv; p->serial.u64 = serial; p->type = type; uint8_t len = strlen(name); strncpy(p->name, name, (len > MAX_NAME_LENGTH) ? MAX_NAME_LENGTH : len); getAssignment(p); toRadioId(p); if(NULL == p->assign) { DPRINT("no assignment for type found!"); return NULL; } else { mRecord[p->id] = new RECORDTYPE[p->listLen]; memset(mRecord[p->id], 0, sizeof(RECORDTYPE) * p->listLen); mNumInv ++; return p; } } inverter_t *findInverter(uint8_t buf[]) { inverter_t *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; } inverter_t *getInverterByPos(uint8_t pos) { if(mInverter[pos].serial.u64 != 0ULL) return &mInverter[pos]; else return NULL; } const char *getFieldName(inverter_t *p, uint8_t pos) { return fields[p->assign[pos].fieldId]; } const char *getUnit(inverter_t *p, uint8_t pos) { return units[p->assign[pos].unitId]; } uint64_t getSerial(inverter_t *p) { return p->serial.u64; } void updateSerial(inverter_t *p, uint64_t serial) { p->serial.u64 = serial; } uint8_t getChannel(inverter_t *p, uint8_t pos) { return p->assign[pos].ch; } uint8_t getCmdId(inverter_t *p, uint8_t pos) { return p->assign[pos].cmdId; } void addValue(inverter_t *p, uint8_t pos, uint8_t buf[]) { uint8_t ptr = p->assign[pos].start; uint8_t end = ptr + p->assign[pos].num; uint16_t div = p->assign[pos].div; uint32_t val = 0; do { val <<= 8; val |= buf[ptr]; } while(++ptr != end); mRecord[p->id][pos] = (RECORDTYPE)(val) / (RECORDTYPE)(div); } RECORDTYPE getValue(inverter_t *p, uint8_t pos) { return mRecord[p->id][pos]; } uint8_t getPosByChField(inverter_t *p, uint8_t channel, uint8_t fieldId) { uint8_t pos = 0; for(; pos < p->listLen; pos++) { if((p->assign[pos].ch == channel) && (p->assign[pos].fieldId == fieldId)) break; } return (pos >= p->listLen) ? 0xff : pos; } uint8_t getNumInverters(void) { return mNumInv; } private: void toRadioId(inverter_t *p) { p->radioId.u64 = 0ULL; p->radioId.b[4] = p->serial.b[0]; p->radioId.b[3] = p->serial.b[1]; p->radioId.b[2] = p->serial.b[2]; p->radioId.b[1] = p->serial.b[3]; p->radioId.b[0] = 0x01; } void getAssignment(inverter_t *p) { if(INV_TYPE_HM600 == p->type) { p->listLen = (uint8_t)(HM1200_LIST_LEN); p->assign = (byteAssign_t*)hm600assignment; } else if(INV_TYPE_HM1200 == p->type) { p->listLen = (uint8_t)(HM1200_LIST_LEN); p->assign = (byteAssign_t*)hm1200assignment; } else { p->listLen = 0; p->assign = NULL; } } inverter_t mInverter[MAX_INVERTER]; uint8_t mNumInv; RECORDTYPE *mRecord[MAX_INVERTER]; }; #endif /*__HM_SYSTEM_H__*/