/*===================================================================== QGroundControl Open Source Ground Control Station (c) 2009 - 2011 QGROUNDCONTROL PROJECT 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 . ======================================================================*/ /** * @file * @brief Brief Description * * @author Lorenz Meier * */ #ifndef SERIALLINK_H #define SERIALLINK_H #include #include #include #include #include #include #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 */ QList 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; QList m_ports; private: volatile bool m_stopp; volatile bool m_reqReset; QMutex m_stoppMutex; QMutex m_writeMutex; QByteArray m_transmitBuffer; bool hardwareConnect(); signals: void aboutToCloseFlag(); }; #endif // SERIALLINK_H