dont dispatch udp to main

This commit is contained in:
ouwou
2022-09-30 01:09:51 -04:00
parent f8ae99ee7b
commit 0438b11c91
3 changed files with 10 additions and 23 deletions

View File

@@ -112,12 +112,16 @@ AudioManager::~AudioManager() {
}
void AudioManager::AddSSRC(uint32_t ssrc) {
std::lock_guard<std::mutex> _(m_mutex);
int error;
auto *decoder = opus_decoder_create(48000, 2, &error);
m_sources.insert(std::make_pair(ssrc, std::make_pair(std::deque<int16_t> {}, decoder)));
if (m_sources.find(ssrc) == m_sources.end()) {
auto *decoder = opus_decoder_create(48000, 2, &error);
m_sources.insert(std::make_pair(ssrc, std::make_pair(std::deque<int16_t> {}, decoder)));
}
}
void AudioManager::RemoveSSRC(uint32_t ssrc) {
std::lock_guard<std::mutex> _(m_mutex);
if (auto it = m_sources.find(ssrc); it != m_sources.end()) {
opus_decoder_destroy(it->second.second);
m_sources.erase(it);
@@ -126,6 +130,7 @@ void AudioManager::RemoveSSRC(uint32_t ssrc) {
void AudioManager::RemoveAllSSRCs() {
puts("remove all ssrc");
std::lock_guard<std::mutex> _(m_mutex);
for (auto &[ssrc, pair] : m_sources) {
opus_decoder_destroy(pair.second);
}
@@ -146,14 +151,14 @@ void AudioManager::FeedMeOpus(uint32_t ssrc, const std::vector<uint8_t> &data) {
size_t payload_size = 0;
const auto *opus_encoded = StripRTPExtensionHeader(data.data(), static_cast<int>(data.size()), payload_size);
static std::array<opus_int16, 120 * 48 * 2> pcm;
std::lock_guard<std::mutex> _(m_mutex);
if (auto it = m_sources.find(ssrc); it != m_sources.end()) {
int decoded = opus_decode(it->second.second, opus_encoded, static_cast<opus_int32>(payload_size), pcm.data(), 120 * 48, 0);
if (decoded <= 0) {
} else {
m_mutex.lock();
auto &buf = it->second.first;
buf.insert(buf.end(), pcm.begin(), pcm.begin() + decoded * 2);
m_mutex.unlock();
}
}
}

View File

@@ -141,9 +141,7 @@ DiscordVoiceClient::DiscordVoiceClient() {
});
m_udp.signal_data().connect([this](const std::vector<uint8_t> &data) {
std::lock_guard<std::mutex> _(m_udp_dispatch_mutex);
m_udp_message_queue.push(data);
m_udp_dispatcher.emit();
OnUDPData(data);
});
m_dispatcher.connect([this]() {
@@ -158,18 +156,6 @@ DiscordVoiceClient::DiscordVoiceClient() {
OnGatewayMessage(msg);
});
m_udp_dispatcher.connect([this]() {
m_udp_dispatch_mutex.lock();
if (m_udp_message_queue.empty()) {
m_udp_dispatch_mutex.unlock();
return;
}
auto data = std::move(m_udp_message_queue.front());
m_udp_message_queue.pop();
m_udp_dispatch_mutex.unlock();
OnUDPData(data);
});
Glib::signal_idle().connect_once([this]() {
// cant put in ctor or deadlock in singleton initialization
auto &aud = Abaddon::Get().GetAudio();

View File

@@ -235,10 +235,6 @@ private:
std::queue<std::string> m_message_queue;
std::mutex m_dispatch_mutex;
Glib::Dispatcher m_udp_dispatcher;
std::queue<std::vector<uint8_t>> m_udp_message_queue;
std::mutex m_udp_dispatch_mutex;
int m_heartbeat_msec;
Waiter m_heartbeat_waiter;
std::thread m_heartbeat_thread;