/** * Digital Voice Modem - DSP Firmware (Hotspot) * GPLv2 Open Source. Use is subject to license terms. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * @package DVM / DSP Firmware (Hotspot) * */ // // Based on code from the MMDVM_HS project. (https://github.com/juribeparada/MMDVM_HS) // Licensed under the GPLv2 License (https://opensource.org/licenses/GPL-2.0) // /* * Copyright (C) 2015,2016,2017 by Jonathan Naylor G4KLX * Copyright (C) 2016 by Colin Durbridge G4EML * Copyright (C) 2017 by Andy Uribe CA6JAU * * 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 2 of the License, or * (at your option) any later version. * * 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 for more details. * * 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., 675 Mass Ave, Cambridge, MA 02139, USA. */ #if !defined(__DMR_TX_H__) #define __DMR_TX_H__ #include "Defines.h" #include "dmr/DMRDefines.h" #include "SerialBuffer.h" namespace dmr { // --------------------------------------------------------------------------- // Constants // --------------------------------------------------------------------------- enum DMRTXSTATE { DMRTXSTATE_IDLE, DMRTXSTATE_SLOT1, DMRTXSTATE_CACH1, DMRTXSTATE_SLOT2, DMRTXSTATE_CACH2, DMRTXSTATE_CAL }; // --------------------------------------------------------------------------- // Class Declaration // Implements receiver logic for duplex DMR mode operation. // --------------------------------------------------------------------------- class DSP_FW_API DMRTX { public: /// Initializes a new instance of the DMRTX class. DMRTX(); /// Process local buffer and transmit on the air interface. void process(); /// Write slot 1 data to the local buffer. uint8_t writeData1(const uint8_t* data, uint8_t length); /// Write slot 2 data to the local buffer. uint8_t writeData2(const uint8_t* data, uint8_t length); /// Write short LC data to the local buffer. uint8_t writeShortLC(const uint8_t* data, uint8_t length); /// Write abort data to the local buffer. uint8_t writeAbort(const uint8_t* data, uint8_t length); /// Helper to set the start state for Tx. void setStart(bool start); /// Helper to set the calibration state for Tx. void setCal(bool start); /// Helper to get how much space the slot 1 ring buffer has for samples. uint8_t getSpace1() const; /// Helper to get how much space the slot 2 ring buffer has for samples. uint8_t getSpace2() const; /// Sets the DMR color code. void setColorCode(uint8_t colorCode); /// Helper to reset data values to defaults for slot 1 FIFO. void resetFifo1(); /// Helper to reset data values to defaults for slot 2 FIFO. void resetFifo2(); /// uint32_t getFrameCount(); private: SerialBuffer m_fifo[2U]; DMRTXSTATE m_state; uint8_t m_idle[DMR_FRAME_LENGTH_BYTES]; uint8_t m_cachPtr; uint8_t m_shortLC[12U]; uint8_t m_newShortLC[12U]; uint8_t m_markBuffer[40U]; uint8_t m_poBuffer[40U]; uint16_t m_poLen; uint16_t m_poPtr; uint32_t m_frameCount; uint32_t m_abortCount[2U]; bool m_abort[2U]; uint8_t m_control_old; /// void createData(uint8_t slotIndex); /// void createCACH(uint8_t txSlotIndex, uint8_t rxSlotIndex); /// void createCal(); /// void writeByte(uint8_t c, uint8_t control); }; } // namespace dmr #endif // __DMR_TX_H__