mirror of
				https://github.com/kunkundi/crossdesk.git
				synced 2025-10-26 20:25:34 +08:00 
			
		
		
		
	[fix] use DecodedFrame ptr in decoding process
This commit is contained in:
		| @@ -44,9 +44,9 @@ class DecodedFrame : public VideoFrame { | ||||
|     decoded_width_ = decoded_width; | ||||
|   } | ||||
|  | ||||
|   uint32_t decodedHeight() const { return decoded_height_; } | ||||
|   uint32_t DecodedHeight() const { return decoded_height_; } | ||||
|  | ||||
|   void SetdecodedHeight(uint32_t decoded_height) { | ||||
|   void SetDecodedHeight(uint32_t decoded_height) { | ||||
|     decoded_height_ = decoded_height; | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -42,3 +42,13 @@ VideoFrame &VideoFrame::operator=(const VideoFrame &video_frame) = default; | ||||
| VideoFrame &VideoFrame::operator=(VideoFrame &&video_frame) = default; | ||||
|  | ||||
| VideoFrame::~VideoFrame() = default; | ||||
|  | ||||
| void VideoFrame::UpdateBuffer(const uint8_t *new_buffer, size_t new_size) { | ||||
|   if (new_size > size_) { | ||||
|     buffer_ = CopyOnWriteBuffer(new_buffer, new_size); | ||||
|     size_ = new_size; | ||||
|   } else { | ||||
|     std::memcpy((void *)buffer_.data(), new_buffer, new_size); | ||||
|     size_ = new_size; | ||||
|   } | ||||
| } | ||||
| @@ -43,6 +43,8 @@ class VideoFrame { | ||||
|   void SetWidth(uint32_t width) { width_ = width; } | ||||
|   void SetHeight(uint32_t height) { height_ = height; } | ||||
|  | ||||
|   void UpdateBuffer(const uint8_t *new_buffer, size_t new_size); | ||||
|  | ||||
|  private: | ||||
|   CopyOnWriteBuffer buffer_; | ||||
|   size_t size_ = 0; | ||||
|   | ||||
| @@ -9,6 +9,10 @@ AomAv1Decoder::AomAv1Decoder(std::shared_ptr<SystemClock> clock) | ||||
|     : clock_(clock) {} | ||||
|  | ||||
| AomAv1Decoder::~AomAv1Decoder() { | ||||
|   if (decoded_frame_) { | ||||
|     delete decoded_frame_; | ||||
|   } | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   if (file_nv12_) { | ||||
|     fflush(file_nv12_); | ||||
| @@ -48,6 +52,11 @@ int AomAv1Decoder::Init() { | ||||
|   aom_codec_control(&aom_av1_decoder_ctx_, AV1D_GET_IMG_FORMAT, | ||||
|                     AOM_IMG_FMT_NV12); | ||||
|  | ||||
|   if (!decoded_frame_) { | ||||
|     decoded_frame_ = new DecodedFrame(frame_width_ * frame_height_ * 3 / 2, | ||||
|                                       frame_width_, frame_height_); | ||||
|   } | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   file_nv12_ = fopen("decoded_nv12_stream.yuv", "w+b"); | ||||
|   if (!file_nv12_) { | ||||
| @@ -135,18 +144,20 @@ int AomAv1Decoder::Decode( | ||||
|       uv_data[2 * i + 1] = v_plane[i]; | ||||
|     } | ||||
|  | ||||
|     DecodedFrame decode_frame(nv12_data.data(), nv12_size, img_->d_w, | ||||
|                               img_->d_h); | ||||
|  | ||||
|     decode_frame.SetReceivedTimestamp(received_frame->ReceivedTimestamp()); | ||||
|     decode_frame.SetCapturedTimestamp(received_frame->CapturedTimestamp()); | ||||
|     decode_frame.SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|     decoded_frame_->UpdateBuffer(nv12_data.data(), nv12_size); | ||||
|     decoded_frame_->SetWidth(received_frame->Width()); | ||||
|     decoded_frame_->SetHeight(received_frame->Height()); | ||||
|     decoded_frame_->SetDecodedWidth(img_->d_w); | ||||
|     decoded_frame_->SetDecodedHeight(img_->d_h); | ||||
|     decoded_frame_->SetReceivedTimestamp(received_frame->ReceivedTimestamp()); | ||||
|     decoded_frame_->SetCapturedTimestamp(received_frame->CapturedTimestamp()); | ||||
|     decoded_frame_->SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|     fwrite((unsigned char *)decode_frame.Buffer(), 1, decode_frame.Size(), | ||||
|     fwrite((unsigned char *)decoded_frame_->Buffer(), 1, decoded_frame_->Size(), | ||||
|            file_nv12_); | ||||
| #endif | ||||
|     on_receive_decoded_frame(decode_frame); | ||||
|     on_receive_decoded_frame(*decoded_frame_); | ||||
|  | ||||
|     return 0; | ||||
|   } | ||||
|   | ||||
| @@ -30,6 +30,7 @@ class AomAv1Decoder : public VideoDecoder { | ||||
|  | ||||
|  private: | ||||
|   std::shared_ptr<SystemClock> clock_ = nullptr; | ||||
|   DecodedFrame *decoded_frame_ = nullptr; | ||||
|   unsigned char *nv12_frame_ = 0; | ||||
|   int nv12_frame_capacity_ = 0; | ||||
|   int nv12_frame_size_ = 0; | ||||
|   | ||||
| @@ -51,6 +51,10 @@ Dav1dAv1Decoder::Dav1dAv1Decoder(std::shared_ptr<SystemClock> clock) | ||||
|     : clock_(clock) {} | ||||
|  | ||||
| Dav1dAv1Decoder::~Dav1dAv1Decoder() { | ||||
|   if (decoded_frame_) { | ||||
|     delete decoded_frame_; | ||||
|   } | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   if (file_nv12_) { | ||||
|     fflush(file_nv12_); | ||||
| @@ -89,6 +93,11 @@ int Dav1dAv1Decoder::Init() { | ||||
|     LOG_ERROR("Dav1d AV1 decoder open failed"); | ||||
|   } | ||||
|  | ||||
|   if (!decoded_frame_) { | ||||
|     decoded_frame_ = new DecodedFrame(frame_width_ * frame_height_ * 3 / 2, | ||||
|                                       frame_width_, frame_height_); | ||||
|   } | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   file_nv12_ = fopen("decoded_nv12_stream.yuv", "w+b"); | ||||
|   if (!file_nv12_) { | ||||
| @@ -187,18 +196,20 @@ int Dav1dAv1Decoder::Decode( | ||||
|         frame_width_, frame_height_); | ||||
|   } | ||||
|  | ||||
|   DecodedFrame decoded_frame(nv12_frame_, nv12_frame_capacity_, frame_width_, | ||||
|                              frame_height_); | ||||
|  | ||||
|   decoded_frame.SetReceivedTimestamp(received_frame->ReceivedTimestamp()); | ||||
|   decoded_frame.SetCapturedTimestamp(received_frame->CapturedTimestamp()); | ||||
|   decoded_frame.SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|   decoded_frame_->UpdateBuffer(nv12_frame_, nv12_frame_capacity_); | ||||
|   decoded_frame_->SetWidth(received_frame->Width()); | ||||
|   decoded_frame_->SetHeight(received_frame->Height()); | ||||
|   decoded_frame_->SetDecodedWidth(frame_width_); | ||||
|   decoded_frame_->SetDecodedHeight(frame_height_); | ||||
|   decoded_frame_->SetReceivedTimestamp(received_frame->ReceivedTimestamp()); | ||||
|   decoded_frame_->SetCapturedTimestamp(received_frame->CapturedTimestamp()); | ||||
|   decoded_frame_->SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   fwrite((unsigned char *)decoded_frame.Buffer(), 1, decoded_frame.Size(), | ||||
|   fwrite((unsigned char *)decoded_frame_->Buffer(), 1, decoded_frame_->Size(), | ||||
|          file_nv12_); | ||||
| #endif | ||||
|   on_receive_decoded_frame(decoded_frame); | ||||
|   on_receive_decoded_frame(*decoded_frame_); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -28,6 +28,7 @@ class Dav1dAv1Decoder : public VideoDecoder { | ||||
|  | ||||
|  private: | ||||
|   std::shared_ptr<SystemClock> clock_ = nullptr; | ||||
|   DecodedFrame *decoded_frame_ = nullptr; | ||||
|   unsigned char *nv12_frame_ = 0; | ||||
|   size_t nv12_frame_capacity_ = 0; | ||||
|   size_t nv12_frame_size_ = 0; | ||||
|   | ||||
| @@ -8,6 +8,10 @@ | ||||
| NvidiaVideoDecoder::NvidiaVideoDecoder(std::shared_ptr<SystemClock> clock) | ||||
|     : clock_(clock) {} | ||||
| NvidiaVideoDecoder::~NvidiaVideoDecoder() { | ||||
|   if (decoded_frame_) { | ||||
|     delete decoded_frame_; | ||||
|   } | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   if (file_nv12_) { | ||||
|     fflush(file_nv12_); | ||||
| @@ -51,6 +55,11 @@ int NvidiaVideoDecoder::Init() { | ||||
|       new NvDecoder(cuda_context_, false, cudaVideoCodec_H264, true, false, | ||||
|                     nullptr, nullptr, false, 4096, 2160, 1000, false); | ||||
|  | ||||
|   if (!decoded_frame_) { | ||||
|     decoded_frame_ = new DecodedFrame(frame_width_ * frame_height_ * 3 / 2, | ||||
|                                       frame_width_, frame_height_); | ||||
|   } | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|   file_nv12_ = fopen("decoded_nv12_stream.yuv", "w+b"); | ||||
|   if (!file_nv12_) { | ||||
| @@ -94,20 +103,24 @@ int NvidiaVideoDecoder::Decode( | ||||
|       decoded_frame_buffer = decoder->GetFrame(); | ||||
|       if (decoded_frame_buffer) { | ||||
|         if (on_receive_decoded_frame) { | ||||
|           DecodedFrame decoded_frame( | ||||
|           decoded_frame_->UpdateBuffer( | ||||
|               decoded_frame_buffer, | ||||
|               decoder->GetWidth() * decoder->GetHeight() * 3 / 2, | ||||
|               decoder->GetWidth(), decoder->GetHeight()); | ||||
|           decoded_frame.SetReceivedTimestamp( | ||||
|               decoder->GetWidth() * decoder->GetHeight() * 3 / 2); | ||||
|           decoded_frame_->SetWidth(received_frame->Width()); | ||||
|           decoded_frame_->SetHeight(received_frame->Height()); | ||||
|           decoded_frame_->SetDecodedWidth(decoder->GetWidth()); | ||||
|           decoded_frame_->SetDecodedHeight(decoder->GetHeight()); | ||||
|           decoded_frame_->SetReceivedTimestamp( | ||||
|               received_frame->ReceivedTimestamp()); | ||||
|           decoded_frame.SetCapturedTimestamp( | ||||
|           decoded_frame_->SetCapturedTimestamp( | ||||
|               received_frame->CapturedTimestamp()); | ||||
|           decoded_frame.SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|           on_receive_decoded_frame(decoded_frame); | ||||
|           decoded_frame_->SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|           fwrite((unsigned char *)decoded_frame.Buffer(), 1, | ||||
|                  decoded_frame.Size(), file_nv12_); | ||||
|           fwrite((unsigned char *)decoded_frame_->Buffer(), 1, | ||||
|                  decoded_frame_->Size(), file_nv12_); | ||||
| #endif | ||||
|           on_receive_decoded_frame(*decoded_frame_); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   | ||||
| @@ -24,6 +24,7 @@ class NvidiaVideoDecoder : public VideoDecoder { | ||||
|   NvDecoder* decoder = nullptr; | ||||
|   CUcontext cuda_context_ = NULL; | ||||
|   CUdevice cuda_device_ = 0; | ||||
|   DecodedFrame* decoded_frame_ = nullptr; | ||||
|   bool get_first_keyframe_ = false; | ||||
|   bool skip_frame_ = false; | ||||
|  | ||||
|   | ||||
| @@ -46,6 +46,10 @@ OpenH264Decoder::~OpenH264Decoder() { | ||||
|     delete[] nv12_frame_; | ||||
|   } | ||||
|  | ||||
|   if (decoded_frame_) { | ||||
|     delete decoded_frame_; | ||||
|   } | ||||
|  | ||||
|   if (yuv420p_frame_) { | ||||
|     delete[] yuv420p_frame_; | ||||
|   } | ||||
| @@ -100,6 +104,11 @@ int OpenH264Decoder::Init() { | ||||
|   int trace_level = WELS_LOG_QUIET; | ||||
|   openh264_decoder_->SetOption(DECODER_OPTION_TRACE_LEVEL, &trace_level); | ||||
|  | ||||
|   if (!decoded_frame_) { | ||||
|     decoded_frame_ = new DecodedFrame(frame_width_ * frame_height_ * 3 / 2, | ||||
|                                       frame_width_, frame_height_); | ||||
|   } | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -182,17 +191,20 @@ int OpenH264Decoder::Decode( | ||||
|           (uint8_t *)nv12_frame_ + frame_width_ * frame_height_, frame_width_, | ||||
|           frame_width_, frame_height_); | ||||
|  | ||||
|       DecodedFrame decoded_frame(nv12_frame_, nv12_frame_capacity_, | ||||
|                                  frame_width_, frame_height_); | ||||
|       decoded_frame.SetReceivedTimestamp(received_frame->ReceivedTimestamp()); | ||||
|       decoded_frame.SetCapturedTimestamp(received_frame->CapturedTimestamp()); | ||||
|       decoded_frame.SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|       decoded_frame_->UpdateBuffer(nv12_frame_, nv12_frame_capacity_); | ||||
|       decoded_frame_->SetWidth(received_frame->Width()); | ||||
|       decoded_frame_->SetHeight(received_frame->Height()); | ||||
|       decoded_frame_->SetDecodedWidth(frame_width_); | ||||
|       decoded_frame_->SetDecodedHeight(frame_height_); | ||||
|       decoded_frame_->SetReceivedTimestamp(received_frame->ReceivedTimestamp()); | ||||
|       decoded_frame_->SetCapturedTimestamp(received_frame->CapturedTimestamp()); | ||||
|       decoded_frame_->SetDecodedTimestamp(clock_->CurrentTime()); | ||||
|  | ||||
| #ifdef SAVE_DECODED_NV12_STREAM | ||||
|       fwrite((unsigned char *)decoded_frame.Buffer(), 1, decoded_frame.Size(), | ||||
|              nv12_stream_); | ||||
|       fwrite((unsigned char *)decoded_frame_->Buffer(), 1, | ||||
|              decoded_frame_->Size(), nv12_stream_); | ||||
| #endif | ||||
|       on_receive_decoded_frame(decoded_frame); | ||||
|       on_receive_decoded_frame(*decoded_frame_); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -32,12 +32,11 @@ class OpenH264Decoder : public VideoDecoder { | ||||
|  private: | ||||
|   std::shared_ptr<SystemClock> clock_ = nullptr; | ||||
|   ISVCDecoder* openh264_decoder_ = nullptr; | ||||
|   DecodedFrame* decoded_frame_ = nullptr; | ||||
|   bool get_first_keyframe_ = false; | ||||
|   bool skip_frame_ = false; | ||||
|   FILE* nv12_stream_ = nullptr; | ||||
|   FILE* h264_stream_ = nullptr; | ||||
|   uint8_t* decoded_frame_ = nullptr; | ||||
|   int decoded_frame_size_ = 0; | ||||
|   uint32_t frame_width_ = 1280; | ||||
|   uint32_t frame_height_ = 720; | ||||
|  | ||||
|   | ||||
| @@ -314,16 +314,17 @@ int IceTransportController::OnReceiveDataRtpPacket(const char* data, | ||||
|  | ||||
| void IceTransportController::OnReceiveCompleteFrame( | ||||
|     std::unique_ptr<ReceivedFrame> received_frame) { | ||||
|   task_queue_decode_->PostTask( | ||||
|       [this, received_frame = std::move(received_frame)]() mutable { | ||||
|   task_queue_decode_->PostTask([this, received_frame = | ||||
|                                           std::move(received_frame)]() mutable { | ||||
|     uint64_t t = clock_->CurrentTime(); | ||||
|     if (video_decoder_) { | ||||
|       int num_frame_returned = video_decoder_->Decode( | ||||
|               std::move(received_frame), [this](DecodedFrame decoded_frame) { | ||||
|           std::move(received_frame), [this](const DecodedFrame& decoded_frame) { | ||||
|             if (on_receive_video_) { | ||||
|               XVideoFrame x_video_frame; | ||||
|               x_video_frame.data = (const char*)decoded_frame.Buffer(); | ||||
|                   x_video_frame.width = decoded_frame.Width(); | ||||
|                   x_video_frame.height = decoded_frame.Height(); | ||||
|               x_video_frame.width = decoded_frame.DecodedWidth(); | ||||
|               x_video_frame.height = decoded_frame.DecodedHeight(); | ||||
|               x_video_frame.size = decoded_frame.Size(); | ||||
|               x_video_frame.captured_timestamp = | ||||
|                   decoded_frame.CapturedTimestamp(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user