You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
dvmfirmware-hs/dmr/DMRTX.h

201 lines
5.5 KiB

// 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.
*
* 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
*
*/
/**
* @file DMRTX.h
* @ingroup dmr_hfw
* @file DMRTX.cpp
* @ingroup dmr_hfw
*/
#if !defined(__DMR_TX_H__)
#define __DMR_TX_H__
#include "Defines.h"
#include "dmr/DMRDefines.h"
#include "SerialBuffer.h"
namespace dmr
{
// ---------------------------------------------------------------------------
// Constants
// ---------------------------------------------------------------------------
/**
* @brief DMR Duplex Transmitter State
* @ingroup dmr_hfw
*/
enum DMRTXSTATE {
DMRTXSTATE_IDLE, //! Idle
DMRTXSTATE_SLOT1, //! Slot 1
DMRTXSTATE_CACH1, //! Common Access Channel 1
DMRTXSTATE_SLOT2, //! Slot 2
DMRTXSTATE_CACH2, //! Common Access Channel 2
DMRTXSTATE_CAL //! Calibration
};
// ---------------------------------------------------------------------------
// Class Declaration
// ---------------------------------------------------------------------------
/**
* @brief Implements receiver logic for duplex DMR mode operation.
* @ingroup dmr_hfw
*/
class DSP_FW_API DMRTX {
public:
/**
* @brief Initializes a new instance of the DMRTX class.
*/
DMRTX();
/**
* @brief Process local buffer and transmit on the air interface.
*/
void process();
/**
* @brief Write slot 1 data to the local buffer.
* @param[in] data Buffer.
* @param length Length of buffer.
* @returns uint8_t Reason code.
*/
uint8_t writeData1(const uint8_t* data, uint8_t length);
/**
* @brief Write slot 2 data to the local buffer.
* @param[in] data Buffer.
* @param length Length of buffer.
* @returns uint8_t Reason code.
*/
uint8_t writeData2(const uint8_t* data, uint8_t length);
/**
* @brief Write short LC data to the local buffer.
* @param[in] data Buffer.
* @param length Length of buffer.
* @returns uint8_t Reason code.
*/
uint8_t writeShortLC(const uint8_t* data, uint8_t length);
/**
* @brief Write abort data to the local buffer.
* @param[in] data Buffer.
* @param length Length of buffer.
* @returns uint8_t Reason code.
*/
uint8_t writeAbort(const uint8_t* data, uint8_t length);
/**
* @brief Helper to set the start state for Tx.
* @param start
*/
void setStart(bool start);
/**
* @brief Helper to set the calibration state for Tx.
* @param start
*/
void setCal(bool start);
/**
* @brief Helper to get how much space the slot 1 ring buffer has for samples.
* @returns uint8_t Amount of space in the slot 1 ring buffer.
*/
uint8_t getSpace1() const;
/**
* @brief Helper to get how much space the slot 2 ring buffer has for samples.
* @returns uint8_t Amount of space in the slot 2 ring buffer.
*/
uint8_t getSpace2() const;
/**
* @brief Sets the ignore flags for setting the CACH Access Type bit.
* @param slot DMR slot number.
*/
void setIgnoreCACH_AT(uint8_t slot);
/**
* @brief Sets the DMR color code.
* @param colorCode Color code.
*/
void setColorCode(uint8_t colorCode);
/**
* @brief Helper to reset data values to defaults for slot 1 FIFO.
*/
void resetFifo1();
/**
* @brief Helper to reset data values to defaults for slot 2 FIFO.
*/
void resetFifo2();
/**
* @brief Helper to resize the FIFO buffer.
* @param size
*/
void resizeBuffer(uint16_t size);
/**
* @brief
* @returns uint32_t
*/
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;
/**
* @brief Helper to generate data.
* @param slotIndex
*/
void createData(uint8_t slotIndex);
/**
* @brief Helper to generate the common access channel.
* @param txSlotIndex
* @param rxSlotIndex
*/
void createCACH(uint8_t txSlotIndex, uint8_t rxSlotIndex);
/**
* @brief Helper to generate calibration data.
*/
void createCal();
/**
* @brief Helper to write a raw byte to the DAC.
* @param c Byte.
* @param control
*/
void writeByte(uint8_t c, uint8_t control);
};
} // namespace dmr
#endif // __DMR_TX_H__

Powered by TurnKey Linux.