Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
F
ffmpeg
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
ffmpeg
Commits
2ba68dd0
Commit
2ba68dd0
authored
Oct 27, 2013
by
Anton Khirnov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
lavf: remove unreliable timestamp guessing heuristic
parent
f2521563
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
0 additions
and
34 deletions
+0
-34
avformat.h
libavformat/avformat.h
+0
-8
seek.c
libavformat/seek.c
+0
-3
seek.h
libavformat/seek.h
+0
-1
utils.c
libavformat/utils.c
+0
-22
No files found.
libavformat/avformat.h
View file @
2ba68dd0
...
...
@@ -730,14 +730,6 @@ typedef struct AVStream {
int
pts_wrap_bits
;
/**< number of bits in pts (used for wrapping control) */
// Timestamp generation support:
/**
* Timestamp corresponding to the last dts sync point.
*
* Initialized when AVCodecParserContext.dts_sync_point >= 0 and
* a DTS is received from the underlying container. Otherwise set to
* AV_NOPTS_VALUE by default.
*/
int64_t
reference_dts
;
int64_t
first_dts
;
int64_t
cur_dts
;
int64_t
last_IP_pts
;
...
...
libavformat/seek.c
View file @
2ba68dd0
...
...
@@ -428,13 +428,11 @@ AVParserState *ff_store_parser_state(AVFormatContext *s)
ss
->
parser
=
st
->
parser
;
ss
->
last_IP_pts
=
st
->
last_IP_pts
;
ss
->
cur_dts
=
st
->
cur_dts
;
ss
->
reference_dts
=
st
->
reference_dts
;
ss
->
probe_packets
=
st
->
probe_packets
;
st
->
parser
=
NULL
;
st
->
last_IP_pts
=
AV_NOPTS_VALUE
;
st
->
cur_dts
=
AV_NOPTS_VALUE
;
st
->
reference_dts
=
AV_NOPTS_VALUE
;
st
->
probe_packets
=
MAX_PROBE_PACKETS
;
}
...
...
@@ -467,7 +465,6 @@ void ff_restore_parser_state(AVFormatContext *s, AVParserState *state)
st
->
parser
=
ss
->
parser
;
st
->
last_IP_pts
=
ss
->
last_IP_pts
;
st
->
cur_dts
=
ss
->
cur_dts
;
st
->
reference_dts
=
ss
->
reference_dts
;
st
->
probe_packets
=
ss
->
probe_packets
;
}
...
...
libavformat/seek.h
View file @
2ba68dd0
...
...
@@ -33,7 +33,6 @@ typedef struct AVParserStreamState {
AVCodecParserContext
*
parser
;
int64_t
last_IP_pts
;
int64_t
cur_dts
;
int64_t
reference_dts
;
int
probe_packets
;
}
AVParserStreamState
;
...
...
libavformat/utils.c
View file @
2ba68dd0
...
...
@@ -771,25 +771,6 @@ static void compute_pkt_fields(AVFormatContext *s, AVStream *st,
pkt
->
dts
+=
offset
;
}
if
(
pc
&&
pc
->
dts_sync_point
>=
0
)
{
// we have synchronization info from the parser
int64_t
den
=
st
->
codec
->
time_base
.
den
*
(
int64_t
)
st
->
time_base
.
num
;
if
(
den
>
0
)
{
int64_t
num
=
st
->
codec
->
time_base
.
num
*
(
int64_t
)
st
->
time_base
.
den
;
if
(
pkt
->
dts
!=
AV_NOPTS_VALUE
)
{
// got DTS from the stream, update reference timestamp
st
->
reference_dts
=
pkt
->
dts
-
pc
->
dts_ref_dts_delta
*
num
/
den
;
pkt
->
pts
=
pkt
->
dts
+
pc
->
pts_dts_delta
*
num
/
den
;
}
else
if
(
st
->
reference_dts
!=
AV_NOPTS_VALUE
)
{
// compute DTS based on reference timestamp
pkt
->
dts
=
st
->
reference_dts
+
pc
->
dts_ref_dts_delta
*
num
/
den
;
pkt
->
pts
=
pkt
->
dts
+
pc
->
pts_dts_delta
*
num
/
den
;
}
if
(
pc
->
dts_sync_point
>
0
)
st
->
reference_dts
=
pkt
->
dts
;
// new reference
}
}
/* This may be redundant, but it should not hurt. */
if
(
pkt
->
dts
!=
AV_NOPTS_VALUE
&&
pkt
->
pts
!=
AV_NOPTS_VALUE
&&
pkt
->
pts
>
pkt
->
dts
)
presentation_delayed
=
1
;
...
...
@@ -1214,7 +1195,6 @@ void ff_read_frame_flush(AVFormatContext *s)
}
st
->
last_IP_pts
=
AV_NOPTS_VALUE
;
st
->
cur_dts
=
AV_NOPTS_VALUE
;
/* we set the current DTS to an unspecified origin */
st
->
reference_dts
=
AV_NOPTS_VALUE
;
st
->
probe_packets
=
MAX_PROBE_PACKETS
;
...
...
@@ -1868,7 +1848,6 @@ static void estimate_timings_from_pts(AVFormatContext *ic, int64_t old_offset)
st
=
ic
->
streams
[
i
];
st
->
cur_dts
=
st
->
first_dts
;
st
->
last_IP_pts
=
AV_NOPTS_VALUE
;
st
->
reference_dts
=
AV_NOPTS_VALUE
;
}
}
...
...
@@ -2618,7 +2597,6 @@ AVStream *avformat_new_stream(AVFormatContext *s, AVCodec *c)
st
->
last_IP_pts
=
AV_NOPTS_VALUE
;
for
(
i
=
0
;
i
<
MAX_REORDER_DELAY
+
1
;
i
++
)
st
->
pts_buffer
[
i
]
=
AV_NOPTS_VALUE
;
st
->
reference_dts
=
AV_NOPTS_VALUE
;
st
->
sample_aspect_ratio
=
(
AVRational
){
0
,
1
};
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment