// SPDX-License-Identifier: GPL-2.0-only /** * Digital Voice Modem - Hotspot Firmware * GPLv2 Open Source. Use is subject to license terms. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * @package DVM / Hotspot Firmware * @derivedfrom MMDVM_HS (https://github.com/g4klx/MMDVM_HS) * @license GPLv2 License (https://opensource.org/licenses/GPL-2.0) * * Copyright (C) 2015,2016,2017 Jonathan Naylor, G4KLX * Copyright (C) 2016 Colin Durbridge, G4EML * Copyright (C) 2017 Andy Uribe, CA6JAU * Copyright (C) 2021-2022 Bryan Biedenkapp, N2PLL * */ #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 ignore flags for setting the CACH Access Type bit. void setIgnoreCACH_AT(uint8_t slot); /// 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(); /// Helper to resize the FIFO buffer. void resizeBuffer(uint16_t size); /// 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_cachATControl; uint8_t m_controlPrev; /// 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__