[FFmpeg-cvslog] cbs_h265: Fix Time Code SEI syntax
Andreas Rheinhardt
git at videolan.org
Sun Dec 2 21:53:56 EET 2018
ffmpeg | branch: master | Andreas Rheinhardt <andreas.rheinhardt at googlemail.com> | Sat Dec 1 08:52:54 2018 +0100| [9f588ba5ca283c6b0b0b744085275e6253ba5cc6] | committer: Mark Thompson
cbs_h265: Fix Time Code SEI syntax
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at googlemail.com>
Signed-off-by: Mark Thompson <sw at jkqxz.net>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=9f588ba5ca283c6b0b0b744085275e6253ba5cc6
---
libavcodec/cbs_h265_syntax_template.c | 56 +++++++++++++++++++----------------
1 file changed, 30 insertions(+), 26 deletions(-)
diff --git a/libavcodec/cbs_h265_syntax_template.c b/libavcodec/cbs_h265_syntax_template.c
index 0a430df23a..f1e1bb0e7e 100644
--- a/libavcodec/cbs_h265_syntax_template.c
+++ b/libavcodec/cbs_h265_syntax_template.c
@@ -1955,36 +1955,40 @@ static int FUNC(sei_time_code)(CodedBitstreamContext *ctx, RWContext *rw,
u(2, num_clock_ts, 1, 3);
for (i = 0; i < current->num_clock_ts; i++) {
- flags(units_field_based_flag[i], 1, i);
- us(5, counting_type[i], 0, 6, 1, i);
- flags(full_timestamp_flag[i], 1, i);
- flags(discontinuity_flag[i], 1, i);
- flags(cnt_dropped_flag[i], 1, i);
-
- us(9, n_frames[i], 0, MAX_UINT_BITS(9), 1, i);
-
- if (current->full_timestamp_flag[i]) {
- us(6, seconds_value[i], 0, 59, 1, i);
- us(6, minutes_value[i], 0, 59, 1, i);
- us(5, hours_value[i], 0, 23, 1, i);
- } else {
- flags(seconds_flag[i], 1, i);
- if (current->seconds_flag[i]) {
+ flags(clock_timestamp_flag[i], 1, i);
+
+ if (current->clock_timestamp_flag[i]) {
+ flags(units_field_based_flag[i], 1, i);
+ us(5, counting_type[i], 0, 6, 1, i);
+ flags(full_timestamp_flag[i], 1, i);
+ flags(discontinuity_flag[i], 1, i);
+ flags(cnt_dropped_flag[i], 1, i);
+
+ us(9, n_frames[i], 0, MAX_UINT_BITS(9), 1, i);
+
+ if (current->full_timestamp_flag[i]) {
us(6, seconds_value[i], 0, 59, 1, i);
- flags(minutes_flag[i], 1, i);
- if (current->minutes_flag[i]) {
- us(6, minutes_value[i], 0, 59, 1, i);
- flags(hours_flag[i], 1, i);
- if (current->hours_flag[i])
- us(5, hours_value[i], 0, 23, 1, i);
+ us(6, minutes_value[i], 0, 59, 1, i);
+ us(5, hours_value[i], 0, 23, 1, i);
+ } else {
+ flags(seconds_flag[i], 1, i);
+ if (current->seconds_flag[i]) {
+ us(6, seconds_value[i], 0, 59, 1, i);
+ flags(minutes_flag[i], 1, i);
+ if (current->minutes_flag[i]) {
+ us(6, minutes_value[i], 0, 59, 1, i);
+ flags(hours_flag[i], 1, i);
+ if (current->hours_flag[i])
+ us(5, hours_value[i], 0, 23, 1, i);
+ }
}
}
- }
- us(5, time_offset_length[i], 0, 31, 1, i);
- if (current->time_offset_length[i] > 0)
- us(current->time_offset_length[i], time_offset_value[i],
- 0, MAX_UINT_BITS(current->time_offset_length[i]), 1, i);
+ us(5, time_offset_length[i], 0, 31, 1, i);
+ if (current->time_offset_length[i] > 0)
+ us(current->time_offset_length[i], time_offset_value[i],
+ 0, MAX_UINT_BITS(current->time_offset_length[i]), 1, i);
+ }
}
return 0;
More information about the ffmpeg-cvslog
mailing list