mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-22 10:40:05 +08:00
修复startSendRtp发送mp4文件时崩溃问题:#2429
This commit is contained in:
parent
beb99ee5b5
commit
19c5323633
@ -248,10 +248,11 @@ void MultiMediaSourceMuxer::startSendRtp(MediaSource &sender, const MediaSourceE
|
|||||||
auto ring = _ring;
|
auto ring = _ring;
|
||||||
auto ssrc = args.ssrc;
|
auto ssrc = args.ssrc;
|
||||||
auto tracks = getTracks(false);
|
auto tracks = getTracks(false);
|
||||||
auto rtp_sender = std::make_shared<RtpSender>(getOwnerPoller(sender));
|
auto poller = getOwnerPoller(sender);
|
||||||
|
auto rtp_sender = std::make_shared<RtpSender>(poller);
|
||||||
weak_ptr<MultiMediaSourceMuxer> weak_self = shared_from_this();
|
weak_ptr<MultiMediaSourceMuxer> weak_self = shared_from_this();
|
||||||
|
|
||||||
rtp_sender->startSend(args, [ssrc, weak_self, rtp_sender, cb, tracks, ring](uint16_t local_port, const SockException &ex) mutable {
|
rtp_sender->startSend(args, [ssrc, weak_self, rtp_sender, cb, tracks, ring, poller](uint16_t local_port, const SockException &ex) mutable {
|
||||||
cb(local_port, ex);
|
cb(local_port, ex);
|
||||||
auto strong_self = weak_self.lock();
|
auto strong_self = weak_self.lock();
|
||||||
if (!strong_self || ex) {
|
if (!strong_self || ex) {
|
||||||
@ -273,7 +274,7 @@ void MultiMediaSourceMuxer::startSendRtp(MediaSource &sender, const MediaSourceE
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
auto reader = ring->attach(EventPoller::getCurrentPoller());
|
auto reader = ring->attach(poller);
|
||||||
reader->setReadCB([rtp_sender](const Frame::Ptr &frame) {
|
reader->setReadCB([rtp_sender](const Frame::Ptr &frame) {
|
||||||
rtp_sender->inputFrame(frame);
|
rtp_sender->inputFrame(frame);
|
||||||
});
|
});
|
||||||
@ -315,7 +316,7 @@ EventPoller::Ptr MultiMediaSourceMuxer::getOwnerPoller(MediaSource &sender) {
|
|||||||
try {
|
try {
|
||||||
auto ret = listener->getOwnerPoller(sender);
|
auto ret = listener->getOwnerPoller(sender);
|
||||||
if (ret != _poller) {
|
if (ret != _poller) {
|
||||||
WarnL << "OwnerPoller changed:" << shortUrl();
|
WarnL << "OwnerPoller changed " << _poller->getThreadName() << " -> " << ret->getThreadName() << " : " << shortUrl();
|
||||||
_poller = ret;
|
_poller = ret;
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user