/** * 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,2017,2018 by Andy Uribe CA6JAU * Copyright (C) 2021 Bryan Biedenkapp N2PLL * * 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(__P25_RX_H__) #define __P25_RX_H__ #include "Defines.h" #include "p25/P25Defines.h" namespace p25 { // --------------------------------------------------------------------------- // Constants // --------------------------------------------------------------------------- enum P25RX_STATE { P25RXS_NONE, P25RXS_SYNC, P25RXS_VOICE, P25RXS_DATA }; // --------------------------------------------------------------------------- // Class Declaration // Implements receiver logic for P25 mode operation. // --------------------------------------------------------------------------- class DSP_FW_API P25RX { public: /// Initializes a new instance of the P25RX class. P25RX(); /// Helper to reset data values to defaults. void reset(); /// Sample P25 bits from the air interface. void databit(bool bit); /// Sets the P25 NAC. void setNAC(uint16_t nac); private: uint64_t m_bitBuffer; uint8_t m_buffer[P25_LDU_FRAME_LENGTH_BYTES + 3U]; uint16_t m_dataPtr; uint16_t m_endPtr; uint16_t m_lostCount; uint16_t m_nac; P25RX_STATE m_state; uint8_t m_duid; /// Helper to process P25 bits. void processBit(bool bit); /// Helper to process LDU P25 bits. void processVoice(bool bit); /// Helper to process PDU P25 bits. void processData(bool bit); /// Frame synchronization correlator. bool correlateSync(); /// Helper to decode the P25 NID. bool decodeNid(); }; } // namespace p25 #endif // __P25_RX_H__