Skip to content

Commit

Permalink
H265: fix some important bugs (#2156)
Browse files Browse the repository at this point in the history
* For #1747, Support HEVC/H.265 in SRT/RTMP/HLS.

* Fixed compile error.

* 1. optimize when to send hevc vps sps pps header
2. fix hevc I frame dropped by rtc before sending to consumer
3. fix overread in nalu parsing

* ignore unknown payload data, otherwise it will be processed in other place

* free err before return

Co-authored-by: runner365 <shi.weibd@hotmail.com>
Co-authored-by: yinjiaoyuan <yinjiaoyuan@163.com>
  • Loading branch information
3 people authored and winlinvip committed Dec 4, 2021
1 parent b846217 commit 2621896
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 12 deletions.
29 changes: 18 additions & 11 deletions trunk/src/app/srs_app_gb28181.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1387,9 +1387,10 @@ srs_error_t SrsGb28181RtmpMuxer::write_hevc_ipb_frame2(char *frame, int frame_si
h265_vps = vps;

//write hevc vps_sps_pps
if ((err = write_hevc_sps_pps(dts, pts)) != srs_success) {
return srs_error_wrap(err, "hevc write vps/sps/pps");
}
// if ((err = write_hevc_sps_pps(dts, pts)) != srs_success) {
// return srs_error_wrap(err, "hevc write vps/sps/pps");
// }
return err;
}

// for sps
Expand All @@ -1405,9 +1406,9 @@ srs_error_t SrsGb28181RtmpMuxer::write_hevc_ipb_frame2(char *frame, int frame_si
hevc_sps_changed = true;
h265_sps = sps;

if ((err = write_hevc_sps_pps(dts, pts)) != srs_success) {
return srs_error_wrap(err, "write hevc sps/pps");
}
// if ((err = write_hevc_sps_pps(dts, pts)) != srs_success) {
// return srs_error_wrap(err, "write hevc sps/pps");
// }
return err;
}

Expand All @@ -1424,10 +1425,16 @@ srs_error_t SrsGb28181RtmpMuxer::write_hevc_ipb_frame2(char *frame, int frame_si
hevc_pps_changed = true;
h265_pps = pps;

// if ((err = write_hevc_sps_pps(dts, pts)) != srs_success) {
// return srs_error_wrap(err, "write hevc sps/pps");
// }
return err;
}

if (hevc_sps_changed || hevc_pps_changed || hevc_vps_changed) {
if ((err = write_hevc_sps_pps(dts, pts)) != srs_success) {
return srs_error_wrap(err, "write hevc sps/pps");
}
return err;
}

srs_info("gb28181: demux hevc ibp frame size=%d, dts=%d", frame_size, dts);
Expand Down Expand Up @@ -1518,13 +1525,12 @@ srs_error_t SrsGb28181RtmpMuxer::write_hevc_ipb_frame2(char *frame, int frame_si
std::list<int> list_index;

for (; index < size; index++) {
if (index > (size - 4))
break;
if (video_data[index] == 0x00 && video_data[index + 1] == 0x00 &&
video_data[index + 2] == 0x00 && video_data[index + 3] == 0x01) {
list_index.push_back(index);
}

if (index > (size - 4))
break;
}

if (list_index.size() == 1) {
Expand Down Expand Up @@ -1757,7 +1763,8 @@ srs_error_t SrsGb28181RtmpMuxer::write_hevc_sps_pps(uint32_t dts, uint32_t pts)
// when sps or pps changed, update the sequence header,
// for the pps maybe not changed while sps changed.
// so, we must check when each video ts message frame parsed.
if (!hevc_sps_changed || !hevc_pps_changed || !hevc_vps_changed) {
// if (!hevc_sps_changed || !hevc_pps_changed || !hevc_vps_changed) {
if (!(hevc_sps_changed || hevc_pps_changed || hevc_vps_changed)) {
return err;
}

Expand Down
6 changes: 5 additions & 1 deletion trunk/src/app/srs_app_source.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2352,7 +2352,11 @@ srs_error_t SrsLiveSource::on_video_imp(SrsSharedPtrMessage* msg)

// For bridger to consume the message.
if (bridger_ && (err = bridger_->on_video(msg)) != srs_success) {
return srs_error_wrap(err, "bridger consume video");
// rtc doesn't support hevc, here fails if it's a hevc key frame
// so consumers can't get 1c01 VideoTag
// return srs_error_wrap(err, "bridger consume video");
// srs_warn("rtc on video err %s", srs_error_desc(err).c_str());
srs_freep(err);
}

// copy to all consumer
Expand Down

0 comments on commit 2621896

Please sign in to comment.