Timestamps are unset in a packet for stream 0. This is deprecated and will stop working in the futur

Timestamps are unset in a packet for stream 0. This is deprecated and will stop working in the future. Fix your code

/* check that the timestamps are set */

if (pkt->pts == AV_NOPTS_VALUE || pkt->dts == AV_NOPTS_VALUE) {

av_log(s, AV_LOG_ERROR,"Timestamps are unset in a packet for stream %d\n", st->index);

return AVERROR(EINVAL);

}

 

​
//FIXME merge with compute_pkt_fields
 static int compute_muxer_pkt_fields(AVFormatContext *s, AVStream *st, AVPacket *pkt)
 {
  int delay = FFMAX(st->codecpar->video_delay, st->internal->avctx->max_b_frames > 0);
  int num, den, i;
  int frame_size;
 
  if (!s->internal->missing_ts_warning &&
  !(s->oformat->flags & AVFMT_NOTIMESTAMPS) &&
  (!(st->disposition & AV_DISPOSITION_ATTACHED_PIC) || (st->disposition & AV_DISPOSITION_TIMED_THUMBNAILS)) &&
  (pkt->pts == AV_NOPTS_VALUE || pkt->dts == AV_NOPTS_VALUE)) {
  av_log(s, AV_LOG_WARNING,
  "Timestamps are unset in a packet for stream %d. "
  "This is deprecated and will stop working in the future. "
  "Fix your code to set the timestamps properly\n", st->index);
  s->internal->missing_ts_warning = 1;
  }
 
  if (s->debug & FF_FDEBUG_TS)
  av_log(s, AV_LOG_TRACE, "compute_muxer_pkt_fields: pts:%s dts:%s cur_dts:%s b:%d size:%d st:%d\n",
  av_ts2str(pkt->pts), av_ts2str(pkt->dts), av_ts2str(st->cur_dts), delay, pkt->size, pkt->stream_index);
 
  if (pkt->duration < 0 && st->codecpar->codec_type != AVMEDIA_TYPE_SUBTITLE) {
  av_log(s, AV_LOG_WARNING, "Packet with invalid duration %"PRId64" in stream %d\n",
  pkt->duration, pkt->stream_index);
  pkt->duration = 0;
  }
 
  /* duration field */
  if (pkt->duration == 0) {
  ff_compute_frame_duration(s, &num, &den, st, NULL, pkt);
  if (den && num) {
  pkt->duration = av_rescale(1, num * (int64_t)st->time_base.den * st->codec->ticks_per_frame, den * (int64_t)st->time_base.num);
  }
  }
 
  if (pkt->pts == AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE && delay == 0)
  pkt->pts = pkt->dts;
 
  //XXX/FIXME this is a temporary hack until all encoders output pts
  if ((pkt->pts == 0 || pkt->pts == AV_NOPTS_VALUE) && pkt->dts == AV_NOPTS_VALUE && !delay) {
  static int warned;
  if (!warned) {
  av_log(s, AV_LOG_WARNING, "Encoder did not produce proper pts, making some up.\n");
  warned = 1;
  }
  pkt->dts =
 // pkt->pts= st->cur_dts;
  pkt->pts = st->internal->priv_pts->val;
  }
 
  //calculate dts from pts
  if (pkt->pts != AV_NOPTS_VALUE && pkt->dts == AV_NOPTS_VALUE && delay <= MAX_REORDER_DELAY) {
  st->pts_buffer[0] = pkt->pts;
  for (i = 1; i < delay + 1 && st->pts_buffer[i] == AV_NOPTS_VALUE; i++)
  st->pts_buffer[i] = pkt->pts + (i - delay - 1) * pkt->duration;
  for (i = 0; i<delay && st->pts_buffer[i] > st->pts_buffer[i + 1]; i++)
  FFSWAP(int64_t, st->pts_buffer[i], st->pts_buffer[i + 1]);
 
  pkt->dts = st->pts_buffer[0];
  }
 
  if (st->cur_dts && st->cur_dts != AV_NOPTS_VALUE &&
  ((!(s->oformat->flags & AVFMT_TS_NONSTRICT) &&
  st->codecpar->codec_type != AVMEDIA_TYPE_SUBTITLE &&
  st->codecpar->codec_type != AVMEDIA_TYPE_DATA &&
  st->cur_dts >= pkt->dts) || st->cur_dts > pkt->dts)) {
  av_log(s, AV_LOG_ERROR,
  "Application provided invalid, non monotonically increasing dts to muxer in stream %d: %s >= %s\n",
  st->index, av_ts2str(st->cur_dts), av_ts2str(pkt->dts));
  return AVERROR(EINVAL);
  }
  if (pkt->dts != AV_NOPTS_VALUE && pkt->pts != AV_NOPTS_VALUE && pkt->pts < pkt->dts) {
  av_log(s, AV_LOG_ERROR,
  "pts (%s) < dts (%s) in stream %d\n",
  av_ts2str(pkt->pts), av_ts2str(pkt->dts),
  st->index);
  return AVERROR(EINVAL);
  }
 
  if (s->debug & FF_FDEBUG_TS)
  av_log(s, AV_LOG_TRACE, "av_write_frame: pts2:%s dts2:%s\n",
  av_ts2str(pkt->pts), av_ts2str(pkt->dts));
 
  st->cur_dts = pkt->dts;
  st->internal->priv_pts->val = pkt->dts;
 
  /* update pts */
  switch (st->codecpar->codec_type) {
  case AVMEDIA_TYPE_AUDIO:
  frame_size = (pkt->flags & AV_PKT_FLAG_UNCODED_FRAME) ?
  ((AVFrame *)pkt->data)->nb_samples :
  av_get_audio_frame_duration(st->codec, pkt->size);
 
  /* HACK/FIXME, we skip the initial 0 size packets as they are most
  * likely equal to the encoder delay, but it would be better if we
  * had the real timestamps from the encoder */
  if (frame_size >= 0 && (pkt->size || st->internal->priv_pts->num != st->internal->priv_pts->den >> 1 || st->internal->priv_pts->val)) {
  frac_add(st->internal->priv_pts, (int64_t)st->time_base.den * frame_size);
  }
  break;
  case AVMEDIA_TYPE_VIDEO:
  frac_add(st->internal->priv_pts, (int64_t)st->time_base.den * st->time_base.num);
  break;
  }
  return 0;
 }
​

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI算法网奇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值