/** * Digital Voice Modem - Host Software * GPLv2 Open Source. Use is subject to license terms. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * @package DVM / Host Software * */ // // Based on code from the MMDVMHost project. (https://github.com/g4klx/MMDVMHost) // Licensed under the GPLv2 License (https://opensource.org/licenses/GPL-2.0) // /* * Copyright (C) 2015,2016 by Jonathan Naylor G4KLX * Copyright (C) 2019-2021 by 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(__DMR_LC__CSBK_H__) #define __DMR_LC__CSBK_H__ #include "Defines.h" #include "dmr/DMRDefines.h" #include "dmr/SiteData.h" #include "lookups/IdenTableLookup.h" namespace dmr { namespace lc { // --------------------------------------------------------------------------- // Class Declaration // Represents DMR control signalling block data. // --------------------------------------------------------------------------- class HOST_SW_API CSBK { public: /// Initializes a copy instance of the CSBK class. CSBK(const CSBK& data); /// Initializes a new instance of the CSBK class. CSBK(); /// Finalizes a instance of the CSBK class. virtual ~CSBK(); /// Decodes a DMR CSBK. virtual bool decode(const uint8_t* data) = 0; /// Encodes a DMR CSBK. virtual void encode(uint8_t* data) = 0; /// Regenerate a DMR CSBK without decoding. /// This is because the DMR archeticture allows fall-thru of unsupported CSBKs. static bool regenerate(uint8_t* data); /// Sets the flag indicating verbose log output. static void setVerbose(bool verbose) { m_verbose = verbose; } /** Local Site data */ /// Gets the local site data. static SiteData getSiteData() { return m_siteData; } /// Sets the local site data. static void setSiteData(SiteData siteData) { m_siteData = siteData; } public: /** Common Data */ /// DMR access color code. __PROTECTED_PROPERTY(uint8_t, colorCode, ColorCode); /// Flag indicating this is the last TSBK in a sequence of TSBKs. __PROTECTED_PROPERTY(bool, lastBlock, LastBlock); /// Flag indicating whether the CSBK is a Cdef block. __PROTECTED_PROPERTY(bool, Cdef, Cdef); /// CSBK opcode. __PROTECTED_PROPERTY(uint8_t, CSBKO, CSBKO); /// CSBK feature ID. __PROTECTED_PROPERTY(uint8_t, FID, FID); /// Flag indicating whether the CSBK is group or individual. __PROTECTED_PROPERTY(bool, GI, GI); /// Source ID. __PROTECTED_PROPERTY(uint32_t, srcId, SrcId); /// Destination ID. __PROTECTED_PROPERTY(uint32_t, dstId, DstId); /// __PROTECTED_READONLY_PROPERTY(bool, dataContent, DataContent); /// Number of blocks to follow. __PROTECTED_PROPERTY(uint8_t, CBF, CBF); /** Common Service Options */ /// Flag indicating the emergency bits are set. __PROTECTED_PROPERTY(bool, emergency, Emergency); /// Flag indicating that privacy is enabled. __PROTECTED_PROPERTY(bool, privacy, Privacy); /// Flag indicating that supplementary data is required. __PROTECTED_PROPERTY(bool, supplementData, SupplementData); /// Priority level for the traffic. __PROTECTED_PROPERTY(uint8_t, priority, Priority); /// Flag indicating a broadcast service. __PROTECTED_PROPERTY(bool, broadcast, Broadcast); /// Flag indicating a proxy. __PROTECTED_PROPERTY(bool, proxy, Proxy); /// Response information. __PROTECTED_PROPERTY(uint8_t, response, Response); /// Reason type. __PROTECTED_PROPERTY(uint8_t, reason, Reason); /** Tier 3 */ /// Site offset timing. __PROTECTED_PROPERTY(bool, siteOffsetTiming, SiteOffsetTiming); /// Broadcast Logical Channel ID 1. __PROTECTED_PROPERTY(uint16_t, logicalCh1, LogicalCh1); /// Broadcast Logical Channel ID 2. __PROTECTED_PROPERTY(uint16_t, logicalCh2, LogicalCh2); /// Logical Channel Slot Number. __PROTECTED_PROPERTY(uint8_t, slotNo, SlotNo); /** Local Site data */ /// Local Site Identity Entry. __PROTECTED_PROPERTY_PLAIN(::lookups::IdenTable, siteIdenEntry, siteIdenEntry); protected: static bool m_verbose; /** Local Site data */ static SiteData m_siteData; /// Internal helper to convert CSBK bytes to a 64-bit long value. static ulong64_t toValue(const uint8_t* Csbk); /// Internal helper to convert a 64-bit long value to CSBK bytes. static std::unique_ptr fromValue(const ulong64_t csbkValue); /// Internal helper to decode a control signalling block. bool decode(const uint8_t* data, uint8_t* csbk); /// Internal helper to encode a control signalling block. void encode(uint8_t* data, const uint8_t* csbk); __PROTECTED_COPY(CSBK); }; } // namespace lc } // namespace dmr #endif // __DMR_LC__CSBK_H__