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/p25/P25RX.h

121 lines
2.8 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,2017,2018 Andy Uribe, CA6JAU
* Copyright (C) 2021-2024 Bryan Biedenkapp, N2PLL
*
*/
/**
* @file P25RX.h
* @ingroup p25_hfw
* @file P25RX.h
* @ingroup p25_hfw
*/
#if !defined(__P25_RX_H__)
#define __P25_RX_H__
#include "Defines.h"
#include "p25/P25Defines.h"
namespace p25
{
// ---------------------------------------------------------------------------
// Constants
// ---------------------------------------------------------------------------
/**
* @brief P25 Receiver State
* @ingroup p25_hfw
*/
enum P25RX_STATE {
P25RXS_NONE, //! None
P25RXS_SYNC, //! Found Sync
P25RXS_VOICE, //! Voice Data
P25RXS_DATA //! PDU Data
};
// ---------------------------------------------------------------------------
// Class Declaration
// ---------------------------------------------------------------------------
/**
* @brief Implements receiver logic for P25 mode operation.
* @ingroup p25_hfw
*/
class DSP_FW_API P25RX {
public:
/**
* @brief Initializes a new instance of the P25RX class.
*/
P25RX();
/**
* @brief Helper to reset data values to defaults.
*/
void reset();
/**
* @brief Sample P25 bits from the air interface.
* @param bit
*/
void databit(bool bit);
/**
* @brief Sets the P25 NAC.
* @param nac Network Access Code.
*/
void setNAC(uint16_t nac);
private:
uint64_t m_bitBuffer;
uint8_t m_buffer[P25_PDU_FRAME_LENGTH_BYTES + 3U];
uint16_t m_dataPtr;
uint16_t m_endPtr;
uint16_t m_pduEndPtr;
uint16_t m_lostCount;
uint16_t m_nac;
P25RX_STATE m_state;
uint8_t m_duid;
/**
* @brief Helper to process P25 bits.
* @param bit
*/
void processBit(bool bit);
/**
* @brief Helper to process LDU P25 bits.
* @param bit
*/
void processVoice(bool bit);
/**
* @brief Helper to process PDU P25 bits.
* @param bit
*/
void processData(bool bit);
/**
* @brief Frame synchronization correlator.
* @returns bool
*/
bool correlateSync();
/**
* @brief Helper to decode the P25 NID.
* @returns bool True, if P25 NID was decoded, otherwise false.
*/
bool decodeNid();
};
} // namespace p25
#endif // __P25_RX_H__

Powered by TurnKey Linux.