2013-04-05 23:46:56 +03:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
*
|
|
|
|
* @file telemetry.h
|
|
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
|
|
* @addtogroup GCSPlugins GCS Plugins
|
|
|
|
* @{
|
|
|
|
* @addtogroup UAVTalkPlugin UAVTalk Plugin
|
|
|
|
* @{
|
|
|
|
* @brief The UAVTalk protocol plugin
|
|
|
|
*****************************************************************************/
|
|
|
|
/*
|
2013-05-19 17:37:30 +03:00
|
|
|
* This program 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
|
2013-04-05 23:46:56 +03:00
|
|
|
* (at your option) any later version.
|
2013-05-19 17:37:30 +03:00
|
|
|
*
|
|
|
|
* This program 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
|
2013-04-05 23:46:56 +03:00
|
|
|
* for more details.
|
2013-05-19 17:37:30 +03:00
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
2013-04-05 23:46:56 +03:00
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef TELEMETRY_H
|
|
|
|
#define TELEMETRY_H
|
|
|
|
|
|
|
|
#include "uavtalk.h"
|
|
|
|
#include "uavobjectmanager.h"
|
|
|
|
#include "gcstelemetrystats.h"
|
|
|
|
#include <QMutex>
|
|
|
|
#include <QMutexLocker>
|
|
|
|
#include <QTimer>
|
|
|
|
#include <QQueue>
|
|
|
|
#include <QMap>
|
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
class ObjectTransactionInfo : public QObject {
|
2013-04-05 23:46:56 +03:00
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2013-05-19 17:37:30 +03:00
|
|
|
ObjectTransactionInfo(QObject *parent);
|
2013-04-05 23:46:56 +03:00
|
|
|
~ObjectTransactionInfo();
|
2013-05-19 17:37:30 +03:00
|
|
|
UAVObject *obj;
|
2013-04-05 23:46:56 +03:00
|
|
|
bool allInstances;
|
|
|
|
bool objRequest;
|
|
|
|
qint32 retriesRemaining;
|
|
|
|
bool acked;
|
|
|
|
QPointer<class Telemetry>telem;
|
2013-05-19 17:37:30 +03:00
|
|
|
QTimer *timer;
|
2013-04-05 23:46:56 +03:00
|
|
|
private slots:
|
|
|
|
void timeout();
|
|
|
|
};
|
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
class Telemetry : public QObject {
|
2013-04-05 23:46:56 +03:00
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
typedef struct {
|
|
|
|
quint32 txBytes;
|
|
|
|
quint32 txObjectBytes;
|
|
|
|
quint32 txObjects;
|
|
|
|
quint32 txErrors;
|
|
|
|
quint32 txRetries;
|
2013-12-19 03:19:29 +01:00
|
|
|
|
|
|
|
quint32 rxBytes;
|
|
|
|
quint32 rxObjectBytes;
|
|
|
|
quint32 rxObjects;
|
|
|
|
quint32 rxErrors;
|
|
|
|
quint32 rxSyncErrors;
|
|
|
|
quint32 rxCrcErrors;
|
2013-04-05 23:46:56 +03:00
|
|
|
} TelemetryStats;
|
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
Telemetry(UAVTalk *utalk, UAVObjectManager *objMngr);
|
2013-04-05 23:46:56 +03:00
|
|
|
~Telemetry();
|
|
|
|
TelemetryStats getStats();
|
|
|
|
void resetStats();
|
|
|
|
void transactionTimeout(ObjectTransactionInfo *info);
|
|
|
|
|
|
|
|
signals:
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Constants
|
|
|
|
static const int REQ_TIMEOUT_MS = 250;
|
2013-05-19 17:37:30 +03:00
|
|
|
static const int MAX_RETRIES = 2;
|
2013-04-05 23:46:56 +03:00
|
|
|
static const int MAX_UPDATE_PERIOD_MS = 1000;
|
|
|
|
static const int MIN_UPDATE_PERIOD_MS = 1;
|
|
|
|
static const int MAX_QUEUE_SIZE = 20;
|
|
|
|
|
|
|
|
// Types
|
|
|
|
/**
|
|
|
|
* Events generated by objects
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2013-05-19 17:37:30 +03:00
|
|
|
EV_NONE = 0x00, /** No event */
|
|
|
|
EV_UNPACKED = 0x01, /** Object data updated by unpacking */
|
|
|
|
EV_UPDATED = 0x02, /** Object data updated by changing the data structure */
|
|
|
|
EV_UPDATED_MANUAL = 0x04, /** Object update event manually generated */
|
2013-12-01 19:25:44 +01:00
|
|
|
EV_UPDATED_PERIODIC = 0x08, /** Object update event generated by timer */
|
|
|
|
EV_UPDATE_REQ = 0x10 /** Request to update object data */
|
2013-04-05 23:46:56 +03:00
|
|
|
} EventMask;
|
|
|
|
|
|
|
|
typedef struct {
|
2013-05-19 17:37:30 +03:00
|
|
|
UAVObject *obj;
|
|
|
|
qint32 updatePeriodMs; /** Update period in ms or 0 if no periodic updates are needed */
|
|
|
|
qint32 timeToNextUpdateMs; /** Time delay to the next update */
|
2013-04-05 23:46:56 +03:00
|
|
|
} ObjectTimeInfo;
|
|
|
|
|
|
|
|
typedef struct {
|
2013-05-19 17:37:30 +03:00
|
|
|
UAVObject *obj;
|
2013-04-05 23:46:56 +03:00
|
|
|
EventMask event;
|
|
|
|
bool allInstances;
|
|
|
|
} ObjectQueueInfo;
|
|
|
|
|
|
|
|
// Variables
|
2013-05-19 17:37:30 +03:00
|
|
|
UAVObjectManager *objMngr;
|
|
|
|
UAVTalk *utalk;
|
|
|
|
GCSTelemetryStats *gcsStatsObj;
|
2013-04-05 23:46:56 +03:00
|
|
|
QList<ObjectTimeInfo> objList;
|
|
|
|
QQueue<ObjectQueueInfo> objQueue;
|
|
|
|
QQueue<ObjectQueueInfo> objPriorityQueue;
|
2013-11-26 01:27:25 +01:00
|
|
|
QMap<quint32, QMap<quint32, ObjectTransactionInfo *> *> transMap;
|
2013-05-19 17:37:30 +03:00
|
|
|
QMutex *mutex;
|
|
|
|
QTimer *updateTimer;
|
|
|
|
QTimer *statsTimer;
|
2013-04-05 23:46:56 +03:00
|
|
|
qint32 timeToNextUpdateMs;
|
|
|
|
quint32 txErrors;
|
|
|
|
quint32 txRetries;
|
|
|
|
|
|
|
|
// Methods
|
2013-05-19 17:37:30 +03:00
|
|
|
void registerObject(UAVObject *obj);
|
|
|
|
void addObject(UAVObject *obj);
|
|
|
|
void setUpdatePeriod(UAVObject *obj, qint32 periodMs);
|
|
|
|
void connectToObjectInstances(UAVObject *obj, quint32 eventMask);
|
2013-12-01 19:25:44 +01:00
|
|
|
void connectToObject(UAVObject *obj, quint32 eventMask);
|
2013-05-19 17:37:30 +03:00
|
|
|
void updateObject(UAVObject *obj, quint32 eventMask);
|
|
|
|
void processObjectUpdates(UAVObject *obj, EventMask event, bool allInstances, bool priority);
|
2013-04-05 23:46:56 +03:00
|
|
|
void processObjectTransaction(ObjectTransactionInfo *transInfo);
|
|
|
|
void processObjectQueue();
|
|
|
|
|
2013-11-26 01:27:25 +01:00
|
|
|
ObjectTransactionInfo *findTransaction(UAVObject *obj);
|
2013-12-01 19:25:44 +01:00
|
|
|
void openTransaction(ObjectTransactionInfo *trans);
|
2013-11-26 01:27:25 +01:00
|
|
|
void closeTransaction(ObjectTransactionInfo *trans);
|
|
|
|
void closeAllTransactions();
|
|
|
|
|
2013-04-05 23:46:56 +03:00
|
|
|
private slots:
|
2013-05-19 17:37:30 +03:00
|
|
|
void objectUpdatedAuto(UAVObject *obj);
|
2013-12-01 19:25:44 +01:00
|
|
|
void objectUpdatedManual(UAVObject *obj, bool all = false);
|
2013-05-19 17:37:30 +03:00
|
|
|
void objectUpdatedPeriodic(UAVObject *obj);
|
|
|
|
void objectUnpacked(UAVObject *obj);
|
2013-12-01 19:25:44 +01:00
|
|
|
void updateRequested(UAVObject *obj, bool all = false);
|
2013-05-19 17:37:30 +03:00
|
|
|
void newObject(UAVObject *obj);
|
|
|
|
void newInstance(UAVObject *obj);
|
2013-04-05 23:46:56 +03:00
|
|
|
void processPeriodicUpdates();
|
2013-05-19 17:37:30 +03:00
|
|
|
void transactionCompleted(UAVObject *obj, bool success);
|
2013-04-05 23:46:56 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // TELEMETRY_H
|