1 /*
2 * This file is part of FFmpeg.
3 *
4 * FFmpeg is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
8 *
9 * FFmpeg is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with FFmpeg; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18
22 {
24
26
27 #ifdef READ
29 #endif
30
32 fixed(8, ff_byte, 0xff);
33
34 return 0;
35 }
36
40 {
42
43 HEADER(
"User Data Registered ITU-T T.35");
44
45 u(8, itu_t_t35_country_code, 0x00, 0xff);
48 else {
49 u(8, itu_t_t35_country_code_extension_byte, 0x00, 0xff);
51 }
52
53 #ifdef READ
54 if (
state->payload_size <
i) {
56 "Invalid SEI user data registered payload.\n");
58 }
60 #endif
61
64 xu(8, itu_t_t35_payload_byte[], current->
data[j], 0x00, 0xff, 1,
i + j);
65
66 return 0;
67 }
68
72 {
74
75 HEADER(
"User Data Unregistered");
76
77 #ifdef READ
78 if (
state->payload_size < 16) {
80 "Invalid SEI user data unregistered payload.\n");
82 }
84 #endif
85
86 for (
i = 0;
i < 16;
i++)
87 us(8, uuid_iso_iec_11578[
i], 0x00, 0xff, 1,
i);
88
90
92 xu(8, user_data_payload_byte[
i], current->
data[
i], 0x00, 0xff, 1,
i);
93
94 return 0;
95 }
96
100 {
101 int err;
102
103 HEADER(
"Frame Packing Arrangement");
104
106 flag(fp_arrangement_cancel_flag);
108 u(7, fp_arrangement_type, 3, 5);
109 flag(fp_quincunx_sampling_flag);
110 u(6, fp_content_interpretation_type, 0, 2);
111 flag(fp_spatial_flipping_flag);
112 flag(fp_frame0_flipped_flag);
113 flag(fp_field_views_flag);
114 flag(fp_current_frame_is_frame0_flag);
115 flag(fp_frame0_self_contained_flag);
116 flag(fp_frame1_self_contained_flag);
118 ub(4, fp_frame0_grid_position_x);
119 ub(4, fp_frame0_grid_position_y);
120 ub(4, fp_frame1_grid_position_x);
121 ub(4, fp_frame1_grid_position_y);
122 }
123 fixed(8, fp_arrangement_reserved_byte, 0);
124 flag(fp_arrangement_persistence_flag);
125 }
126 flag(fp_upsampled_aspect_ratio_flag);
127
128 return 0;
129 }
130
135 {
137
138 HEADER(
"Decoded Picture Hash");
139
140 u(8, dph_sei_hash_type, 0, 2);
141 flag(dph_sei_single_component_flag);
142 ub(7, dph_sei_reserved_zero_7bits);
143
145 c_idx++) {
147 for (
i = 0;
i < 16;
i++)
148 us(8, dph_sei_picture_md5[c_idx][
i], 0x00, 0xff, 2, c_idx,
i);
150 us(16, dph_sei_picture_crc[c_idx], 0x0000, 0xffff, 1, c_idx);
152 us(32, dph_sei_picture_checksum[c_idx], 0x00000000, 0xffffffff, 1,
153 c_idx);
154 }
155 }
156 return 0;
157 }
158
163 {
165
166 HEADER(
"Mastering Display Colour Volume");
167
168 for (
c = 0;
c < 3;
c++) {
169 ubs(16, display_primaries_x[
c], 1,
c);
170 ubs(16, display_primaries_y[
c], 1,
c);
171 }
172
173 ub(16, white_point_x);
174 ub(16, white_point_y);
175
176 ub(32, max_display_mastering_luminance);
177 ub(32, min_display_mastering_luminance);
178
179 return 0;
180 }
181
185 {
186 int err;
187
188 HEADER(
"Content Light Level Information");
189
190 ub(16, max_content_light_level);
191 ub(16, max_pic_average_light_level);
192
193 return 0;
194 }
195
200 {
201 int err;
202
203 HEADER(
"Alternative Transfer Characteristics");
204
205 ub(8, preferred_transfer_characteristics);
206
207 return 0;
208 }
209
214 {
215 static const uint16_t max_ambient_light_value = 50000;
216 int err;
217
218 HEADER(
"Ambient Viewing Environment");
219
221 u(16, ambient_light_x, 0, max_ambient_light_value);
222 u(16, ambient_light_y, 0, max_ambient_light_value);
223
224 return 0;
225 }
226
229 {
232
236 .payload_type = current->payload_type,
237 .payload_size = current->payload_size,
238 .extension_present = current->extension_bit_length > 0,
239 };
240 int start_position, current_position, bits_written;
241
242 #ifdef READ
244 #endif
245
247
249
251 bits_written = current_position - start_position;
252
254 bits_written < 8 * current->payload_size) {
256
257 #ifdef READ
260
261 bits_left = 8 * current->payload_size - bits_written;
266 // The trailing bits must contain a bit_equal_to_one, so
267 // they can't all be zero.
269 }
271 current->extension_bit_length =
273 #endif
274
275 if (current->extension_bit_length > 0) {
277 (current->extension_bit_length + 7) / 8);
278
279 bits_left = current->extension_bit_length;
282 xu(length, reserved_payload_extension_data,
283 current->extension_data[
i],
286 }
287 }
288
289 fixed(1, bit_equal_to_one, 1);
291 fixed(1, bit_equal_to_zero, 0);
292 }
293
294 #ifdef WRITE
295 current->payload_size = (
put_bits_count(rw) - start_position) / 8;
296 #endif
297 } else {
299
300 #ifdef READ
301 allocate(current->payload_ref, current->payload_size);
302 current->payload = current->payload_ref;
303 #else
304 allocate(current->payload, current->payload_size);
305 #endif
306 data = current->payload;
307
308 for (
i = 0;
i < current->payload_size;
i++)
309 xu(8, payload_byte[
i],
data[
i], 0, 255, 1,
i);
310 }
311
312 return 0;
313 }
314
317 {
319 int err, k;
320
321 #ifdef READ
322 for (k = 0;; k++) {
323 uint32_t payload_type = 0;
324 uint32_t payload_size = 0;
327
329 fixed(8, ff_byte, 0xff);
330 payload_type += 255;
331 }
332 xu(8, last_payload_type_byte,
tmp, 0, 254, 0);
334
336 fixed(8, ff_byte, 0xff);
337 payload_size += 255;
338 }
339 xu(8, last_payload_size_byte,
tmp, 0, 254, 0);
341
342 // There must be space remaining for both the payload and
343 // the trailing bits on the SEI NAL unit.
346 "Invalid SEI message: payload_size too large "
347 "(%"PRIu32" bytes).\n", payload_size);
349 }
353
355 message = ¤t->messages[k];
356
357 message->payload_type = payload_type;
358 message->payload_size = payload_size;
359
361
363
365 break;
366 }
367 #else
368 for (k = 0; k < current->nb_messages; k++) {
372
373 message = ¤t->messages[k];
374
375 // We write the payload twice in order to find the size. Trace
376 // output is switched off for the first write.
377 trace =
ctx->trace_enable;
378 ctx->trace_enable = 0;
379
380 start_state = *rw;
381 for (
i = 0;
i < 2;
i++) {
382 *rw = start_state;
383
386 fixed(8, ff_byte, 0xff);
388 }
389 xu(8, last_payload_type_byte,
tmp, 0, 254, 0);
390
393 fixed(8, ff_byte, 0xff);
395 }
396 xu(8, last_payload_size_byte,
tmp, 0, 254, 0);
397
399 ctx->trace_enable = trace;
400 if (err < 0)
401 return err;
402 }
403 }
404 #endif
405
406 return 0;
407 }