mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-26 20:25:34 +08:00
[fix] stop threads when DestroyIceTransmission() called
This commit is contained in:
@@ -83,7 +83,8 @@ int AomAv1Decoder::Decode(
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (img_ = aom_codec_get_frame(&aom_av1_decoder_ctx_, &iter)) {
|
||||
img_ = aom_codec_get_frame(&aom_av1_decoder_ctx_, &iter);
|
||||
if (img_) {
|
||||
{
|
||||
aom_codec_frame_flags_t flags;
|
||||
ret = aom_codec_control(&aom_av1_decoder_ctx_, AOMD_GET_FRAME_FLAGS,
|
||||
|
||||
@@ -956,6 +956,7 @@ void PeerConnection::ProcessIceWorkMsg(const IceWorkMsg &msg) {
|
||||
}
|
||||
case IceWorkMsg::Type::Destroy: {
|
||||
for (auto &user_id_it : ice_transmission_list_) {
|
||||
LOG_ERROR("Destroy transmission");
|
||||
user_id_it.second->DestroyIceTransmission();
|
||||
}
|
||||
ice_transmission_list_.clear();
|
||||
|
||||
@@ -1,5 +1,7 @@
|
||||
#include "io_statistics.h"
|
||||
|
||||
#include "log.h"
|
||||
|
||||
IOStatistics::IOStatistics(
|
||||
std::function<void(uint32_t, uint32_t, uint32_t, uint32_t, uint32_t,
|
||||
uint32_t, uint32_t, uint32_t)>
|
||||
@@ -8,13 +10,7 @@ IOStatistics::IOStatistics(
|
||||
interval_ = 1000;
|
||||
}
|
||||
|
||||
IOStatistics::~IOStatistics() {
|
||||
running_ = false;
|
||||
cond_var_.notify_one();
|
||||
if (statistics_thread_.joinable()) {
|
||||
statistics_thread_.join();
|
||||
}
|
||||
}
|
||||
IOStatistics::~IOStatistics() {}
|
||||
|
||||
void IOStatistics::Process() {
|
||||
while (running_) {
|
||||
@@ -56,6 +52,14 @@ void IOStatistics::Start() {
|
||||
}
|
||||
}
|
||||
|
||||
void IOStatistics::Stop() {
|
||||
running_ = false;
|
||||
cond_var_.notify_one();
|
||||
if (statistics_thread_.joinable()) {
|
||||
statistics_thread_.join();
|
||||
}
|
||||
}
|
||||
|
||||
void IOStatistics::UpdateVideoInboundBytes(uint32_t bytes) {
|
||||
video_inbound_bytes_ += bytes;
|
||||
}
|
||||
|
||||
@@ -22,6 +22,7 @@ class IOStatistics {
|
||||
|
||||
public:
|
||||
void Start();
|
||||
void Stop();
|
||||
|
||||
void UpdateVideoInboundBytes(uint32_t bytes);
|
||||
void UpdateVideoOutboundBytes(uint32_t bytes);
|
||||
|
||||
@@ -22,19 +22,7 @@ IceTransmission::IceTransmission(
|
||||
ice_ws_transport_(ice_ws_transmission),
|
||||
on_ice_status_change_(on_ice_status_change) {}
|
||||
|
||||
IceTransmission::~IceTransmission() {
|
||||
if (rtp_video_sender_) {
|
||||
rtp_video_sender_->Stop();
|
||||
}
|
||||
|
||||
if (rtp_audio_sender_) {
|
||||
rtp_audio_sender_->Stop();
|
||||
}
|
||||
|
||||
if (rtp_data_sender_) {
|
||||
rtp_data_sender_->Stop();
|
||||
}
|
||||
}
|
||||
IceTransmission::~IceTransmission() {}
|
||||
|
||||
int IceTransmission::SetLocalCapabilities(
|
||||
bool use_trickle_ice, bool use_reliable_ice, bool enable_turn,
|
||||
@@ -351,6 +339,29 @@ int IceTransmission::DestroyIceTransmission() {
|
||||
if (on_ice_status_change_) {
|
||||
on_ice_status_change_("closed");
|
||||
}
|
||||
|
||||
if (ice_io_statistics_) {
|
||||
ice_io_statistics_->Stop();
|
||||
}
|
||||
|
||||
if (rtp_video_receiver_) {
|
||||
rtp_video_receiver_->Stop();
|
||||
}
|
||||
|
||||
if (rtp_video_sender_) {
|
||||
rtp_video_sender_->Stop();
|
||||
}
|
||||
|
||||
if (rtp_audio_sender_) {
|
||||
rtp_audio_sender_->Stop();
|
||||
}
|
||||
|
||||
if (rtp_data_sender_) {
|
||||
rtp_data_sender_->Stop();
|
||||
}
|
||||
|
||||
LOG_ERROR("threads stoped");
|
||||
|
||||
return ice_agent_->DestroyIceAgent();
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user