/* * Copyright (C) 2015 Jared Boone, ShareBrained Technology, Inc. * Copyright (C) 2016 Furrtek * * This file is part of PortaPack. * * 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, 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; see the file COPYING. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, * Boston, MA 02110-1301, USA. */ #ifndef __PROC_XYLOS_H__ #define __PROC_XYLOS_H__ #include "baseband_processor.hpp" #include "dsp_decimate.hpp" #include "dsp_demodulate.hpp" #include "audio_output.hpp" #include "baseband_thread.hpp" #define CCIR_TONELENGTH (15360*5)-1 // 1536000/10/10 #define PHASEV (436.91/5) // (65536*1024)/1536000*10 #define SILENCE (46080*5)-1 // 400ms class XylosProcessor : public BasebandProcessor { public: void execute(const buffer_c8_t& buffer) override; void on_message(const Message* const p) override; private: bool configured = false; bool transmit_done = false; BasebandThread baseband_thread { 1536000, this, NORMALPRIO + 20, baseband::Direction::Transmit }; uint32_t ccir_phases[16] = { (uint32_t)(1981*PHASEV), (uint32_t)(1124*PHASEV), (uint32_t)(1197*PHASEV), (uint32_t)(1275*PHASEV), (uint32_t)(1358*PHASEV), (uint32_t)(1446*PHASEV), (uint32_t)(1540*PHASEV), (uint32_t)(1640*PHASEV), (uint32_t)(1747*PHASEV), (uint32_t)(1860*PHASEV), (uint32_t)(2400*PHASEV), (uint32_t)(930*PHASEV), (uint32_t)(2247*PHASEV), (uint32_t)(991*PHASEV), (uint32_t)(2110*PHASEV), (uint32_t)(1055*PHASEV) }; char xylosdata[21]; int8_t re, im; uint8_t s, as = 0, ai; uint8_t byte_pos = 0; uint8_t digit = 0; uint32_t sample_count = CCIR_TONELENGTH; uint32_t aphase, phase, sphase; int32_t sample, frq; bool silence = true; TXDoneMessage message; //AudioOutput audio_output; }; #endif