2016-02-10 23:11:19 -05:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Jared Boone, ShareBrained Technology, Inc.
|
2016-12-01 00:58:47 -05:00
|
|
|
* Copyright (C) 2016 Furrtek
|
2016-02-10 23:11:19 -05:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "baseband_api.hpp"
|
|
|
|
|
|
|
|
#include "audio.hpp"
|
2017-07-18 14:31:05 -04:00
|
|
|
#include "tonesets.hpp"
|
2016-02-10 23:11:19 -05:00
|
|
|
#include "dsp_iir_config.hpp"
|
|
|
|
|
|
|
|
#include "portapack_shared_memory.hpp"
|
2018-05-16 04:45:13 -04:00
|
|
|
#include "portapack_persistent_memory.hpp"
|
2016-02-10 23:11:19 -05:00
|
|
|
|
2016-06-24 14:30:54 -04:00
|
|
|
#include "core_control.hpp"
|
|
|
|
|
2018-05-16 04:45:13 -04:00
|
|
|
using namespace portapack;
|
|
|
|
|
2016-02-10 23:11:19 -05:00
|
|
|
namespace baseband {
|
|
|
|
|
2016-06-24 17:16:45 -04:00
|
|
|
static void send_message(const Message* const message) {
|
|
|
|
// If message is only sent by this function via one thread, no need to check if
|
|
|
|
// another message is present before setting new message.
|
|
|
|
shared_memory.baseband_message = message;
|
2020-08-19 03:43:04 -04:00
|
|
|
creg::m0apptxevent::assert_event();
|
2016-06-24 17:16:45 -04:00
|
|
|
while(shared_memory.baseband_message);
|
|
|
|
}
|
|
|
|
|
2016-02-10 23:11:19 -05:00
|
|
|
void AMConfig::apply() const {
|
|
|
|
const AMConfigureMessage message {
|
2022-11-19 12:17:54 -05:00
|
|
|
taps_6k0_decim_0, // common FIR filter taps pre-decim_0 to all 5 x AM mod types.(AM-9K, AM-6K, USB, LSB, CW)
|
|
|
|
taps_6k0_decim_1, // common FIR filter taps pre-decim_1 to all 5 x AM mod. types.
|
|
|
|
decim_2, // var decim_2 FIR taps filter , variable values, depending selected AM mod(AM 9k / 6k all rest AM modes)
|
|
|
|
channel, // var channel FIR taps filter , variable values, depending selected AM mode, each one different (DSB-9K, DSB-6K, USB-3K, LSB-3K,CW)
|
|
|
|
modulation, // var parameter .
|
2016-02-10 23:11:19 -05:00
|
|
|
audio_12k_hpf_300hz_config
|
|
|
|
};
|
2016-06-24 17:16:45 -04:00
|
|
|
send_message(&message);
|
2016-02-10 23:11:19 -05:00
|
|
|
audio::set_rate(audio::Rate::Hz_12000);
|
|
|
|
}
|
|
|
|
|
2017-06-11 04:50:29 -04:00
|
|
|
void NBFMConfig::apply(const uint8_t squelch_level) const {
|
2016-02-10 23:11:19 -05:00
|
|
|
const NBFMConfigureMessage message {
|
|
|
|
decim_0,
|
|
|
|
decim_1,
|
|
|
|
channel,
|
|
|
|
2,
|
|
|
|
deviation,
|
|
|
|
audio_24k_hpf_300hz_config,
|
2017-06-11 04:50:29 -04:00
|
|
|
audio_24k_deemph_300_6_config,
|
|
|
|
squelch_level
|
2016-02-10 23:11:19 -05:00
|
|
|
};
|
2016-06-24 17:16:45 -04:00
|
|
|
send_message(&message);
|
2016-02-10 23:11:19 -05:00
|
|
|
audio::set_rate(audio::Rate::Hz_24000);
|
|
|
|
}
|
|
|
|
|
|
|
|
void WFMConfig::apply() const {
|
|
|
|
const WFMConfigureMessage message {
|
|
|
|
taps_200k_wfm_decim_0,
|
|
|
|
taps_200k_wfm_decim_1,
|
|
|
|
taps_64_lp_156_198,
|
|
|
|
75000,
|
|
|
|
audio_48k_hpf_30hz_config,
|
|
|
|
audio_48k_deemph_2122_6_config
|
|
|
|
};
|
2016-06-24 17:16:45 -04:00
|
|
|
send_message(&message);
|
2016-02-10 23:11:19 -05:00
|
|
|
audio::set_rate(audio::Rate::Hz_48000);
|
|
|
|
}
|
|
|
|
|
2017-04-11 03:42:31 -04:00
|
|
|
void set_tone(const uint32_t index, const uint32_t delta, const uint32_t duration) {
|
|
|
|
shared_memory.bb_data.tones_data.tone_defs[index].delta = delta;
|
|
|
|
shared_memory.bb_data.tones_data.tone_defs[index].duration = duration;
|
|
|
|
}
|
|
|
|
|
|
|
|
void set_tones_config(const uint32_t bw, const uint32_t pre_silence, const uint16_t tone_count,
|
2016-12-09 12:21:47 -05:00
|
|
|
const bool dual_tone, const bool audio_out) {
|
|
|
|
const TonesConfigureMessage message {
|
2017-01-31 19:21:13 -05:00
|
|
|
bw,
|
2016-12-09 12:21:47 -05:00
|
|
|
pre_silence,
|
|
|
|
tone_count,
|
|
|
|
dual_tone,
|
|
|
|
audio_out
|
2016-07-26 21:03:40 -04:00
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-04-18 07:55:49 -04:00
|
|
|
void kill_tone() {
|
|
|
|
const TonesConfigureMessage message {
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-03-23 00:29:58 -04:00
|
|
|
void set_sstv_data(const uint8_t vis_code, const uint32_t pixel_duration) {
|
|
|
|
const SSTVConfigureMessage message {
|
|
|
|
vis_code,
|
|
|
|
pixel_duration
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-09-02 03:28:29 -04:00
|
|
|
void set_afsk(const uint32_t baudrate, const uint32_t word_length, const uint32_t trigger_value, const bool trigger_word) {
|
2017-08-29 04:42:04 -04:00
|
|
|
const AFSKRxConfigureMessage message {
|
2017-09-02 03:28:29 -04:00
|
|
|
baudrate,
|
|
|
|
word_length,
|
|
|
|
trigger_value,
|
|
|
|
trigger_word
|
2017-08-29 04:42:04 -04:00
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2021-03-07 17:05:23 -05:00
|
|
|
void set_aprs(const uint32_t baudrate) {
|
|
|
|
const APRSRxConfigureMessage message {
|
|
|
|
baudrate
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2020-04-20 00:50:03 -04:00
|
|
|
void set_btle(const uint32_t baudrate, const uint32_t word_length, const uint32_t trigger_value, const bool trigger_word) {
|
|
|
|
const BTLERxConfigureMessage message {
|
|
|
|
baudrate,
|
|
|
|
word_length,
|
|
|
|
trigger_value,
|
|
|
|
trigger_word
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
2022-12-05 09:51:23 -05:00
|
|
|
|
2020-04-20 00:45:28 -04:00
|
|
|
void set_nrf(const uint32_t baudrate, const uint32_t word_length, const uint32_t trigger_value, const bool trigger_word) {
|
|
|
|
const NRFRxConfigureMessage message {
|
|
|
|
baudrate,
|
|
|
|
word_length,
|
|
|
|
trigger_value,
|
|
|
|
trigger_word
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
2022-12-05 09:51:23 -05:00
|
|
|
|
2016-08-06 02:49:45 -04:00
|
|
|
void set_afsk_data(const uint32_t afsk_samples_per_bit, const uint32_t afsk_phase_inc_mark, const uint32_t afsk_phase_inc_space,
|
2017-04-21 01:22:31 -04:00
|
|
|
const uint8_t afsk_repeat, const uint32_t afsk_bw, const uint8_t symbol_count) {
|
2017-08-29 04:42:04 -04:00
|
|
|
const AFSKTxConfigureMessage message {
|
2016-07-27 15:26:03 -04:00
|
|
|
afsk_samples_per_bit,
|
|
|
|
afsk_phase_inc_mark,
|
|
|
|
afsk_phase_inc_space,
|
|
|
|
afsk_repeat,
|
|
|
|
afsk_bw,
|
2017-04-21 01:22:31 -04:00
|
|
|
symbol_count
|
2016-07-27 15:26:03 -04:00
|
|
|
};
|
2016-08-06 02:49:45 -04:00
|
|
|
send_message(&message);
|
2016-07-27 15:26:03 -04:00
|
|
|
}
|
|
|
|
|
2017-04-18 07:55:49 -04:00
|
|
|
void kill_afsk() {
|
2017-08-29 04:42:04 -04:00
|
|
|
const AFSKTxConfigureMessage message {
|
2017-04-18 07:55:49 -04:00
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
false
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2018-05-15 18:35:30 -04:00
|
|
|
void set_audiotx_config(const uint32_t divider, const float deviation_hz, const float audio_gain,
|
2022-12-05 09:51:23 -05:00
|
|
|
uint8_t audio_shift_bits_s16, const uint32_t tone_key_delta, const bool am_enabled,
|
2022-09-28 16:42:33 -04:00
|
|
|
const bool dsb_enabled, const bool usb_enabled, const bool lsb_enabled) {
|
2016-08-16 20:55:34 -04:00
|
|
|
const AudioTXConfigMessage message {
|
2016-08-26 03:54:17 -04:00
|
|
|
divider,
|
2018-02-01 06:17:51 -05:00
|
|
|
deviation_hz,
|
|
|
|
audio_gain,
|
2022-09-28 16:42:33 -04:00
|
|
|
audio_shift_bits_s16,
|
2017-11-09 19:25:04 -05:00
|
|
|
tone_key_delta,
|
2021-03-21 21:11:40 -04:00
|
|
|
(float)persistent_memory::tone_mix() / 100.0f,
|
|
|
|
am_enabled,
|
|
|
|
dsb_enabled,
|
|
|
|
usb_enabled,
|
|
|
|
lsb_enabled
|
2016-08-16 20:55:34 -04:00
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2016-08-16 22:17:24 -04:00
|
|
|
void set_fifo_data(const int8_t * data) {
|
|
|
|
const FIFODataMessage message {
|
|
|
|
data
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-11-28 02:52:04 -05:00
|
|
|
void set_pitch_rssi(int32_t avg, bool enabled) {
|
|
|
|
const PitchRSSIConfigureMessage message {
|
2016-07-27 23:25:33 -04:00
|
|
|
enabled,
|
|
|
|
avg
|
|
|
|
};
|
2022-12-05 09:51:23 -05:00
|
|
|
send_message(&message);
|
2016-07-27 23:25:33 -04:00
|
|
|
}
|
|
|
|
|
2016-08-06 02:49:45 -04:00
|
|
|
void set_ook_data(const uint32_t stream_length, const uint32_t samples_per_bit, const uint8_t repeat,
|
2022-12-05 09:51:23 -05:00
|
|
|
const uint32_t pause_symbols, const uint8_t de_bruijn_length) {
|
2016-08-03 02:53:50 -04:00
|
|
|
const OOKConfigureMessage message {
|
|
|
|
stream_length,
|
|
|
|
samples_per_bit,
|
2016-08-06 02:49:45 -04:00
|
|
|
repeat,
|
2022-12-05 09:51:23 -05:00
|
|
|
pause_symbols,
|
|
|
|
de_bruijn_length
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
|
|
|
void kill_ook() {
|
|
|
|
const OOKConfigureMessage message {
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0
|
2016-08-03 02:53:50 -04:00
|
|
|
};
|
2017-02-07 12:48:17 -05:00
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
|
|
|
void set_fsk_data(const uint32_t stream_length, const uint32_t samples_per_bit, const uint32_t shift,
|
|
|
|
const uint32_t progress_notice) {
|
|
|
|
const FSKConfigureMessage message {
|
|
|
|
stream_length,
|
|
|
|
samples_per_bit,
|
|
|
|
shift,
|
|
|
|
progress_notice
|
|
|
|
};
|
2016-08-06 02:49:45 -04:00
|
|
|
send_message(&message);
|
2016-08-03 02:53:50 -04:00
|
|
|
}
|
|
|
|
|
2021-10-22 13:11:50 -04:00
|
|
|
void set_pocsag() {
|
|
|
|
const POCSAGConfigureMessage message {};
|
2016-08-23 02:45:33 -04:00
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2016-12-01 00:58:47 -05:00
|
|
|
void set_adsb() {
|
|
|
|
const ADSBConfigureMessage message {
|
|
|
|
1
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-02-13 00:35:13 -05:00
|
|
|
void set_jammer(const bool run, const jammer::JammerType type, const uint32_t speed) {
|
2017-01-17 03:42:35 -05:00
|
|
|
const JammerConfigureMessage message {
|
2022-12-05 09:51:23 -05:00
|
|
|
run,
|
2017-01-29 20:09:00 -05:00
|
|
|
type,
|
|
|
|
speed
|
2017-01-17 03:42:35 -05:00
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2016-12-05 06:56:41 -05:00
|
|
|
void set_rds_data(const uint16_t message_length) {
|
|
|
|
const RDSConfigureMessage message {
|
|
|
|
message_length
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-02-01 03:53:26 -05:00
|
|
|
void set_spectrum(const size_t sampling_rate, const size_t trigger) {
|
|
|
|
const WidebandSpectrumConfigMessage message {
|
|
|
|
sampling_rate, trigger
|
2016-09-23 11:34:50 -04:00
|
|
|
};
|
|
|
|
send_message(&message);
|
2017-02-01 03:53:26 -05:00
|
|
|
}
|
2016-09-23 11:34:50 -04:00
|
|
|
|
2017-07-18 14:31:05 -04:00
|
|
|
void set_siggen_tone(const uint32_t tone) {
|
|
|
|
const SigGenToneMessage message {
|
2018-05-15 18:35:30 -04:00
|
|
|
TONES_F2D(tone, TONES_SAMPLERATE)
|
2017-07-18 14:31:05 -04:00
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
|
|
|
void set_siggen_config(const uint32_t bw, const uint32_t shape, const uint32_t duration) {
|
|
|
|
const SigGenConfigMessage message {
|
|
|
|
bw, shape, duration * TONES_SAMPLERATE
|
|
|
|
};
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2016-07-02 19:12:36 -04:00
|
|
|
static bool baseband_image_running = false;
|
2016-02-10 23:11:19 -05:00
|
|
|
|
2016-07-01 13:37:22 -04:00
|
|
|
void run_image(const portapack::spi_flash::image_tag_t image_tag) {
|
2016-07-02 19:12:36 -04:00
|
|
|
if( baseband_image_running ) {
|
|
|
|
chDbgPanic("BBRunning");
|
|
|
|
}
|
|
|
|
|
2016-07-02 19:15:43 -04:00
|
|
|
creg::m4txevent::clear();
|
|
|
|
|
2023-02-16 07:09:23 -05:00
|
|
|
m4_init(image_tag, portapack::memory::map::m4_code, false);
|
2016-07-02 19:12:36 -04:00
|
|
|
baseband_image_running = true;
|
2016-06-24 14:32:24 -04:00
|
|
|
|
|
|
|
creg::m4txevent::enable();
|
2016-02-10 23:11:19 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void shutdown() {
|
2016-07-02 19:12:36 -04:00
|
|
|
if( !baseband_image_running ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-06-24 14:32:24 -04:00
|
|
|
creg::m4txevent::disable();
|
|
|
|
|
2016-06-24 17:16:45 -04:00
|
|
|
ShutdownMessage message;
|
|
|
|
send_message(&message);
|
2016-07-02 19:12:36 -04:00
|
|
|
|
2016-07-02 19:19:28 -04:00
|
|
|
shared_memory.application_queue.reset();
|
2022-12-05 09:51:23 -05:00
|
|
|
|
2016-07-02 19:12:36 -04:00
|
|
|
baseband_image_running = false;
|
2016-02-10 23:11:19 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void spectrum_streaming_start() {
|
2016-06-24 17:16:45 -04:00
|
|
|
SpectrumStreamingConfigMessage message {
|
|
|
|
SpectrumStreamingConfigMessage::Mode::Running
|
|
|
|
};
|
|
|
|
send_message(&message);
|
2016-02-10 23:11:19 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void spectrum_streaming_stop() {
|
2016-06-24 17:16:45 -04:00
|
|
|
SpectrumStreamingConfigMessage message {
|
|
|
|
SpectrumStreamingConfigMessage::Mode::Stopped
|
|
|
|
};
|
|
|
|
send_message(&message);
|
2016-02-10 23:11:19 -05:00
|
|
|
}
|
|
|
|
|
2018-02-22 02:04:19 -05:00
|
|
|
void set_sample_rate(const uint32_t sample_rate) {
|
|
|
|
SamplerateConfigMessage message { sample_rate };
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2016-06-20 13:52:59 -04:00
|
|
|
void capture_start(CaptureConfig* const config) {
|
2016-06-24 17:16:45 -04:00
|
|
|
CaptureConfigMessage message { config };
|
|
|
|
send_message(&message);
|
2016-06-20 13:52:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void capture_stop() {
|
2016-06-24 17:16:45 -04:00
|
|
|
CaptureConfigMessage message { nullptr };
|
|
|
|
send_message(&message);
|
2016-02-10 23:11:19 -05:00
|
|
|
}
|
|
|
|
|
2017-04-19 17:05:16 -04:00
|
|
|
void replay_start(ReplayConfig* const config) {
|
|
|
|
ReplayConfigMessage message { config };
|
2017-01-15 22:45:44 -05:00
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
|
|
|
void replay_stop() {
|
2017-04-19 17:05:16 -04:00
|
|
|
ReplayConfigMessage message { nullptr };
|
2017-01-15 22:45:44 -05:00
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2017-03-14 03:24:04 -04:00
|
|
|
void request_beep() {
|
|
|
|
RequestSignalMessage message { RequestSignalMessage::Signal::BeepRequest };
|
|
|
|
send_message(&message);
|
|
|
|
}
|
|
|
|
|
2016-02-10 23:11:19 -05:00
|
|
|
} /* namespace baseband */
|