1 /*
2 * MPEG2 transport stream (aka DVB) muxer
3 * Copyright (c) 2003 Fabrice Bellard
4 *
5 * This file is part of FFmpeg.
6 *
7 * FFmpeg is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
11 *
12 * FFmpeg is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with FFmpeg; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
33
34 #define PCR_TIME_BASE 27000000
35
36 /* write DVB SI sections */
37
38 /*********************************************/
39 /* mpegts section writer */
40
47
50 int sid;
/* service ID */
57
73
77
81
83
84 #define MPEGTS_FLAG_REEMIT_PAT_PMT 0x01
85 #define MPEGTS_FLAG_AAC_LATM 0x02
89
90 /* a PES packet header is generated every DEFAULT_PES_HEADER_FREQ packets */
91 #define DEFAULT_PES_HEADER_FREQ 16
92 #define DEFAULT_PES_PAYLOAD_SIZE ((DEFAULT_PES_HEADER_FREQ - 1) * 184 + 170)
93
95 { "mpegts_transport_stream_id", "Set transport_stream_id field.",
97 { "mpegts_original_network_id", "Set original_network_id field.",
99 { "mpegts_service_id", "Set service_id field.",
101 { "mpegts_pmt_start_pid", "Set the first pid of the PMT.",
103 { "mpegts_start_pid", "Set the first pid.",
105 {"mpegts_m2ts_mode", "Enable m2ts mode.",
109 { "pes_payload_size", "Minimum PES packet payload in bytes",
113 { "resend_headers", "Reemit PAT/PMT before writing the next packet",
116 { "latm", "Use LATM packetization for AAC",
119 // backward compatibility
120 { "resend_headers", "Reemit PAT/PMT before writing the next packet",
122 { "mpegts_copyts", "don't offset dts/pts",
124 { NULL },
125 };
126
132 };
133
134 /* NOTE: 4 bytes must be left at the end for the crc32 */
136 {
137 unsigned int crc;
139 const unsigned char *buf_ptr;
140 unsigned char *q;
141 int first,
b, len1, left;
142
144 buf[len - 4] = (crc >> 24) & 0xff;
145 buf[len - 3] = (crc >> 16) & 0xff;
146 buf[len - 2] = (crc >> 8) & 0xff;
147 buf[len - 1] = (crc) & 0xff;
148
149 /* send each packet */
151 while (len > 0) {
152 first = (buf == buf_ptr);
153 q = packet;
154 *q++ = 0x47;
156 if (first)
157 b |= 0x40;
160 s->
cc = (s->
cc + 1) & 0xf;
162 if (first)
163 *q++ = 0; /* 0 offset */
165 if (len1 > len)
167 memcpy(q, buf_ptr, len1);
168 q += len1;
169 /* add known padding data */
171 if (left > 0)
172 memset(q, 0xff, left);
173
175
176 buf_ptr += len1;
177 len -= len1;
178 }
179 }
180
182 {
184 q = *q_ptr;
185 *q++ = val >> 8;
187 *q_ptr = q;
188 }
189
191 int version,
int sec_num,
int last_sec_num,
193 {
195 unsigned int tot_len;
196 /* reserved_future_use field must be set to 1 for SDT */
198
199 tot_len = 3 + 5 + len + 4;
200 /* check if not too big */
201 if (tot_len > 1024)
203
204 q = section;
205 *q++ = tid;
206 put16(&q, flags | (len + 5 + 4));
/* 5 byte header + 4 byte CRC */
208 *q++ = 0xc1 | (version << 1); /* current_next_indicator = 1 */
209 *q++ = sec_num;
210 *q++ = last_sec_num;
211 memcpy(q, buf, len);
212
214 return 0;
215 }
216
217 /*********************************************/
218 /* mpegts writer */
219
220 #define DEFAULT_PROVIDER_NAME "FFmpeg"
221 #define DEFAULT_SERVICE_NAME "Service01"
222
223 /* we retransmit the SI info at this rate */
224 #define SDT_RETRANS_TIME 500
225 #define PAT_RETRANS_TIME 100
226 #define PCR_RETRANS_TIME 20
227
230 int pid;
/* stream associated pid */
241
243 {
247 int i;
248
254 }
256 data, q - data);
257 }
258
260 {
262 uint8_t data[1012], *q, *desc_length_ptr, *program_info_length_ptr;
263 int val, stream_type, i;
264
267
268 program_info_length_ptr = q;
269 q += 2; /* patched after */
270
271 /* put program info here */
272
273 val = 0xf000 | (q - program_info_length_ptr - 2);
274 program_info_length_ptr[0] = val >> 8;
275 program_info_length_ptr[1] =
val;
276
285 break;
288 break;
291 break;
294 break;
297 break;
301 break;
304 break;
307 break;
310 break;
311 default:
313 break;
314 }
315 *q++ = stream_type;
317 desc_length_ptr = q;
318 q += 2; /* patched after */
319
320 /* write optional descriptors here */
324 *q++=0x7a; // EAC3 descriptor see A038 DVB SI
325 *q++=1; // 1 byte, all flags sets to 0
326 *q++=0; // omit all fields...
327 }
329 *q++ = 0x05; /* MPEG-2 registration descriptor*/
330 *q++ = 4;
331 *q++ = 'B';
332 *q++ = 'S';
333 *q++ = 'S';
334 *q++ = 'D';
335 }
336
337 if (lang) {
338 char *p;
339 char *next = lang->
value;
341
342 *q++ = 0x0a; /* ISO 639 language descriptor */
343 len_ptr = q++;
344 *len_ptr = 0;
345
346 for (p = lang->
value; next && *len_ptr < 255 / 4 * 4; p = next + 1) {
347 next = strchr(p, ',');
348 if (strlen(p) != 3 && (!next || next != p + 3))
349 continue; /* not a 3-letter code */
350
351 *q++ = *p++;
352 *q++ = *p++;
353 *q++ = *p++;
354
356 *q++ = 0x01;
358 *q++ = 0x02;
360 *q++ = 0x03;
361 else
362 *q++ = 0; /* undefined type */
363
364 *len_ptr += 4;
365 }
366
367 if (*len_ptr == 0)
368 q -= 2; /* no language codes were written */
369 }
370 break;
372 {
373 const char *language;
374 language = lang && strlen(lang->
value)==3 ? lang->
value :
"eng";
375 *q++ = 0x59;
376 *q++ = 8;
377 *q++ = language[0];
378 *q++ = language[1];
379 *q++ = language[2];
380 *q++ = 0x10; /* normal subtitles (0x20 = if hearing pb) */
383 q += 4;
384 } else {
385 put16(&q, 1);
/* page id */
386 put16(&q, 1);
/* ancillary page id */
387 }
388 }
389 break;
392 *q++ = 0x05; /*MPEG-2 registration descriptor*/
393 *q++ = 4;
394 *q++ = 'd';
395 *q++ = 'r';
396 *q++ = 'a';
397 *q++ = 'c';
398 }
399 break;
402 *q++ = 0x05; /* MPEG-2 registration descriptor */
403 *q++ = 4;
404 *q++ = 'K';
405 *q++ = 'L';
406 *q++ = 'V';
407 *q++ = 'A';
408 }
409 break;
410 }
411
412 val = 0xf000 | (q - desc_length_ptr - 2);
413 desc_length_ptr[0] = val >> 8;
414 desc_length_ptr[1] =
val;
415 }
417 data, q - data);
418 }
419
420 /* NOTE: str == NULL is accepted for an empty string */
422 {
425
426 q = *q_ptr;
427 if (!str)
428 len = 0;
429 else
430 len = strlen(str);
432 memcpy(q, str, len);
434 *q_ptr = q;
435 }
436
438 {
441 uint8_t data[1012], *q, *desc_list_len_ptr, *desc_len_ptr;
442 int i, running_status, free_ca_mode,
val;
443
446 *q++ = 0xff;
450 *q++ = 0xfc | 0x00; /* currently no EIT info */
451 desc_list_len_ptr = q;
452 q += 2;
453 running_status = 4; /* running */
454 free_ca_mode = 0;
455
456 /* write only one descriptor for the service name and provider */
457 *q++ = 0x48;
458 desc_len_ptr = q;
459 q++;
460 *q++ = 0x01; /* digital television service */
463 desc_len_ptr[0] = q - desc_len_ptr - 1;
464
465 /* fill descriptor length */
466 val = (running_status << 13) | (free_ca_mode << 12) |
467 (q - desc_list_len_ptr - 2);
468 desc_list_len_ptr[0] = val >> 8;
469 desc_list_len_ptr[1] =
val;
470 }
472 data, q - data);
473 }
474
479 {
481
483 if (!service)
484 return NULL;
491 return service;
492 }
493
495 {
498 }
499
501 {
505 uint32_t tp_extra_header = pcr % 0x3fffffff;
506 tp_extra_header =
AV_RB32(&tp_extra_header);
508 sizeof(tp_extra_header));
509 }
510 }
511
513 {
517 }
518
520 {
526 int i, j;
527 const char *service_name;
529 int *pids;
531
532 if (s->
max_delay < 0)
/* Not set by the caller */
534
535 // round up to a whole number of TS packets
537
540 /* allocate a single DVB service */
542 if (!title)
550 service->
pmt.
cc = 15;
551
553 ts->
pat.
cc = 15;
// Initialize at 15 so that it wraps and be equal to 0 for the first packet we write
556
561
563 if (!pids)
565
566 /* assign pids to each stream */
571 if (!ts_st) {
573 goto fail;
574 }
579 goto fail;
580 }
582 /* MPEG pid values < 16 are reserved. Applications which set st->id in
583 * this range are assigned a calculated pid. */
586 }
else if (st->
id < 0x1FFF) {
588 } else {
591 goto fail;
592 }
596 goto fail;
597 }
598 for (j = 0; j < i; j++)
599 if (pids[j] == ts_st->
pid) {
602 goto fail;
603 }
604 pids[i] = ts_st->
pid;
609 /* update PCR pid by using the first video stream */
613 pcr_st = st;
614 }
617 {
622 goto fail;
623 }
627 goto fail;
628 }
631 if (ret != 0)
632 goto fail;
634 if (ret < 0)
635 goto fail;
636 }
637 }
638
640
641 /* if no video stream, use the first stream as PCR */
646 }
647
655
658 } else {
659 /* Arbitrary values, PAT/PMT will also be written on video key frames */
667 } else {
670 }
671 } else {
672 // max delta PCR 0.1s
675 }
678 }
679
680 // output a PCR as soon as possible
684
687 else
690 "sdt every %d, pat/pmt every %d pkts\n",
693
697 } else {
699 }
700 }
701
703
704 return 0;
705
706 fail:
712 if (ts_st) {
717 }
718 }
720 }
722 }
723
724 /* send SDT, PAT and PMT tables regulary */
726 {
728 int i;
729
733 }
739 }
740 }
741 }
742
744 {
745 int64_t pcr_low = pcr % 300, pcr_high = pcr / 300;
746
747 *buf++ = pcr_high >> 25;
748 *buf++ = pcr_high >> 17;
749 *buf++ = pcr_high >> 9;
750 *buf++ = pcr_high >> 1;
751 *buf++ = pcr_high << 7 | pcr_low >> 8 | 0x7e;
752 *buf++ = pcr_low;
753
754 return 6;
755 }
756
757 /* Write a single null transport stream packet */
759 {
762
764 *q++ = 0x47;
765 *q++ = 0x00 | 0x1f;
766 *q++ = 0xff;
767 *q++ = 0x10;
771 }
772
773 /* Write a single transport stream packet with a PCR and no payload */
775 {
780
782 *q++ = 0x47;
783 *q++ = ts_st->
pid >> 8;
785 *q++ = 0x20 | ts_st->
cc;
/* Adaptation only */
786 /* Continuity Count field does not increment (see 13818-1 section 2.4.3.3) */
788 *q++ = 0x10; /* Adaptation flags: PCR present */
789
790 /* PCR coded into 6 bytes */
792
793 /* stuffing bytes */
797 }
798
800 {
802
803 val = fourbits << 4 | (((pts >> 30) & 0x07) << 1) | 1;
805 val = (((pts >> 15) & 0x7fff) << 1) | 1;
806 *q++ = val >> 8;
808 val = (((pts) & 0x7fff) << 1) | 1;
809 *q++ = val >> 8;
811 }
812
813 /* Set an adaptation field flag in an MPEG-TS packet*/
815 {
816 // expect at least one flag to set
818
819 if ((pkt[3] & 0x20) == 0) {
820 // no AF yet, set adaptation field flag
821 pkt[3] |= 0x20;
822 // 1 byte length, no flags
823 pkt[4] = 1;
824 pkt[5] = 0;
825 }
826 pkt[5] |= flag;
827 }
828
829 /* Extend the adaptation field by size bytes */
831 {
832 // expect already existing adaptation field
835 }
836
837 /* Get a pointer to MPEG-TS payload (right after TS packet header) */
839 {
840 if (pkt[3] & 0x20)
841 return pkt + 5 + pkt[4];
842 else
843 return pkt + 4;
844 }
845
846 /* Add a pes header to the front of payload, and segment into an integer number of
847 * ts packets. The final ts packet is padded using an over-sized adaptation header
848 * to exactly fill the last ts packet.
849 * NOTE: 'payload' contains a complete PES payload.
850 */
852 const uint8_t *payload,
int payload_size,
853 int64_t pts, int64_t dts, int key)
854 {
859 int val, is_start,
len, header_len, write_pcr, private_code,
flags;
860 int afc_len, stuffing_len;
861 int64_t pcr = -1; /* avoid warning */
864
865 is_start = 1;
866 while (payload_size > 0) {
868 force_pat = 0;
869
870 write_pcr = 0;
872 if (ts->
mux_rate > 1 || is_start)
// VBR pcr period is based on frames
877 write_pcr = 1;
878 }
879 }
880
882 (dts -
get_pcr(ts, s->
pb)/300) > delay) {
883 /* pcr insert gets priority over null packet insert */
884 if (write_pcr)
886 else
888 continue; /* recalculate write_pcr and possibly retransmit si_info */
889 }
890
891 /* prepare packet header */
893 *q++ = 0x47;
894 val = (ts_st->
pid >> 8);
895 if (is_start)
896 val |= 0x40;
899 ts_st->
cc = (ts_st->
cc + 1) & 0xf;
900 *q++ = 0x10 | ts_st->
cc;
// payload indicator + CC
902 // set Random Access for key frames
904 write_pcr = 1;
907 }
908 if (write_pcr) {
911 // add 11, pcr references the last byte of program clock reference base
914 else
915 pcr = (dts - delay)*300;
920 }
921 if (is_start) {
922 int pes_extension = 0;
923 /* write PES header */
924 *q++ = 0x00;
925 *q++ = 0x00;
926 *q++ = 0x01;
927 private_code = 0;
930 *q++ = 0xfd;
931 } else
932 *q++ = 0xe0;
937 *q++ = 0xc0;
941 *q++ = 0xfd;
942 } else {
943 *q++ = 0xbd;
945 private_code = 0x20;
946 }
947 }
948 header_len = 0;
949 flags = 0;
951 header_len += 5;
952 flags |= 0x80;
953 }
955 header_len += 5;
956 flags |= 0x40;
957 }
960 /* set PES_extension_flag */
961 pes_extension = 1;
962 flags |= 0x01;
963
964 /*
965 * One byte for PES2 extension flag +
966 * one byte for extension length +
967 * one byte for extension id
968 */
969 header_len += 3;
970 }
971 /* for Blu-ray AC3 Audio the PES Extension flag should be as follow
972 * otherwise it will not play sound on blu-ray
973 */
977 /* set PES_extension_flag */
978 pes_extension = 1;
979 flags |= 0x01;
980 header_len += 3;
981 }
982 len = payload_size + header_len + 3;
983 if (private_code != 0)
984 len++;
985 if (len > 0xffff)
986 len = 0;
987 *q++ = len >> 8;
989 val = 0x80;
990 /* data alignment indicator is required for subtitle and data streams */
992 val |= 0x04;
995 *q++ = header_len;
998 q += 5;
999 }
1002 q += 5;
1003 }
1005 flags = 0x01; /* set PES_extension_flag_2 */
1007 *q++ = 0x80 | 0x01; /* marker bit + extension length */
1008 /*
1009 * Set the stream id extension flag bit to 0 and
1010 * write the extended stream id
1011 */
1012 *q++ = 0x00 | 0x60;
1013 }
1014 /* For Blu-ray AC3 Audio Setting extended flags */
1016 pes_extension &&
1018 flags = 0x01; /* set PES_extension_flag_2 */
1020 *q++ = 0x80 | 0x01; /* marker bit + extension length */
1021 *q++ = 0x00 | 0x71; /* for AC3 Audio (specifically on blue-rays) */
1022 }
1023
1024
1025 if (private_code != 0)
1026 *q++ = private_code;
1027 is_start = 0;
1028 }
1029 /* header size */
1030 header_len = q -
buf;
1031 /* data len */
1033 if (len > payload_size)
1034 len = payload_size;
1036 if (stuffing_len > 0) {
1037 /* add stuffing with AFC */
1038 if (buf[3] & 0x20) {
1039 /* stuffing already present: increase its size */
1040 afc_len = buf[4] + 1;
1041 memmove(buf + 4 + afc_len + stuffing_len,
1042 buf + 4 + afc_len,
1043 header_len - (4 + afc_len));
1044 buf[4] += stuffing_len;
1045 memset(buf + 4 + afc_len, 0xff, stuffing_len);
1046 } else {
1047 /* add stuffing */
1048 memmove(buf + 4 + stuffing_len, buf + 4, header_len - 4);
1049 buf[3] |= 0x20;
1050 buf[4] = stuffing_len - 1;
1051 if (stuffing_len >= 2) {
1052 buf[5] = 0x00;
1053 memset(buf + 6, 0xff, stuffing_len - 2);
1054 }
1055 }
1056 }
1059 payload_size -=
len;
1062 }
1065 }
1066
1068 {
1076 int64_t dts = pkt->
dts, pts = pkt->
pts;
1077
1079 av_log(s,
AV_LOG_WARNING,
"resend_headers option is deprecated, use -mpegts_flags resend_headers\n");
1082 }
1083
1088 }
1089
1092 pts += delay;
1094 dts += delay;
1095 }
1096
1100 }
1102
1105 uint32_t
state = -1;
1106
1110 "no startcode found, use the h264_mp4toannexb bitstream filter (-bsf h264_mp4toannexb)\n");
1112 }
1114 }
1115
1116 do {
1118 av_dlog(s,
"nal %d\n", state & 0x1f);
1119 } while (p < buf_end && (state & 0x1f) != 9 &&
1120 (state & 0x1f) != 5 && (state & 0x1f) != 1);
1121
1122 if ((state & 0x1f) != 9) { // AUD NAL
1124 if (!data)
1126 memcpy(data+6, pkt->
data, pkt->
size);
1128 data[4] = 0x09;
1129 data[5] = 0xf0; // any slice type (0xe) + rbsp stop one bit
1132 }
1134 if (pkt->
size < 2) {
1137 }
1141
1144 "and extradata missing\n");
1146 }
1147
1152 if (ret < 0)
1154
1156 if (ret < 0) {
1161 }
1165 }
1166 }
1167
1169 int i;
1179 }
1180 }
1181 }
1182
1188 }
1189
1192 // for video and subtitle, write a single pes packet
1195 return 0;
1196 }
1197
1202 }
1203
1206
1208
1209 return 0;
1210 }
1211
1213 {
1214 int i;
1215
1216 /* flush current packets */
1225 }
1226 }
1228 }
1229
1231 {
1232 if (!pkt) {
1234 return 1;
1235 } else {
1237 }
1238 }
1239
1241 {
1244 int i;
1245
1247
1255 }
1256 }
1257
1263 }
1265
1266 return 0;
1267 }
1268
1272 .mime_type = "video/x-mpegts",
1273 .extensions = "ts,m2t,m2ts,mts",
1281 .priv_class = &mpegts_muxer_class,
1282 };