|
|
|
/*=====================================================================
|
|
|
|
|
|
|
|
QGroundControl Open Source Ground Control Station
|
|
|
|
|
|
|
|
(c) 2009 - 2011 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
|
|
|
|
|
|
|
|
This file is part of the QGROUNDCONTROL project
|
|
|
|
|
|
|
|
QGROUNDCONTROL 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.
|
|
|
|
|
|
|
|
QGROUNDCONTROL 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 QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
======================================================================*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @brief Brief Description
|
|
|
|
*
|
|
|
|
* @author Lorenz Meier <mavteam@student.ethz.ch>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SERIALLINK_H
|
|
|
|
#define SERIALLINK_H
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
#include <QThread>
|
|
|
|
#include <QMutex>
|
|
|
|
#include <QString>
|
|
|
|
#include <qserialport.h>
|
|
|
|
#include <configuration.h>
|
|
|
|
#include "SerialLinkInterface.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The SerialLink class provides cross-platform access to serial links.
|
|
|
|
* It takes care of the link management and provides a common API to higher
|
|
|
|
* level communication layers. It is implemented as a wrapper class for a thread
|
|
|
|
* that handles the serial communication. All methods have therefore to be thread-
|
|
|
|
* safe.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
class SerialLink : public SerialLinkInterface
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
//Q_INTERFACES(SerialLinkInterface:LinkInterface)
|
|
|
|
|
|
|
|
public:
|
|
|
|
SerialLink(QString portname = "",
|
|
|
|
int baudrate=57600,
|
|
|
|
bool flow=false,
|
|
|
|
bool parity=false,
|
|
|
|
int dataBits=8,
|
|
|
|
int stopBits=1);
|
|
|
|
~SerialLink();
|
|
|
|
|
|
|
|
static const int poll_interval = SERIAL_POLL_INTERVAL; ///< Polling interval, defined in configuration.h
|
|
|
|
|
|
|
|
/** @brief Get a list of the currently available ports */
|
|
|
|
QVector<QString>* getCurrentPorts();
|
|
|
|
|
|
|
|
void requestReset();
|
|
|
|
|
|
|
|
bool isConnected();
|
|
|
|
qint64 bytesAvailable();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The port handle
|
|
|
|
*/
|
|
|
|
QString getPortName();
|
|
|
|
/**
|
|
|
|
* @brief The human readable port name
|
|
|
|
*/
|
|
|
|
QString getName();
|
|
|
|
int getBaudRate();
|
|
|
|
int getDataBits();
|
|
|
|
int getStopBits();
|
|
|
|
|
|
|
|
// ENUM values
|
|
|
|
int getBaudRateType();
|
|
|
|
int getFlowType();
|
|
|
|
int getParityType();
|
|
|
|
int getDataBitsType();
|
|
|
|
int getStopBitsType();
|
|
|
|
|
|
|
|
/* Extensive statistics for scientific purposes */
|
|
|
|
qint64 getNominalDataRate();
|
|
|
|
qint64 getTotalUpstream();
|
|
|
|
qint64 getCurrentUpstream();
|
|
|
|
qint64 getMaxUpstream();
|
|
|
|
qint64 getTotalDownstream();
|
|
|
|
qint64 getCurrentDownstream();
|
|
|
|
qint64 getMaxDownstream();
|
|
|
|
qint64 getBitsSent();
|
|
|
|
qint64 getBitsReceived();
|
|
|
|
|
|
|
|
void loadSettings();
|
|
|
|
void writeSettings();
|
|
|
|
|
|
|
|
void run();
|
|
|
|
void run2();
|
|
|
|
|
|
|
|
int getLinkQuality();
|
|
|
|
bool isFullDuplex();
|
|
|
|
int getId();
|
|
|
|
|
|
|
|
signals: //[TODO] Refactor to Linkinterface
|
|
|
|
void updateLink(LinkInterface*);
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
bool setPortName(QString portName);
|
|
|
|
bool setBaudRate(int rate);
|
|
|
|
bool setDataBits(int dataBits);
|
|
|
|
bool setStopBits(int stopBits);
|
|
|
|
|
|
|
|
// Set string rate
|
|
|
|
bool setBaudRateString(const QString& rate);
|
|
|
|
|
|
|
|
// Set ENUM values
|
|
|
|
bool setBaudRateType(int rateIndex);
|
|
|
|
bool setFlowType(int flow);
|
|
|
|
bool setParityType(int parity);
|
|
|
|
bool setDataBitsType(int dataBits);
|
|
|
|
bool setStopBitsType(int stopBits);
|
|
|
|
|
|
|
|
void readBytes();
|
|
|
|
/**
|
|
|
|
* @brief Write a number of bytes to the interface.
|
|
|
|
*
|
|
|
|
* @param data Pointer to the data byte array
|
|
|
|
* @param size The size of the bytes array
|
|
|
|
**/
|
|
|
|
void writeBytes(const char* data, qint64 length);
|
|
|
|
bool connect();
|
|
|
|
bool disconnect();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
quint64 m_bytesRead;
|
|
|
|
QSerialPort* m_port;
|
|
|
|
int m_baud;
|
|
|
|
int m_dataBits;
|
|
|
|
int m_flowControl;
|
|
|
|
int m_stopBits;
|
|
|
|
int m_parity;
|
|
|
|
QString m_portName;
|
|
|
|
// QString m_name;
|
|
|
|
int m_timeout;
|
|
|
|
int m_id;
|
|
|
|
|
|
|
|
quint64 m_bitsSentTotal;
|
|
|
|
quint64 m_bitsSentShortTerm;
|
|
|
|
quint64 m_bitsSentCurrent;
|
|
|
|
quint64 m_bitsSentMax;
|
|
|
|
quint64 m_bitsReceivedTotal;
|
|
|
|
quint64 m_bitsReceivedShortTerm;
|
|
|
|
quint64 m_bitsReceivedCurrent;
|
|
|
|
quint64 m_bitsReceivedMax;
|
|
|
|
quint64 m_connectionStartTime;
|
|
|
|
QMutex m_statisticsMutex;
|
|
|
|
QMutex m_dataMutex;
|
|
|
|
QVector<QString>* m_ports;
|
|
|
|
|
|
|
|
private:
|
|
|
|
volatile bool m_stopp;
|
|
|
|
volatile bool m_reqReset;
|
|
|
|
QMutex m_stoppMutex;
|
|
|
|
|
|
|
|
bool hardwareConnect();
|
|
|
|
|
|
|
|
signals:
|
|
|
|
void aboutToCloseFlag();
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // SERIALLINK_H
|