forked from vedderb/vesc_tool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vescinterface.h
executable file
·487 lines (416 loc) · 15.1 KB
/
vescinterface.h
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
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
/*
Copyright 2016 - 2020 Benjamin Vedder [email protected]
This file is part of VESC Tool.
VESC Tool is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
VESC Tool is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef VESCINTERFACE_H
#define VESCINTERFACE_H
#include <QObject>
#include <QDateTime>
#include <QTimer>
#include <QByteArray>
#include <QList>
#include <QVariantList>
#include <QTcpSocket>
#include <QUdpSocket>
#include <QSettings>
#include <QHash>
#include <QFile>
#ifdef HAS_SERIALPORT
#include <QSerialPort>
#endif
#ifdef HAS_CANBUS
#include <QCanBus>
#endif
#include "datatypes.h"
#include "configparams.h"
#include "commands.h"
#include "packet.h"
#include "tcpserversimple.h"
#include "udpserversimple.h"
#ifdef HAS_BLUETOOTH
#include "bleuart.h"
#else
#include "bleuartdummy.h"
#endif
#ifdef HAS_POS
#include <QGeoPositionInfoSource>
#endif
#ifdef Q_OS_ANDROID
#include <QtAndroid>
#include <QAndroidJniObject>
#include <QAndroidJniEnvironment>
#endif
class VescInterface : public QObject
{
Q_OBJECT
public:
explicit VescInterface(QObject *parent = nullptr);
~VescInterface();
Q_INVOKABLE Commands *commands() const;
Q_INVOKABLE ConfigParams *mcConfig();
Q_INVOKABLE ConfigParams *appConfig();
Q_INVOKABLE ConfigParams *infoConfig();
Q_INVOKABLE ConfigParams *fwConfig();
Q_INVOKABLE QStringList getSupportedFirmwares();
QList<QPair<int, int> > getSupportedFirmwarePairs();
Q_INVOKABLE QString getFirmwareNow();
QPair<int, int> getFirmwareNowPair();
Q_INVOKABLE void emitStatusMessage(const QString &msg, bool isGood);
Q_INVOKABLE void emitMessageDialog(const QString &title, const QString &msg, bool isGood, bool richText = false);
Q_INVOKABLE bool fwRx();
Q_INVOKABLE void storeSettings();
// Profiles
Q_INVOKABLE QVariantList getProfiles();
Q_INVOKABLE void addProfile(QVariant profile);
Q_INVOKABLE void clearProfiles();
Q_INVOKABLE void deleteProfile(int index);
Q_INVOKABLE void moveProfileUp(int index);
Q_INVOKABLE void moveProfileDown(int index);
Q_INVOKABLE MCCONF_TEMP getProfile(int index);
Q_INVOKABLE void updateProfile(int index, QVariant profile);
Q_INVOKABLE bool isProfileInUse(int index);
Q_INVOKABLE MCCONF_TEMP createMcconfTemp();
Q_INVOKABLE void updateMcconfFromProfile(MCCONF_TEMP profile);
// Pairing
Q_INVOKABLE QStringList getPairedUuids();
Q_INVOKABLE bool addPairedUuid(QString uuid);
Q_INVOKABLE bool deletePairedUuid(QString uuid);
Q_INVOKABLE void clearPairedUuids();
Q_INVOKABLE bool hasPairedUuid(QString uuid);
Q_INVOKABLE QString getConnectedUuid();
Q_INVOKABLE bool isIntroDone();
Q_INVOKABLE void setIntroDone(bool done);
Q_INVOKABLE QString getLastTcpServer() const;
Q_INVOKABLE int getLastTcpPort() const;
Q_INVOKABLE QString getLastUdpServer() const;
Q_INVOKABLE int getLastUdpPort() const;
#ifdef HAS_SERIALPORT
Q_INVOKABLE QString getLastSerialPort() const;
Q_INVOKABLE int getLastSerialBaud() const;
#endif
#ifdef HAS_CANBUS
Q_INVOKABLE QString getLastCANbusInterface() const;
Q_INVOKABLE int getLastCANbusBitrate() const;
#endif
// SWD Programming
bool swdEraseFlash();
bool swdUploadFw(QByteArray newFirmware, uint32_t startAddr = 0,
bool verify = false, bool isLzo = true);
void swdCancel();
bool swdReboot();
// Firmware Updates
bool fwEraseNewApp(bool fwdCan, quint32 fwSize);
bool fwEraseBootloader(bool fwdCan);
bool fwUpload(QByteArray &newFirmware, bool isBootloader = false, bool fwdCan = false, bool isLzo = true, bool autoDisconnect = true);
Q_INVOKABLE bool fwUpdate(QByteArray newFirmware) { return fwUpload(newFirmware, false, false, true, false); }
Q_INVOKABLE void fwUploadCancel();
Q_INVOKABLE double getFwUploadProgress();
Q_INVOKABLE QString getFwUploadStatus();
Q_INVOKABLE bool isCurrentFwBootloader();
// Logging
Q_INVOKABLE bool openRtLogFile(QString outDirectory);
Q_INVOKABLE void closeRtLogFile();
Q_INVOKABLE bool isRtLogOpen();
Q_INVOKABLE QString rtLogFilePath();
Q_INVOKABLE QVector<LOG_DATA> getRtLogData();
Q_INVOKABLE bool loadRtLogFile(QString file);
Q_INVOKABLE bool loadRtLogFile(QByteArray data);
Q_INVOKABLE LOG_DATA getRtLogSample(double progress);
Q_INVOKABLE LOG_DATA getRtLogSampleAtValTimeFromStart(int time);
// Persistent settings
Q_INVOKABLE bool useImperialUnits();
Q_INVOKABLE void setUseImperialUnits(bool useImperialUnits);
Q_INVOKABLE bool keepScreenOn();
Q_INVOKABLE void setKeepScreenOn(bool on);
Q_INVOKABLE bool useWakeLock();
Q_INVOKABLE void setUseWakeLock(bool on);
Q_INVOKABLE bool setWakeLock(bool lock);
Q_INVOKABLE bool getLoadQmlUiOnConnect() const;
Q_INVOKABLE void setLoadQmlUiOnConnect(bool loadQmlUiOnConnect);
Q_INVOKABLE bool getAllowScreenRotation() const;
Q_INVOKABLE void setAllowScreenRotation(bool allowScreenRotation);
Q_INVOKABLE bool speedGaugeUseNegativeValues();
Q_INVOKABLE void setSpeedGaugeUseNegativeValues(bool useNegativeValues);
Q_INVOKABLE bool askQmlLoad() const;
Q_INVOKABLE void setAskQmlLoad(bool newAskQmlLoad);
#ifdef HAS_BLUETOOTH
Q_INVOKABLE BleUart* bleDevice();
Q_INVOKABLE void storeBleName(QString address, QString name);
Q_INVOKABLE QString getBleName(QString address);
Q_INVOKABLE QString getLastBleAddr() const;
Q_INVOKABLE void storeBlePreferred(QString address, bool preferred);
Q_INVOKABLE bool getBlePreferred(QString address);
Q_INVOKABLE bool hasBluetooth() {return true;}
#else
Q_INVOKABLE BleUartDummy* bleDevice() {return mBleUart;}
Q_INVOKABLE bool hasBluetooth() {return false;}
#endif
// Connection
Q_INVOKABLE bool isPortConnected();
Q_INVOKABLE void disconnectPort();
Q_INVOKABLE bool reconnectLastPort();
Q_INVOKABLE bool lastPortAvailable();
Q_INVOKABLE bool autoconnect();
Q_INVOKABLE QString getConnectedPortName();
Q_INVOKABLE bool connectSerial(QString port, int baudrate);
bool connectSerial(QString port) {
return connectSerial(port, 115200);
}
Q_INVOKABLE QVariantList listSerialPorts();
QList<QString> listCANbusInterfaces();
Q_INVOKABLE bool connectCANbus(QString backend, QString ifName, int bitrate);
Q_INVOKABLE bool isCANbusConnected();
Q_INVOKABLE void setCANbusReceiverID(int node_ID);
Q_INVOKABLE void scanCANbus();
Q_INVOKABLE void connectTcp(QString server, int port);
Q_INVOKABLE void connectTcpHub(QString server, int port, QString id, QString pass);
Q_INVOKABLE void connectUdp(QString server, int port);
Q_INVOKABLE void connectBle(QString address);
Q_INVOKABLE bool isAutoconnectOngoing() const;
Q_INVOKABLE double getAutoconnectProgress() const;
Q_INVOKABLE QVector<int> scanCan();
Q_INVOKABLE QVector<int> getCanDevsLast() const;
Q_INVOKABLE void ignoreCanChange(bool ignore);
Q_INVOKABLE bool isIgnoringCanChanges();
Q_INVOKABLE void canTmpOverride(bool fwdCan, int canId);
Q_INVOKABLE void canTmpOverrideEnd();
Q_INVOKABLE bool tcpServerStart(int port);
Q_INVOKABLE void tcpServerStop();
Q_INVOKABLE bool tcpServerIsRunning();
Q_INVOKABLE bool tcpServerIsClientConnected();
Q_INVOKABLE QString tcpServerClientIp();
Q_INVOKABLE bool tcpServerConnectToHub(QString server, int port, QString id, QString pass);
Q_INVOKABLE bool udpServerStart(int port);
Q_INVOKABLE void udpServerStop();
Q_INVOKABLE bool udpServerIsRunning();
Q_INVOKABLE bool udpServerIsClientConnected();
Q_INVOKABLE QString udpServerClientIp();
Q_INVOKABLE void emitConfigurationChanged();
Q_INVOKABLE bool getFwSupportsConfiguration() const;
// Configuration backups
Q_INVOKABLE bool confStoreBackup(bool can, QString name = "");
Q_INVOKABLE bool confRestoreBackup(bool can);
Q_INVOKABLE bool confLoadBackup(QString uuid);
Q_INVOKABLE QStringList confListBackups();
Q_INVOKABLE void confClearBackups();
Q_INVOKABLE QString confBackupName(QString uuid);
Q_INVOKABLE bool deserializeFailedSinceConnected();
Q_INVOKABLE FW_RX_PARAMS getLastFwRxParams();
Q_INVOKABLE int customConfigNum();
Q_INVOKABLE bool customConfigsLoaded();
Q_INVOKABLE bool customConfigRxDone();
Q_INVOKABLE ConfigParams *customConfig(int configNum);
Q_INVOKABLE bool qmlHwLoaded();
Q_INVOKABLE bool qmlAppLoaded();
Q_INVOKABLE QString qmlHw();
Q_INVOKABLE QString qmlApp();
Q_INVOKABLE QString getLastTcpHubVescID() const;
Q_INVOKABLE QString getLastTcpHubVescPass() const;
Q_INVOKABLE QString getLastTcpHubServer() const;
Q_INVOKABLE int getLastTcpHubPort() const;
Q_INVOKABLE QVariantList getTcpHubDevs();
Q_INVOKABLE void clearTcpHubDevs();
Q_INVOKABLE bool updateTcpHubPassword(QString uuid, QString newPass);
Q_INVOKABLE bool connectTcpHubUuid(QString uuid);
// Force reloading of firmware version, custom UIs and custom configs
Q_INVOKABLE void reloadFirmware() {
updateFwRx(false);
}
Q_INVOKABLE bool downloadFwArchive();
bool ignoreCustomConfigs() const;
void setIgnoreCustomConfigs(bool newIgnoreCustomConfigs);
Q_INVOKABLE bool reconnectLastCan();
Q_INVOKABLE void setReconnectLastCan(bool set);
Q_INVOKABLE bool scanCanOnConnect();
Q_INVOKABLE void setScanCanOnConnect(bool set);
Q_INVOKABLE bool showFwUpdateAvailable() const;
Q_INVOKABLE void setShowFwUpdateAvailable(bool set);
signals:
void statusMessage(const QString &msg, bool isGood);
void messageDialog(const QString &title, const QString &msg, bool isGood, bool richText);
void fwUploadStatus(const QString &status, double progress, bool isOngoing);
void serialPortNotWritable(const QString &port);
void fwRxChanged(bool rx, bool limited);
void portConnectedChanged();
void autoConnectProgressUpdated(double progress, bool isOngoing);
void autoConnectFinished();
void profilesUpdated();
void pairingListUpdated();
void unintentionalBleDisconnect();
void CANbusNewNode(int node);
void CANbusInterfaceListUpdated();
void useImperialUnitsChanged(bool useImperialUnits);
void configurationChanged();
void configurationBackupsChanged();
void customConfigLoadDone();
void qmlLoadDone();
void fwArchiveDlProgress(QString msg, double prog);
public slots:
private slots:
#ifdef HAS_SERIALPORT
void serialDataAvailable();
void serialPortError(QSerialPort::SerialPortError error);
#endif
#ifdef HAS_CANBUS
void CANbusDataAvailable();
void CANbusError(QCanBusDevice::CanBusError error);
#endif
void tcpInputConnected();
void tcpInputDisconnected();
void tcpInputDataAvailable();
void tcpInputError(QAbstractSocket::SocketError socketError);
void udpInputError(QAbstractSocket::SocketError socketError);
void udpInputDataAvailable();
#ifdef HAS_BLUETOOTH
void bleDataRx(QByteArray data);
void bleUnintentionalDisconnect();
#endif
void timerSlot();
void packetDataToSend(QByteArray &data);
void packetReceived(QByteArray &data);
void cmdDataToSend(QByteArray &data);
void fwVersionReceived(FW_RX_PARAMS params);
void appconfUpdated();
void mcconfUpdated();
void ackReceived(QString ackType);
void customConfigRx(int confId, QByteArray data);
private:
typedef enum {
CONN_NONE = 0,
CONN_SERIAL,
CONN_CANBUS,
CONN_TCP,
CONN_BLE,
CONN_UDP,
CONN_TCP_HUB,
} conn_t;
QSettings mSettings;
QHash<QString, QString> mBleNames;
QHash<QString, bool> mBlePreferred;
QHash<QString, CONFIG_BACKUP> mConfigurationBackups;
QVariantList mProfiles;
QStringList mPairedUuids;
TcpServerSimple *mTcpServer;
UdpServerSimple *mUdpServer;
QTimer *mTimerBroadcast;
QTimer *mTimerConfigUpdate;
QVariantList mTcpHubDevs;
ConfigParams *mMcConfig;
ConfigParams *mAppConfig;
ConfigParams *mInfoConfig;
ConfigParams *mFwConfig;
QVector<ConfigParams*> mCustomConfigs;
bool mCustomConfigsLoaded;
bool mCustomConfigRxDone;
bool mQmlHwLoaded;
QString mQmlHw;
bool mQmlAppLoaded;
QString mQmlApp;
QTimer *mTimer;
Packet *mPacket;
Commands *mCommands;
bool mFwVersionReceived;
bool mDeserialFailedMessageShown;
int mFwRetries;
int mFwPollCnt;
QString mFwTxt;
QPair<int, int> mFwPair;
QString mHwTxt;
QString mUuidStr;
QString mUuidStrLocal;
bool mIsUploadingFw;
bool mIsLastFwBootloader;
bool mFwSupportsConfiguration;
// FW Upload
bool mCancelSwdUpload;
bool mCancelFwUpload;
double mFwUploadProgress;
QString mFwUploadStatus;
bool mFwIsBootloader;
// Connections
conn_t mLastConnType;
#ifdef HAS_SERIALPORT
QSerialPort *mSerialPort;
QString mLastSerialPort;
int mLastSerialBaud;
#endif
#ifdef HAS_CANBUS
QCanBusDevice *mCanDevice;
QString mLastCanDeviceInterface;
int mLastCanDeviceBitrate;
QString mLastCanBackend;
int mLastCanDeviceID;
QByteArray mCanRxBuffer;
QVector<int> mCanNodesID;
QList<QString> mCanDeviceInterfaces;
bool mCANbusScanning;
#endif
QTcpSocket *mTcpSocket;
bool mTcpConnected;
QString mLastTcpServer;
int mLastTcpPort;
QString mLastTcpHubServer;
int mLastTcpHubPort;
QString mLastTcpHubVescID;
QString mLastTcpHubVescPass;
QUdpSocket *mUdpSocket;
bool mUdpConnected;
QHostAddress mLastUdpServer;
int mLastUdpPort;
#ifdef HAS_BLUETOOTH
BleUart *mBleUart;
QString mLastBleAddr;
#else
BleUartDummy *mBleUart;
#endif
#ifdef HAS_POS
QGeoPositionInfoSource *mPosSource;
QGeoPositionInfo mLastPos;
QDateTime mLastPosTime;
#endif
#ifdef Q_OS_ANDROID
QAndroidJniObject mWakeLock;
#endif
bool mWakeLockActive;
QFile mRtLogFile;
QVector<LOG_DATA> mRtLogData;
IMU_VALUES mLastImuValues;
QDateTime mLastImuTime;
SETUP_VALUES mLastSetupValues;
QDateTime mLastSetupTime;
bool mSendCanBefore = false;
int mCanIdBefore = 0;
bool mWasConnected;
bool mAutoconnectOngoing;
double mAutoconnectProgress;
bool mIgnoreCanChange;
bool mCanTmpFwdActive;
bool mCanTmpFwdSendCanLast;
int mCanTmpFwdIdLast;
QVector<int> mCanDevsLast;
FW_RX_PARAMS mLastFwParams;
QMap<QString, QPair<QString, int> > mLastFwUuids;
bool mFwSwapDone;
// Other settings
bool mUseImperialUnits;
bool mKeepScreenOn;
bool mUseWakeLock;
bool mLoadQmlUiOnConnect;
bool mAllowScreenRotation;
bool mSpeedGaugeUseNegativeValues;
bool mAskQmlLoad;
bool mIgnoreCustomConfigs;
void updateFwRx(bool fwRx);
void setLastConnectionType(conn_t type);
};
#endif // VESCINTERFACE_H