hvc.c
2.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#include <stdio.h>
#include <stdlib.h>
#include <termios.h>
#include <unistd.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <strings.h>
#include <inttypes.h>
#include <time.h>
#include "ui.h"
#include "hvc.h"
#include "printx.h"
#include "serial.h"
#define DEVICE1 "/dev/ttyACM1"
#define SPEED B19200
#define HVC_POLLING_TIME 50000
#define WAIT_BEFORE_RETRY 5000
#define GET_DEVICE_MODEL 'A'
#define DEVICE_MODEL_HVC 'C'
#define GET_TEMP 'H'
#define SET_HEAT_ON 'E'
#define SET_HEAT_OFF 'G'
#define SET_PUMP_ON 'B'
#define SET_PUMP_OFF 'D'
// Globals
int hvc_fd = -1;
bool hvcStop = false;
bool sPump = false;
bool sHeat = false;
struct termios hvcSaveterm;
bool wHeat = false;
bool wPump = false;
time_t tHeatStart;
time_t tHeatStop;
double tHeatTimer;
time_t tPumpStart;
double tPumpTimer;
time_t tPumpStop;
void stopHVC()
{
hvcStop = true;
}
void setPumpWantedState(bool s)
{
tPumpStart = clock();
tPumpStop = clock();
wPump = s;
}
void setHeatWantedState(bool s)
{
tHeatStart = clock();
tHeatStop = clock();
wHeat = s;
}
void setPumpTimer(double t)
{
tPumpTimer = t;
}
void setHeatTimer(double t)
{
tHeatTimer = t;
}
bool initHVC()
{
unsigned char data;
printx(DEBUG, HVC, "Connecting to interface 1\n");
if(init_serial(DEVICE1, SPEED, &hvc_fd, &hvcSaveterm))
{
printx(DEBUG, HVC, "Connected to an interface\n");
sendData(&hvc_fd, GET_DEVICE_MODEL);
printx(DEBUG, HVC, "Sended identification request %02x\n", GET_DEVICE_MODEL);
data = getData(&hvc_fd);
if(data == DEVICE_MODEL_HVC)
printx(INFO, HVC, "HVC Arduino connected\n");
else
printx(DEBUG, HVC, "HVC Arduino not found, response was %02x\n", data);
}
else
{
printx(WARNING, HVC, "Unable to connect to such interface\n");
return false;
}
return true;
}
void* processHVC(void* we)
{
uint8_t data;
while(!hvcStop)
{
printx(DEBUG, HVC, "Querying data\n");
sendData(&hvc_fd, GET_TEMP);
data = getData(&hvc_fd);
setTemp(data);
printx(DEBUG, HVC, "TEMP %d\n", data);
if(tHeatTimer > 0)
{
tHeatStop = clock();
if(((double)(tHeatStop - tHeatStart) / CLOCKS_PER_SEC) > tHeatTimer)
{
wHeat = false;
tHeatTimer = 0;
printx(INFO, HVC, "Shutting down HEAT according to timer\n");
}
}
if(tPumpTimer > 0)
{
tPumpStop = clock();
if(((double)(tPumpStop - tPumpStart) / CLOCKS_PER_SEC) > tPumpTimer)
{
wPump = false;
tPumpTimer = 0;
printx(INFO, HVC, "Shutting down PUMP according to timer\n");
}
}
if(wHeat ^ sHeat)
{
sendData(&hvc_fd, wHeat ? SET_HEAT_ON : SET_HEAT_OFF);
sHeat = wHeat;
setHeat(sHeat);
if(sHeat)
tHeatStart = clock();
}
if(wPump ^ sPump)
{
sendData(&hvc_fd, wPump ? SET_PUMP_ON : SET_PUMP_OFF);
sPump = wPump;
setPump(sPump);
if(sPump)
tPumpStart = clock();
}
usleep(HVC_POLLING_TIME);
}
return NULL;
}