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
90
91 /* a PES packet header is generated every DEFAULT_PES_HEADER_FREQ packets */
92 #define DEFAULT_PES_HEADER_FREQ 16
93 #define DEFAULT_PES_PAYLOAD_SIZE ((DEFAULT_PES_HEADER_FREQ - 1) * 184 + 170)
94
96 { "mpegts_transport_stream_id", "Set transport_stream_id field.",
98 { "mpegts_original_network_id", "Set original_network_id field.",
100 { "mpegts_service_id", "Set service_id field.",
102 { "mpegts_pmt_start_pid", "Set the first pid of the PMT.",
104 { "mpegts_start_pid", "Set the first pid.",
106 {"mpegts_m2ts_mode", "Enable m2ts mode.",
110 { "pes_payload_size", "Minimum PES packet payload in bytes",
114 { "resend_headers", "Reemit PAT/PMT before writing the next packet",
117 { "latm", "Use LATM packetization for AAC",
120 // backward compatibility
121 { "resend_headers", "Reemit PAT/PMT before writing the next packet",
123 { "mpegts_copyts", "don't offset dts/pts",
125 { "tables_version", "set PAT, PMT and SDT version",
127 { NULL },
128 };
129
135 };
136
137 /* NOTE: 4 bytes must be left at the end for the crc32 */
139 {
140 unsigned int crc;
142 const unsigned char *buf_ptr;
143 unsigned char *q;
144 int first,
b, len1, left;
145
147 buf[len - 4] = (crc >> 24) & 0xff;
148 buf[len - 3] = (crc >> 16) & 0xff;
149 buf[len - 2] = (crc >> 8) & 0xff;
150 buf[len - 1] = (crc) & 0xff;
151
152 /* send each packet */
154 while (len > 0) {
155 first = (buf == buf_ptr);
156 q = packet;
157 *q++ = 0x47;
159 if (first)
160 b |= 0x40;
163 s->
cc = (s->
cc + 1) & 0xf;
165 if (first)
166 *q++ = 0; /* 0 offset */
168 if (len1 > len)
170 memcpy(q, buf_ptr, len1);
171 q += len1;
172 /* add known padding data */
174 if (left > 0)
175 memset(q, 0xff, left);
176
178
179 buf_ptr += len1;
180 len -= len1;
181 }
182 }
183
185 {
187 q = *q_ptr;
188 *q++ = val >> 8;
190 *q_ptr = q;
191 }
192
194 int version,
int sec_num,
int last_sec_num,
196 {
198 unsigned int tot_len;
199 /* reserved_future_use field must be set to 1 for SDT */
201
202 tot_len = 3 + 5 + len + 4;
203 /* check if not too big */
204 if (tot_len > 1024)
206
207 q = section;
208 *q++ = tid;
209 put16(&q, flags | (len + 5 + 4));
/* 5 byte header + 4 byte CRC */
211 *q++ = 0xc1 | (version << 1); /* current_next_indicator = 1 */
212 *q++ = sec_num;
213 *q++ = last_sec_num;
214 memcpy(q, buf, len);
215
217 return 0;
218 }
219
220 /*********************************************/
221 /* mpegts writer */
222
223 #define DEFAULT_PROVIDER_NAME "FFmpeg"
224 #define DEFAULT_SERVICE_NAME "Service01"
225
226 /* we retransmit the SI info at this rate */
227 #define SDT_RETRANS_TIME 500
228 #define PAT_RETRANS_TIME 100
229 #define PCR_RETRANS_TIME 20
230
233 int pid;
/* stream associated pid */
244
246 {
250 int i;
251
257 }
259 data, q - data);
260 }
261
263 {
265 uint8_t data[1012], *q, *desc_length_ptr, *program_info_length_ptr;
266 int val, stream_type, i;
267
270
271 program_info_length_ptr = q;
272 q += 2; /* patched after */
273
274 /* put program info here */
275
276 val = 0xf000 | (q - program_info_length_ptr - 2);
277 program_info_length_ptr[0] = val >> 8;
278 program_info_length_ptr[1] =
val;
279
288 break;
291 break;
294 break;
297 break;
300 break;
304 break;
307 break;
310 break;
313 break;
314 default:
316 break;
317 }
318 *q++ = stream_type;
320 desc_length_ptr = q;
321 q += 2; /* patched after */
322
323 /* write optional descriptors here */
327 *q++=0x7a; // EAC3 descriptor see A038 DVB SI
328 *q++=1; // 1 byte, all flags sets to 0
329 *q++=0; // omit all fields...
330 }
332 *q++ = 0x05; /* MPEG-2 registration descriptor*/
333 *q++ = 4;
334 *q++ = 'B';
335 *q++ = 'S';
336 *q++ = 'S';
337 *q++ = 'D';
338 }
339
340 if (lang) {
341 char *p;
342 char *next = lang->
value;
344
345 *q++ = 0x0a; /* ISO 639 language descriptor */
346 len_ptr = q++;
347 *len_ptr = 0;
348
349 for (p = lang->
value; next && *len_ptr < 255 / 4 * 4; p = next + 1) {
350 next = strchr(p, ',');
351 if (strlen(p) != 3 && (!next || next != p + 3))
352 continue; /* not a 3-letter code */
353
354 *q++ = *p++;
355 *q++ = *p++;
356 *q++ = *p++;
357
359 *q++ = 0x01;
361 *q++ = 0x02;
363 *q++ = 0x03;
364 else
365 *q++ = 0; /* undefined type */
366
367 *len_ptr += 4;
368 }
369
370 if (*len_ptr == 0)
371 q -= 2; /* no language codes were written */
372 }
373 break;
375 {
376 const char *language;
377 language = lang && strlen(lang->
value)==3 ? lang->
value :
"eng";
378 *q++ = 0x59;
379 *q++ = 8;
380 *q++ = language[0];
381 *q++ = language[1];
382 *q++ = language[2];
383 *q++ = 0x10; /* normal subtitles (0x20 = if hearing pb) */
386 q += 4;
387 } else {
388 put16(&q, 1);
/* page id */
389 put16(&q, 1);
/* ancillary page id */
390 }
391 }
392 break;
395 *q++ = 0x05; /*MPEG-2 registration descriptor*/
396 *q++ = 4;
397 *q++ = 'd';
398 *q++ = 'r';
399 *q++ = 'a';
400 *q++ = 'c';
401 }
402 break;
405 *q++ = 0x05; /* MPEG-2 registration descriptor */
406 *q++ = 4;
407 *q++ = 'K';
408 *q++ = 'L';
409 *q++ = 'V';
410 *q++ = 'A';
411 }
412 break;
413 }
414
415 val = 0xf000 | (q - desc_length_ptr - 2);
416 desc_length_ptr[0] = val >> 8;
417 desc_length_ptr[1] =
val;
418 }
420 data, q - data);
421 }
422
423 /* NOTE: str == NULL is accepted for an empty string */
425 {
428
429 q = *q_ptr;
430 if (!str)
431 len = 0;
432 else
433 len = strlen(str);
435 memcpy(q, str, len);
437 *q_ptr = q;
438 }
439
441 {
444 uint8_t data[1012], *q, *desc_list_len_ptr, *desc_len_ptr;
445 int i, running_status, free_ca_mode,
val;
446
449 *q++ = 0xff;
453 *q++ = 0xfc | 0x00; /* currently no EIT info */
454 desc_list_len_ptr = q;
455 q += 2;
456 running_status = 4; /* running */
457 free_ca_mode = 0;
458
459 /* write only one descriptor for the service name and provider */
460 *q++ = 0x48;
461 desc_len_ptr = q;
462 q++;
463 *q++ = 0x01; /* digital television service */
466 desc_len_ptr[0] = q - desc_len_ptr - 1;
467
468 /* fill descriptor length */
469 val = (running_status << 13) | (free_ca_mode << 12) |
470 (q - desc_list_len_ptr - 2);
471 desc_list_len_ptr[0] = val >> 8;
472 desc_list_len_ptr[1] =
val;
473 }
475 data, q - data);
476 }
477
482 {
484
486 if (!service)
487 return NULL;
494 return service;
495 }
496
498 {
501 }
502
504 {
508 uint32_t tp_extra_header = pcr % 0x3fffffff;
509 tp_extra_header =
AV_RB32(&tp_extra_header);
511 sizeof(tp_extra_header));
512 }
513 }
514
516 {
520 }
521
523 {
529 int i, j;
530 const char *service_name;
532 int *pids;
534
535 if (s->
max_delay < 0)
/* Not set by the caller */
537
538 // round up to a whole number of TS packets
540
543 /* allocate a single DVB service */
545 if (!title)
553 service->
pmt.
cc = 15;
554
556 ts->
pat.
cc = 15;
// Initialize at 15 so that it wraps and be equal to 0 for the first packet we write
559
564
566 if (!pids)
568
569 /* assign pids to each stream */
574 if (!ts_st) {
576 goto fail;
577 }
582 goto fail;
583 }
585 /* MPEG pid values < 16 are reserved. Applications which set st->id in
586 * this range are assigned a calculated pid. */
589 }
else if (st->
id < 0x1FFF) {
591 } else {
594 goto fail;
595 }
599 goto fail;
600 }
601 for (j = 0; j < i; j++)
602 if (pids[j] == ts_st->
pid) {
605 goto fail;
606 }
607 pids[i] = ts_st->
pid;
612 /* update PCR pid by using the first video stream */
616 pcr_st = st;
617 }
620 {
625 goto fail;
626 }
630 goto fail;
631 }
634 if (ret != 0)
635 goto fail;
637 if (ret < 0)
638 goto fail;
639 }
640 }
641
643
644 /* if no video stream, use the first stream as PCR */
649 }
650
658
661 } else {
662 /* Arbitrary values, PAT/PMT will also be written on video key frames */
670 } else {
673 }
674 } else {
675 // max delta PCR 0.1s
678 }
681 }
682
683 // output a PCR as soon as possible
687
690 else
693 "sdt every %d, pat/pmt every %d pkts\n",
696
700 } else {
702 }
703 }
704
706
707 return 0;
708
709 fail:
715 if (ts_st) {
720 }
721 }
723 }
725 }
726
727 /* send SDT, PAT and PMT tables regulary */
729 {
731 int i;
732
736 }
742 }
743 }
744 }
745
747 {
748 int64_t pcr_low = pcr % 300, pcr_high = pcr / 300;
749
750 *buf++ = pcr_high >> 25;
751 *buf++ = pcr_high >> 17;
752 *buf++ = pcr_high >> 9;
753 *buf++ = pcr_high >> 1;
754 *buf++ = pcr_high << 7 | pcr_low >> 8 | 0x7e;
755 *buf++ = pcr_low;
756
757 return 6;
758 }
759
760 /* Write a single null transport stream packet */
762 {
765
767 *q++ = 0x47;
768 *q++ = 0x00 | 0x1f;
769 *q++ = 0xff;
770 *q++ = 0x10;
774 }
775
776 /* Write a single transport stream packet with a PCR and no payload */
778 {
783
785 *q++ = 0x47;
786 *q++ = ts_st->
pid >> 8;
788 *q++ = 0x20 | ts_st->
cc;
/* Adaptation only */
789 /* Continuity Count field does not increment (see 13818-1 section 2.4.3.3) */
791 *q++ = 0x10; /* Adaptation flags: PCR present */
792
793 /* PCR coded into 6 bytes */
795
796 /* stuffing bytes */
800 }
801
803 {
805
806 val = fourbits << 4 | (((pts >> 30) & 0x07) << 1) | 1;
808 val = (((pts >> 15) & 0x7fff) << 1) | 1;
809 *q++ = val >> 8;
811 val = (((pts) & 0x7fff) << 1) | 1;
812 *q++ = val >> 8;
814 }
815
816 /* Set an adaptation field flag in an MPEG-TS packet*/
818 {
819 // expect at least one flag to set
821
822 if ((pkt[3] & 0x20) == 0) {
823 // no AF yet, set adaptation field flag
824 pkt[3] |= 0x20;
825 // 1 byte length, no flags
826 pkt[4] = 1;
827 pkt[5] = 0;
828 }
829 pkt[5] |= flag;
830 }
831
832 /* Extend the adaptation field by size bytes */
834 {
835 // expect already existing adaptation field
838 }
839
840 /* Get a pointer to MPEG-TS payload (right after TS packet header) */
842 {
843 if (pkt[3] & 0x20)
844 return pkt + 5 + pkt[4];
845 else
846 return pkt + 4;
847 }
848
849 /* Add a pes header to the front of payload, and segment into an integer number of
850 * ts packets. The final ts packet is padded using an over-sized adaptation header
851 * to exactly fill the last ts packet.
852 * NOTE: 'payload' contains a complete PES payload.
853 */
855 const uint8_t *payload,
int payload_size,
856 int64_t pts, int64_t dts, int key)
857 {
862 int val, is_start,
len, header_len, write_pcr, private_code,
flags;
863 int afc_len, stuffing_len;
864 int64_t pcr = -1; /* avoid warning */
867
868 is_start = 1;
869 while (payload_size > 0) {
871 force_pat = 0;
872
873 write_pcr = 0;
875 if (ts->
mux_rate > 1 || is_start)
// VBR pcr period is based on frames
880 write_pcr = 1;
881 }
882 }
883
885 (dts -
get_pcr(ts, s->
pb)/300) > delay) {
886 /* pcr insert gets priority over null packet insert */
887 if (write_pcr)
889 else
891 continue; /* recalculate write_pcr and possibly retransmit si_info */
892 }
893
894 /* prepare packet header */
896 *q++ = 0x47;
897 val = (ts_st->
pid >> 8);
898 if (is_start)
899 val |= 0x40;
902 ts_st->
cc = (ts_st->
cc + 1) & 0xf;
903 *q++ = 0x10 | ts_st->
cc;
// payload indicator + CC
905 // set Random Access for key frames
907 write_pcr = 1;
910 }
911 if (write_pcr) {
914 // add 11, pcr references the last byte of program clock reference base
917 else
918 pcr = (dts - delay)*300;
923 }
924 if (is_start) {
925 int pes_extension = 0;
926 /* write PES header */
927 *q++ = 0x00;
928 *q++ = 0x00;
929 *q++ = 0x01;
930 private_code = 0;
933 *q++ = 0xfd;
934 } else
935 *q++ = 0xe0;
940 *q++ = 0xc0;
944 *q++ = 0xfd;
945 } else {
946 *q++ = 0xbd;
948 private_code = 0x20;
949 }
950 }
951 header_len = 0;
952 flags = 0;
954 header_len += 5;
955 flags |= 0x80;
956 }
958 header_len += 5;
959 flags |= 0x40;
960 }
963 /* set PES_extension_flag */
964 pes_extension = 1;
965 flags |= 0x01;
966
967 /*
968 * One byte for PES2 extension flag +
969 * one byte for extension length +
970 * one byte for extension id
971 */
972 header_len += 3;
973 }
974 /* for Blu-ray AC3 Audio the PES Extension flag should be as follow
975 * otherwise it will not play sound on blu-ray
976 */
980 /* set PES_extension_flag */
981 pes_extension = 1;
982 flags |= 0x01;
983 header_len += 3;
984 }
985 len = payload_size + header_len + 3;
986 if (private_code != 0)
987 len++;
988 if (len > 0xffff)
989 len = 0;
990 *q++ = len >> 8;
992 val = 0x80;
993 /* data alignment indicator is required for subtitle and data streams */
995 val |= 0x04;
998 *q++ = header_len;
1001 q += 5;
1002 }
1005 q += 5;
1006 }
1008 flags = 0x01; /* set PES_extension_flag_2 */
1010 *q++ = 0x80 | 0x01; /* marker bit + extension length */
1011 /*
1012 * Set the stream id extension flag bit to 0 and
1013 * write the extended stream id
1014 */
1015 *q++ = 0x00 | 0x60;
1016 }
1017 /* For Blu-ray AC3 Audio Setting extended flags */
1019 pes_extension &&
1021 flags = 0x01; /* set PES_extension_flag_2 */
1023 *q++ = 0x80 | 0x01; /* marker bit + extension length */
1024 *q++ = 0x00 | 0x71; /* for AC3 Audio (specifically on blue-rays) */
1025 }
1026
1027
1028 if (private_code != 0)
1029 *q++ = private_code;
1030 is_start = 0;
1031 }
1032 /* header size */
1033 header_len = q -
buf;
1034 /* data len */
1036 if (len > payload_size)
1037 len = payload_size;
1039 if (stuffing_len > 0) {
1040 /* add stuffing with AFC */
1041 if (buf[3] & 0x20) {
1042 /* stuffing already present: increase its size */
1043 afc_len = buf[4] + 1;
1044 memmove(buf + 4 + afc_len + stuffing_len,
1045 buf + 4 + afc_len,
1046 header_len - (4 + afc_len));
1047 buf[4] += stuffing_len;
1048 memset(buf + 4 + afc_len, 0xff, stuffing_len);
1049 } else {
1050 /* add stuffing */
1051 memmove(buf + 4 + stuffing_len, buf + 4, header_len - 4);
1052 buf[3] |= 0x20;
1053 buf[4] = stuffing_len - 1;
1054 if (stuffing_len >= 2) {
1055 buf[5] = 0x00;
1056 memset(buf + 6, 0xff, stuffing_len - 2);
1057 }
1058 }
1059 }
1062 payload_size -=
len;
1065 }
1068 }
1069
1071 {
1079 int64_t dts = pkt->
dts, pts = pkt->
pts;
1080
1082 av_log(s,
AV_LOG_WARNING,
"resend_headers option is deprecated, use -mpegts_flags resend_headers\n");
1085 }
1086
1091 }
1092
1095 pts += delay;
1097 dts += delay;
1098 }
1099
1103 }
1105
1108 uint32_t
state = -1;
1109
1113 "no startcode found, use the h264_mp4toannexb bitstream filter (-bsf h264_mp4toannexb)\n");
1115 }
1117 }
1118
1119 do {
1121 av_dlog(s,
"nal %d\n", state & 0x1f);
1122 } while (p < buf_end && (state & 0x1f) != 9 &&
1123 (state & 0x1f) != 5 && (state & 0x1f) != 1);
1124
1125 if ((state & 0x1f) != 9) { // AUD NAL
1127 if (!data)
1129 memcpy(data+6, pkt->
data, pkt->
size);
1131 data[4] = 0x09;
1132 data[5] = 0xf0; // any slice type (0xe) + rbsp stop one bit
1135 }
1137 if (pkt->
size < 2) {
1140 }
1144
1147 "and extradata missing\n");
1149 }
1150
1155 if (ret < 0)
1157
1159 if (ret < 0) {
1164 }
1168 }
1169 }
1170
1172 int i;
1182 }
1183 }
1184 }
1185
1191 }
1192
1195 // for video and subtitle, write a single pes packet
1198 return 0;
1199 }
1200
1205 }
1206
1209
1211
1212 return 0;
1213 }
1214
1216 {
1217 int i;
1218
1219 /* flush current packets */
1228 }
1229 }
1231 }
1232
1234 {
1235 if (!pkt) {
1237 return 1;
1238 } else {
1240 }
1241 }
1242
1244 {
1247 int i;
1248
1250
1258 }
1259 }
1260
1266 }
1268
1269 return 0;
1270 }
1271
1275 .mime_type = "video/x-mpegts",
1276 .extensions = "ts,m2t,m2ts,mts",
1284 .priv_class = &mpegts_muxer_class,
1285 };