// tcd - a hybid transcoder using DVSI hardware and Codec2 software // Copyright © 2021 Thomas A. Early N7TAE // 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 3 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, see . #include #include #include "TranscoderPacket.h" CTranscoderPacket::CTranscoderPacket(const STCPacket &tcp) : dstar_set(false), dmr_set(false), p25_set(false), m17_set(false), usrp_set(false), not_sent(true) { tcpacket.module = tcp.module; tcpacket.is_last = tcp.is_last; tcpacket.streamid = tcp.streamid; tcpacket.codec_in = tcp.codec_in; tcpacket.sequence = tcp.sequence; switch (tcp.codec_in) { case ECodecType::dstar: SetDStarData(tcp.dstar); break; case ECodecType::dmr: SetDMRData(tcp.dmr); break; case ECodecType::p25: SetP25Data(tcp.p25); break; case ECodecType::usrp: SetUSRPData(tcp.usrp); break; case ECodecType::c2_1600: case ECodecType::c2_3200: SetM17Data(tcp.m17); break; default: std::cerr << "Trying to allocate CTranscoderPacket with an unknown codec type!" << std::endl; break; } } char CTranscoderPacket::GetModule() const { return tcpacket.module; } const uint8_t *CTranscoderPacket::GetDStarData() const { return tcpacket.dstar; } const uint8_t *CTranscoderPacket::GetDMRData() const { return tcpacket.dmr; } const uint8_t *CTranscoderPacket::GetP25Data() const { return tcpacket.p25; } const int16_t *CTranscoderPacket::GetUSRPData() const { return tcpacket.usrp; } const uint8_t *CTranscoderPacket::GetM17Data() const { return tcpacket.m17; } const STCPacket *CTranscoderPacket::GetTCPacket() const { return &tcpacket; } void CTranscoderPacket::SetM17Data(const uint8_t *data) { memcpy(tcpacket.m17, data, 16); m17_set = true; } void CTranscoderPacket::SetDStarData(const uint8_t *dstar) { memcpy(tcpacket.dstar, dstar, 9); dstar_set = true; } void CTranscoderPacket::SetDMRData(const uint8_t *dmr) { memcpy(tcpacket.dmr, dmr, 9); dmr_set = true; } void CTranscoderPacket::SetP25Data(const uint8_t *p25) { memcpy(tcpacket.p25, p25, 11); p25_set = true; } void CTranscoderPacket::SetUSRPData(const int16_t *usrp) { for(int i = 0; i < 160; ++i){ tcpacket.usrp[i] = usrp[i]; } usrp_set = true; } void CTranscoderPacket::SetAudioSamples(const int16_t *sample, bool swap) { for (unsigned int i=0; i<160; i++) audio[i] = swap ? ntohs(sample[i]) : sample[i]; } const int16_t *CTranscoderPacket::GetAudioSamples() const { return audio; } ECodecType CTranscoderPacket::GetCodecIn() const { return tcpacket.codec_in; } uint16_t CTranscoderPacket::GetStreamId() const { return tcpacket.streamid; } uint32_t CTranscoderPacket::GetSequence() const { return tcpacket.sequence; } bool CTranscoderPacket::IsLast() const { return tcpacket.is_last; } bool CTranscoderPacket::IsSecond() const { return (1 == tcpacket.sequence % 2); } bool CTranscoderPacket::DStarIsSet() const { return dstar_set; } bool CTranscoderPacket::DMRIsSet() const { return dmr_set; } bool CTranscoderPacket::P25IsSet() const { return p25_set; } bool CTranscoderPacket::USRPIsSet() const { return usrp_set; } bool CTranscoderPacket::M17IsSet() const { return m17_set; } bool CTranscoderPacket::AllCodecsAreSet() const { return (dstar_set && dmr_set && m17_set && p25_set && usrp_set); } void CTranscoderPacket::Sent() { not_sent = false; } bool CTranscoderPacket::HasNotBeenSent() const { return not_sent; }