annotate src/tssplitter_lite.c @ 149:a9f60d56d673

Fix DLNA problem
author Naoya OYAMA <naoya.oyama@gmail.com>
date Sat, 25 Aug 2012 11:10:24 +0900
parents 066f33b2213a
children 30e91361506a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
1 /* -*- tab-width: 4; indent-tabs-mode: t -*- */
117
ac39bb18136e commit test.
naoyan@johnstown.minaminoshima.org
parents: 112
diff changeset
2 /* vim: set ts=4 sts=4 sw=4 noexpandtab number : */
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
3 /* tssplitter_lite.c -- split TS stream.
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
4
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
5 Copyright 2009 querulous
143
e72dd5e8d53f Number of samples per ADTS packet instead of 1000 and 1024.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 124
diff changeset
6 Copyright 2010-2012 Naoya OYAMA <naoya.oyama@gmail.com>
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
7
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
8 This program is free software: you can redistribute it and/or modify
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
9 it under the terms of the GNU General Public License as published by
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
10 the Free Software Foundation, either version 3 of the License, or
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
11 (at your option) any later version.
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
12
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
13 This program is distributed in the hope that it will be useful,
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
16 GNU General Public License for more details.
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
17
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
20
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
21 #include <stdlib.h>
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
22 #include <stdio.h>
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
23 #include <string.h>
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
24 #include <ctype.h>
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
25
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
26 #include <fcntl.h>
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
27 #include <sys/stat.h>
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
28 #include <math.h>
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
29 #include <time.h>
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
30 #include "decoder.h"
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
31 #include "recpt1.h"
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
32 #include "tssplitter_lite.h"
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
33 #include "ushare.h"
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
34 #include "metadata.h"
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
35
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
36 #ifndef AV_RB32
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
37 #define AV_RB32(x) ((((const uint8_t*)(x))[0] << 24) | \
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
38 (((const uint8_t*)(x))[1] << 16) | \
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
39 (((const uint8_t*)(x))[2] << 8) | \
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
40 ((const uint8_t*)(x))[3])
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
41 #endif
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
42
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
43 #ifndef AV_RB24
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
44 #define AV_RB24(x) ((((const uint8_t*)(x))[0] << 16) | \
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
45 (((const uint8_t*)(x))[1] << 8) | \
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
46 ((const uint8_t*)(x))[2])
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
47 #endif
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
48
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
49 #ifndef AV_RB16
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
50 #define AV_RB16(x) ((((const uint8_t*)(x))[0] << 8) | ((const uint8_t*)(x))[1])
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
51 #endif
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
52 #define MAX_SERVICE_ID ( 0xffff )
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
53 #define LIST_DECIMAL "0123456789"
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
54 #define TSS_STREAM_TYPE_AUDIO (1)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
55 #define TSS_STREAM_TYPE_VIDEO (2)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
56
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
57 //global
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
58 extern struct ushare_t *ut;
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
59
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
60 /* prototypes */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
61 static int ReadTs(splitter *sp, ARIB_STD_B25_BUFFER *sbuf);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
62 static int AnalyzePat(splitter *sp, unsigned char *buf);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
63 static int RecreatePat(splitter *sp, unsigned char *buf, int *pos);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
64 static char** AnalyzeSid(char *sid);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
65 static int AnalyzePmt(splitter *sp, const uint8_t *buf, int sid, const int size);
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
66 static int GetCrc32(unsigned char *data, int len);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
67 static int GetPid(unsigned char *data);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
68 static int parse_tot( const unsigned char* packet, time_t *t );
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
69 //void dump_packet( const uint8_t *packet );
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
70 static int parse_pcr(int64_t *ppcr_high, int *ppcr_low, const uint8_t *packet);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
71 static int DemuxTs(const uint8_t *packet, splitter *sp, const int pid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
72 //static int pes2es(splitpesbuf_t *pesbuf, splitesbuf_t *esbuf, const int pid, int random_access_indicator);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
73 static int pes2es(splitpesbuf_t *pesbuf, splitesbuf_t *esbuf, const int pid);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
74 static int64_t get_pts(const uint8_t *p);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
75 //void search_mpeg_system_header(const uint8_t *p);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
76 static int esbuf_write(splitesbuf_t *esbuf);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
77 static int pesbuf_packet_start_code_prefix(splitpesbuf_t *pesbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
78 static int pesbuf_empty(splitpesbuf_t *pesbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
79 void pesbuf_clear(splitpesbuf_t *pesbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
80 static int pesbuf_add(splitpesbuf_t *pesbuf, const uint8_t *data, int len);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
81 static int esbuf_empty(splitesbuf_t *esbuf);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
82 void esbuf_clear(splitesbuf_t *esbuf, uint64_t pts, uint64_t dts);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
83 static int esbuf_add(splitesbuf_t *esbuf, const uint8_t *data, int len);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
84 static int get_pmt_version(const uint8_t *p);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
85 static int next_adts_start_code(splitesbuf_t *esbuf, int offset);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
86 static int is_video_stream(const int pid, splitesbuf_t *esbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
87 static int is_audio_stream(const int pid, splitesbuf_t *esbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
88 static int AnalyzeAdifHeader(splitesbuf_t *esbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
89 static int get_adif_id(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
90 static int get_adif_layer(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
91 static int get_adif_protection_absent(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
92 static int get_adif_profile(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
93 static int get_adif_sampling_frequency_index(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
94 static int get_adif_private_bit(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
95 static int get_adif_channel_configuration(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
96 static int get_adif_original_copy(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
97 static int get_adif_home(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
98 static int get_adif_copyright_idication_bit(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
99 static int get_adif_copyright_idication_start(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
100 static int get_adif_aac_frame_length(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
101 static int get_adts_buffer_fullness(uint8_t *p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
102 static int get_adts_no_raw_data_blocks_in_frame(uint8_t *p);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
103 //static int search_pmt_program(splitter *sp, int pid);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
104 static int search_gop_start_code(splitesbuf_t *esbuf);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
105 static int creat_es_file(splitter *sp, int sid, int pid, int av_flag);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
106 static time_t cue2time(char *yyyymmddhhmiss);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
107 static int search_pcr_pid(splitter *sp, int pid);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
108
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
109 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
110 * サービスID解析
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
111 */
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
112 static char** AnalyzeSid(
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
113 char* sid) // [in] サービスID(カンマ区切りテキスト)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
114 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
115 int i = 0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
116 char** sid_list = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
117 char* p;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
118 int CommaNum = 0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
119
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
120 /* sid は次の形式の引数を許容する */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
121 /* 指定無し */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
122 /* SID[0] */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
123 /* SID[0],SID[1],...,SID[N-1],SID[N] */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
124
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
125 /*カンマの数を数える*/
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
126 p = sid;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
127 while(*p != '\0')
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
128 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
129 if( *p == C_CHAR_COMMA ){
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
130 CommaNum++;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
131 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
132 p++;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
133 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
134
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
135 /* sid_listの数はカンマの数+2(NULL止めするから) */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
136 sid_list = malloc(sizeof(char*)*(CommaNum+2));
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
137 if ( sid_list == NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
138 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
139 fprintf(stderr, "AnalyzeSid() malloc error.\n");
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
140 return NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
141 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
142
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
143 /* sidが空である場合 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
144 p = sid;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
145 if ( strlen(p) == 0 )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
146 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
147 sid_list[0] = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
148 return sid_list;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
149 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
150
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
151 /* カンマ無し */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
152 if ( CommaNum == 0 )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
153 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
154 sid_list[0] = sid;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
155 sid_list[1] = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
156 return sid_list;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
157 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
158
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
159 /* カンマ区切りで複数指定時 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
160 i=0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
161 p = sid;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
162 /* 文字列端に到達するか、カンマ数が数えた数に達したら終了 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
163 while((*p != '\0') || i < CommaNum)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
164 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
165 /* 現在の処理位置をsid_list[i]にセット */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
166 /* このタイミングの p は
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
167 * ・sid先頭
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
168 * ・[,]の次の文字
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
169 * いずれかであるので p を sid_list[i] に代入してよい
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
170 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
171 sid_list[i] = p;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
172 i++;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
173
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
174 /* 最初に現れる[,]をNULL文字で置換する */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
175 p = strchr(p, C_CHAR_COMMA);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
176 if ( p == NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
177 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
178 /* カンマが見つからない場合は最後の処理対象なので終了 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
179 break;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
180 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
181 *p = '\0';
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
182 /* 処理位置をNULLで置換した文字の次の位置に設定する */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
183 p++;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
184 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
185
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
186 /* 最後のsid_list[n]はNULLポインタで止める */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
187 sid_list[i] = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
188
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
189 i=0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
190 while( sid_list[i] != NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
191 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
192 i++;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
193 }
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
194 #if 0
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
195 for(i=0; sid_list[i] != NULL; i++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
196 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
197 printf("sid_list[%d]=[%s].\n",i, sid_list[i]);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
198 }
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
199 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
200 return sid_list;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
201 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
202
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
203 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
204 * 初期化処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
205 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
206 splitter* split_startup(
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
207 char *sid, // [in] サービスID(引数で指定した文字列)
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
208 char *filename, // [in] 出力ESファイル名(引数で指定したファイル名)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
209 char *arg_cue // [in] 録画開始時刻(引数で指定した文字列 YYYYMMDDHHMISS)
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
210 )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
211 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
212 splitter* sp;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
213 int i;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
214 sp = malloc(sizeof(splitter));
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
215 if ( sp == NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
216 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
217 fprintf(stderr, "split_startup malloc error.\n");
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
218 return NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
219 }
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
220 sp->program = malloc( sizeof(program_t) * MAX_SERVICE_ID );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
221 if ( sp->program == NULL )
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
222 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
223 fprintf(stderr, "split_startup malloc error.\n");
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
224 return NULL;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
225 }
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
226 memset(sp->pids, 0, sizeof(sp->pids));
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
227 memset(sp->pmt_pids, 0, sizeof(sp->pmt_pids));
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
228 memset(sp->cat_pids, 0, sizeof(sp->cat_pids));
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
229 memset(sp->pcr_pids, 0, sizeof(sp->pcr_pids));
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
230 memset(sp->pcr, 0, sizeof(sp->pcr));
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
231
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
232 sp->sid_list = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
233 sp->pat = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
234 sp->sid_list = AnalyzeSid(sid);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
235 if ( sp->sid_list == NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
236 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
237 free(sp);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
238 return NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
239 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
240 sp->pat_count = 0xFF;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
241 sp->pmt_retain = -1;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
242 sp->pmt_counter = 0;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
243 sp->time_cue = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
244 sp->time_tot = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
245 sp->pcr_nb = 0;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
246 memset(sp->esbuf, 0, sizeof(splitesbuf_t *)*MAX_PID);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
247 memset(sp->pesbuf, 0, sizeof(splitpesbuf_t *)*MAX_PID);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
248 memset(sp->program, 0, sizeof(program_t *)*MAX_SERVICE_ID);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
249 for ( i=0; i < MAX_PID; i++ ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
250 /* pmt_version は (N%32) の値を取るので、0 で初期化してはならない */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
251 sp->program[i].pmt_version = -1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
252 /* cue は最大値で初期化(CUE <= STCとなると録画開始するため) */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
253 sp->program[i].cue = INT64_MAX;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
254 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
255 memset(sp->pid_sid_table, 0, sizeof(int)*MAX_PID);
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
256 sp->filename = NULL;
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
257 sp->esout = 0;
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
258 if ( filename != NULL ) {
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
259 sp->esout = 1;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
260 sp->filename = filename;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
261 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
262 if ( arg_cue != NULL ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
263 sp->arg_cue = arg_cue;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
264 } else {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
265 sp->arg_cue = "00000000000000"; /* とりあえず最小値 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
266 }
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
267 return sp;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
268 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
269
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
270 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
271 * 落とすPIDを確定させる
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
272 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
273 int split_select(
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
274 splitter *sp, // [in/out] splitter構造体
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
275 ARIB_STD_B25_BUFFER *sbuf // [in] 入力TS
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
276 )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
277 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
278 int result;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
279 // TS解析
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
280 result = ReadTs(sp, sbuf);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
281
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
282 return result;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
283 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
284
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
285 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
286 * 終了処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
287 */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
288 void split_shutdown(splitter* sp)
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
289 {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
290 int i = 0;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
291 if ( sp != NULL ) {
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
292 if ( sp->program != NULL )
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
293 {
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
294 free(sp->program);
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
295 sp->program = NULL;
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
296 }
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
297 if ( sp->pat != NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
298 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
299 free(sp->pat);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
300 sp->pat = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
301 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
302 if ( sp->sid_list != NULL )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
303 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
304 free(sp->sid_list);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
305 sp->sid_list = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
306 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
307 for(i=0; i < MAX_PID; i++) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
308 if ( sp->esbuf[i] != NULL ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
309 if ( sp->esbuf[i]->fd != -1 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
310 close(sp->esbuf[i]->fd);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
311 sp->esbuf[i]->fd = -1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
312 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
313 free(sp->esbuf[i]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
314 sp->esbuf[i] = NULL;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
315 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
316 if ( sp->pesbuf[i] != NULL ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
317 free(sp->pesbuf[i]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
318 sp->pesbuf[i] = NULL;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
319 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
320 }
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
321 free(sp);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
322 sp = NULL;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
323 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
324 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
325
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
326 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
327 * TS 解析処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
328 *
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
329 * 対象のチャンネル番号のみの PAT の再構築と出力対象 PID の抽出を行う
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
330 */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
331 static int ReadTs(splitter *sp, ARIB_STD_B25_BUFFER *sbuf)
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
332 {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
333 #if 0
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
334 splitter *sp, // [in/out] splitter構造体
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
335 ARIB_STD_B25_BUFFER *sbuf, // [in] pt1_drvの入力TS
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
336 #endif
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
337
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
338 int length = sbuf->size;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
339 int pid;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
340 int result = TSS_ERROR;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
341 int index;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
342
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
343 index = 0;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
344 while(length - index - LENGTH_PACKET > 0) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
345 pid = GetPid(sbuf->data + index + 1);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
346 // PAT
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
347 if(PAT == pid) {
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
348 result = AnalyzePat(sp, sbuf->data + index);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
349 if(TSS_SUCCESS != result) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
350 /* 下位の関数内部でmalloc error発生 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
351 return result;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
352 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
353 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
354
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
355 // PMT
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
356 /* 残すpmt_pidである場合には、pmtに書かれている
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
357 * 残すべきPCR/AUDIO/VIDEO PIDを取得する */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
358 if(sp->pmt_pids[pid] == 1) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
359 /* この中にはPMT毎に一度しか入らないようにしておく */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
360 sp->pmt_pids[pid]++;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
361 sp->pmt_counter += 1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
362 DemuxTs(sbuf->data +index, sp, pid); /* AnalyzePmt より DemuxTs の方がアダプテーションフィールドの処理が良いので変更 */
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
363 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
364 /* 録画する全てのPMTについて、中にあるPCR/AUDIO/VIDEOのPIDを得る */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
365 /* pmt_counter と pmt_retain が一致する場合に条件は満たされる */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
366 if(sp->pmt_counter == sp->pmt_retain) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
367 result = TSS_SUCCESS;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
368 break;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
369 }
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
370 else {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
371 result = TSS_ERROR;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
372 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
373 index += LENGTH_PACKET;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
374 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
375
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
376 return(result);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
377 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
378
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
379 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
380 * TS 分離処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
381 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
382 int split_ts(
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
383 splitter *sp, // [in] splitterパラメータ
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
384 ARIB_STD_B25_BUFFER *sbuf, // [in] 入力TS
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
385 splitbuf_t *dbuf // [out] 出力TS
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
386 )
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
387 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
388 int pid;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
389 unsigned char *sptr, *dptr;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
390 int s_offset = 0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
391 int d_offset = 0;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
392 int64_t pcr_h = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
393 int pcr_l = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
394 int ret = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
395 int sid = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
396 program_t *program;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
397 static int packet_nb; /* パケット受信数 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
398 int i = 0;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
399
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
400 /* 初期化 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
401 dbuf->size = 0;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
402 if (sbuf->size < 0) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
403 return TSS_ERROR;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
404 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
405
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
406 sptr = sbuf->data;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
407 dptr = dbuf->buffer;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
408
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
409 while(sbuf->size > s_offset) {
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
410 pid = GetPid(sptr + s_offset + 1);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
411 sid = sp->pid_sid_table[pid]; /* PIDからSIDを取得 */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
412 switch(pid) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
413
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
414 // PAT
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
415 case PAT:
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
416 // 巡回カウンタカウントアップ
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
417 if(0xFF == sp->pat_count) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
418 sp->pat_count = sp->pat[3];
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
419 }
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
420 else {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
421 sp->pat_count += 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
422 if(0 == sp->pat_count % 0x10) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
423 sp->pat_count -= 0x10;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
424 }
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
425 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
426 sp->pat[3] = sp->pat_count;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
427
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
428 memcpy(dptr + d_offset, sp->pat, LENGTH_PACKET);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
429 d_offset += LENGTH_PACKET;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
430 dbuf->size += LENGTH_PACKET;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
431 break;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
432 case TOT:
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
433 /* TOT に TDTの情報全てが含まれており、実放送では TOT しか送信されない */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
434 /* TOT は 500msec の誤差が保証されている
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
435 * 閏秒の場合は最大1.5秒の誤差となる
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
436 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
437 if ( sp->time_tot == 0 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
438 /* splitter構造体の時刻関係(TOT/CUE)のパラメータ初期化 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
439 parse_tot(sptr + s_offset, &(sp->time_tot));
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
440 sp->time_cue = cue2time(sp->arg_cue);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
441 sp->tot_packet_nb = packet_nb;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
442 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
443 break;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
444 default:
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
445 /* ■時間管理に関しての実装方針■ */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
446 /*
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
447 * ■時間関係を扱っている変数■
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
448 * PCR : 42Bit @27MHz(ServiceID(ProgramID, sid)毎に独立)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
449 * PTS : 42Bit @90KHz(ES毎に独立)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
450 * DTS : 42Bit @90KHz(ES毎に独立)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
451 * TOT : MJD + 2進化10進数(TSに1つだけ)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
452 * STC : 64Bit @27MHz(ServiceID(ProgramID, sid)の現在時刻(ソースはPCR))
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
453 * CUE : 録画開始時刻 YYYYMMDDHHMISS (引数指定)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
454 *
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
455 * ■STCの管理方針■
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
456 * PCR受信時にSTCに時間情報をコピーする
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
457 * 1パケットを受信すると経過する時間を加算してSTCを管理する
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
458 * (ffmpegのmpegts.cと同じ方針)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
459 *
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
460 * ■CUEとTOTとSTC■
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
461 * TOTからSTCと比較するための情報を作成する。
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
462 * ・TOTは time_t
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
463 * ・CUEは time_t
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
464 * ・STCは42Bitの27MHz周期の数値
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
465 * TOT 受信時に各Program(ServiceID)のSTCを変換基準値とする
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
466 * 録画開始時(27MHz)の値の計算式は、
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
467 * Program->CUE = STCの変換基準値 + 27e6*(ARG_CUE-TOT(秒))
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
468 * 録画の開始確認として Program->CUE と PTS を比較すればよい
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
469 *
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
470 * ※PCR/PTS/DTSはオーバーフローしたときには34Bit目が立っていると見なすこと※
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
471 * オーバーフロー時の処理は未実装
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
472 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
473 if ( 2 == sp->pmt_pids[pid] ) {
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
474 /* PMT の追跡 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
475 DemuxTs((sptr+s_offset), sp, pid);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
476 }
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
477 /* pids[pid] が 1 は残すパケットなので書き込む */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
478 if ( (1 == sp->pids[pid]) ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
479 /* PCRとSTCの処理 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
480 int pcr_index;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
481 pcr_index = search_pcr_pid(sp, pid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
482 if ( sp->pcr_pids[pid] == 1 && pcr_index != -1) { /* PCRか否か */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
483 ret = parse_pcr(&pcr_h, &pcr_l, (sptr+s_offset));
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
484 /*
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
485 * PCR は複数 ServiceID(ProgramID)で重複利用される場合がある
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
486 * PCR を参照する複数の ServiceID(ProgramID)分ループ
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
487 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
488 for (i=0; i < sp->pcr[pcr_index].sid_nb; i++) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
489 sid = sp->pcr[pcr_index].sid[i];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
490 program = &(sp->program[sid]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
491 /* こっから */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
492 if ( ret == 0 ) { /* PCR の解析に成功 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
493 program->stc = pcr_h * 300 + pcr_l; /* PCR受信時にSTCを補正*/
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
494 if ( program->pcr1 == 0 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
495 program->pcr1 = program->stc;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
496 printf("pcr1 pid[%d] sid[%d] packet_nb[%d] sid_nb[%d] i[%d]\n",
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
497 pid, sid, packet_nb, sp->pcr[pcr_index].sid_nb, i);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
498 } else if ( program->pcr2 == 0 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
499 // printf("pcr2 pid[%d] sid[%d] packet_nb[%d], p_packet_nb[%d] sid_nb[%d] i[%d]\n",
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
500 // pid, sid, packet_nb, program->pcr_packet_nb, sp->pcr[pcr_index].sid_nb, i);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
501 program->pcr2 = program->stc;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
502 program->pcr_incr = (program->pcr2 -program->pcr1)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
503 /(packet_nb -program->pcr_packet_nb);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
504 printf("pcr2 pid[%d] sid[%d] pcr_incr[%llu]\n",
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
505 pid, sid, program->pcr_incr);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
506 } else {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
507 /* PCR処理済み */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
508 ; /* 得に処理無し */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
509 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
510 if ( (program->cue == INT64_MAX ) &&
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
511 (sp->arg_cue != NULL) &&
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
512 (sp->time_tot != 0) ) { /* 録画開始時刻指定時 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
513 /*
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
514 * 録画開始時刻 = STC +(CUE -TOT)*27MHz
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
515 * +(TOT取得時から現在までのパケット数の増分)*パケットあたりの進む時間
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
516 * -0.49秒(この数字は適当)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
517 * TOT/STCで時間調整して、GOP先頭から出すので攻めてしまっていい気がする
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
518 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
519 program->cue = program->stc
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
520 +(sp->time_cue -sp->time_tot)*27e6
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
521 +(packet_nb -sp->tot_packet_nb)*program->pcr_incr
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
522 -(27e6*49/100);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
523 printf("STC[%llu] CUE[%llu] SID[%d]\n",
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
524 program->stc, program->cue, sid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
525 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
526 program->pcr_packet_nb = packet_nb;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
527 program->packet_nb = packet_nb;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
528 } else if ( program->pcr_incr ) { /* PCRの解析に失敗且つpcr_incr変数の計算済み*/
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
529 /* STCを成長させる */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
530 program->stc += (packet_nb -program->packet_nb)*program->pcr_incr;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
531 program->packet_nb = packet_nb;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
532 } else {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
533 ; /* STCを進める要素が揃ってません */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
534 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
535 } /* for */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
536 } else { /* 処理対象パケットはPCRではない */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
537 program = &(sp->program[sid]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
538 if ( program->pcr_incr ) { /* PCRを受信しない且つpcr_incr変数の計算済み */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
539 /* STCを成長させる */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
540 program->stc += (packet_nb -program->packet_nb)*program->pcr_incr;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
541 program->packet_nb = packet_nb;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
542 } else { /* それ以外 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
543 ; /* STCを進める要素が揃ってません */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
544 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
545 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
546 #if 0
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
547 // NHK Gを ALL とすると SID 1024 しか出ない...orz..
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
548 if ( !(packet_nb % 1000) ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
549 program = &(sp->program[sid]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
550 printf("STC[%llu] SID[%d]\n", program->stc, sid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
551 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
552 #endif
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
553 /* TS処理 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
554 DemuxTs((sptr+s_offset), sp, pid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
555 memcpy(dptr + d_offset, sptr + s_offset, LENGTH_PACKET);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
556 d_offset += LENGTH_PACKET;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
557 dbuf->size += LENGTH_PACKET;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
558 }
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
559 break;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
560 } /* switch */
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
561 s_offset += LENGTH_PACKET;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
562 packet_nb += 1; /* パケット受信数加算 */
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
563 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
564 return(TSS_SUCCESS);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
565 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
566
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
567 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
568 * PAT 解析処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
569 *
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
570 * PAT を解析し、出力対象チャンネルが含まれているかチェックを行い、PAT を再構築する
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
571 */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
572 static int AnalyzePat(splitter *sp, unsigned char *buf)
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
573 #if 0
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
574 unsigned char* buf, // [in] 読み込んだバッファ
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
575 unsigned char** pat, // [out] PAT 情報(再構築後)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
576 unsigned char* pids, // [out] 出力対象 PID 情報
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
577 char** sid_list, // [in] 出力対象サービス ID のリスト
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
578 unsigned char* pmt_pids, // [out] サービス ID に対応する PMT の PID
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
579 int* pmt_retain // [out] 残すPMTの数
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
580 )
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
581 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
582 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
583 int pos[MAX_PID];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
584 int service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
585 int i, j, k;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
586 int size = 0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
587 int pid;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
588 int result = TSS_SUCCESS;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
589 char **p;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
590 int sid_found = FALSE;
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
591 int avail_sids[MAX_SERVICES];
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
592
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
593 unsigned char *pat = sp->pat;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
594 unsigned char *pids = sp->pids;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
595 char **sid_list = sp->sid_list;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
596 unsigned char *pmt_pids = sp->pmt_pids;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
597
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
598 char chosen_sid[512];
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
599 chosen_sid[0] = '\0';
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
600
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
601 if(pat == NULL) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
602 /* 初期化 */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
603 sp->pmt_retain = 0;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
604 memset(pos, 0, sizeof(pos));
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
605 size = buf[7];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
606
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
607 /* prescan SID/PMT */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
608 for(i = 17, j = 0; i < (size + 8) - 4; i = i + 4, j++) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
609 avail_sids[j] = (buf[i] << 8) + buf[i+1];
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
610 sp->avail_pmts[j] = GetPid(&buf[i+2]);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
611 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
612 sp->num_pmts = j;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
613
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
614 // 対象チャンネル判定
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
615 /* size + 8 = パケット全長 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
616 /* 最終 4 バイトはCRCなので飛ばす */
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
617 for(i = 17; i < (size + 8) - 4; i = i + 4) {
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
618
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
619 service_id = (buf[i] << 8) + buf[i+1];
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
620 p = sid_list;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
621
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
622 while(*p) {
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
623 if(service_id == atoi(*p)) {
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
624 /* 録画対象の pmt_pids は 1 とする */
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
625 /* 録画対象の pmt の pids は 1 とする */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
626 /* 対応する pid_sid_table に サービスID(ProgramID) を入れる */
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
627 pid = GetPid(&buf[i + 2]);
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
628 *(pmt_pids+pid) = 1;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
629 *(pids+pid) = 1;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
630 pos[pid] = i;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
631 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
632 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
633 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
634 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
635 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
636 p++;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
637 continue;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
638 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
639 else if(!strcasecmp(*p, "hd") || !strcasecmp(*p, "sd1")) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
640 /* hd/sd1 指定時には1番目のサービスを保存する */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
641 if(service_id == avail_sids[0]) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
642 pid = GetPid(&buf[i + 2]);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
643 *(pmt_pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
644 *(pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
645 pos[pid] = i;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
646 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
647 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
648 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
649 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
650 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
651 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
652 p++;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
653 continue;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
654 }
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
655 else if(!strcasecmp(*p, "sd2")) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
656 /* sd2 指定時には2番目のサービスを保存する */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
657 if(service_id == avail_sids[1]) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
658 pid = GetPid(&buf[i + 2]);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
659 *(pmt_pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
660 *(pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
661 pos[pid] = i;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
662 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
663 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
664 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
665 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
666 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
667 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
668 p++;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
669 continue;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
670 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
671 else if(!strcasecmp(*p, "sd3")) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
672 /* sd3 指定時には3番目のサービスを保存する */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
673 if(service_id == avail_sids[2]) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
674 pid = GetPid(&buf[i + 2]);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
675 *(pmt_pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
676 *(pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
677 pos[pid] = i;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
678 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
679 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
680 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
681 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
682 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
683 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
684 p++;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
685 continue;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
686 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
687 else if(!strcasecmp(*p, "1seg")) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
688 /* 1seg 指定時には PMTPID=0x1FC8 のサービスを保存する */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
689 pid = GetPid(&buf[i + 2]);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
690 if(pid == 0x1FC8) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
691 *(pmt_pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
692 *(pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
693 pos[pid] = i;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
694 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
695 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
696 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
697 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
698 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
699 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
700 p++;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
701 continue;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
702 }
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
703 else if(!strcasecmp(*p, "all")) {
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
704 /* all指定時には全保存する */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
705 pid = GetPid(&buf[i + 2]);
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
706 *(pmt_pids+pid) = 1;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
707 *(pids+pid) = 1;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
708 pos[pid] = i;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
709 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
710 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
711 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
712 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
713 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
714 break;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
715 }
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
716
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
717 p++;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
718 } /* while */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
719 }
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
720
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
721 /* if sid has been specified but no sid found, fall back to all */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
722 if(*sid_list && !sid_found) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
723 for(i = 17; i < (size + 8) - 4; i = i + 4) {
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
724 service_id = (buf[i] << 8) + buf[i+1];
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
725 pid = GetPid(&buf[i + 2]);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
726 *(pmt_pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
727 *(pids+pid) = 1;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
728 pos[pid] = i;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
729 sid_found = TRUE;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
730 sp->pmt_retain += 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
731 sp->program[service_id].pmt_packet_id = pid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
732 sp->pid_sid_table[pid] = service_id;
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
733 sprintf(chosen_sid, "%s %d", *chosen_sid ? chosen_sid : "", service_id);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
734 }
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
735 }
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
736
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
737 /* print SIDs */
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
738 fprintf(stderr, "Available sid = ");
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
739 for(k=0; k < sp->num_pmts; k++) {
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
740 fprintf(stderr, "%d ", avail_sids[k]);
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
741 /* ut->channel_name にSID番号を入れる
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
742 * ushare 側(TV表示上)には channel_name を表示させる
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
743 * TODO 局名も含めて入れたいなぁ
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
744 */
149
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
745 if(!strcmp("all", sp->sid_list[0])) {
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
746 #define CHANNEL_NAME_LENGTH (64)
149
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
747 ut->channel_name[ut->nr_channel] = malloc(CHANNEL_NAME_LENGTH);
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
748 if(!ut->channel_name[ut->nr_channel])
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
749 return TSS_NULL;
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
750 snprintf(ut->channel_name[ut->nr_channel],
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
751 CHANNEL_NAME_LENGTH,
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
752 "%d.ts",
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
753 avail_sids[k]);
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
754 ut->location_name[ut->nr_channel] = malloc(CHANNEL_NAME_LENGTH);
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
755 if(!ut->location_name[ut->nr_channel])
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
756 return TSS_NULL;
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
757 snprintf(ut->location_name[ut->nr_channel],
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
758 CHANNEL_NAME_LENGTH,
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
759 VIRTUAL_DIR "/%d.ts",
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
760 avail_sids[k]);
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
761 ut->nr_channel += 1;
a9f60d56d673 Fix DLNA problem
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 146
diff changeset
762 }
146
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
763 }
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
764 // metadata list を作り直す
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
765 free_metadata_list(ut);
066f33b2213a EXPERIMENTAL: Select a particular program from multi-channel.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 143
diff changeset
766 build_metadata_list(ut);
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
767 fprintf(stderr, "\n");
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
768 fprintf(stderr, "Chosen sid =%s\n", chosen_sid);
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
769
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
770 #if 0
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
771 /* print PMTs */
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
772 fprintf(stderr, "Available PMT = ");
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
773 for(k=0; k < sp->num_pmts; k++)
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
774 fprintf(stderr, "%d ", sp->avail_pmts[k]);
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
775 fprintf(stderr, "\n");
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
776 #endif
98
3fd15032fd3a tweak user interface for sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 96
diff changeset
777
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
778 // PAT 再構築
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
779 result = RecreatePat(sp, buf, pos);
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
780 #if 0
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
781 int tc;
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
782 for(tc=0; tc<188; tc++)
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
783 fprintf(stderr, "%02x ", *(pat+tc));
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
784 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
785 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
786
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
787 return(result);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
788 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
789
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
790 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
791 * PAT 再構築処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
792 *
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
793 * PMT から出力対象チャンネル以外のチャンネル情報を削除し、PAT を再構築する
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
794 */
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
795 static int RecreatePat(splitter *sp, unsigned char *buf, int *pos)
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
796 #if 0
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
797 unsigned char* buf, // [in] 読み込んだバッファ
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
798 unsigned char** pat, // [out] PAT 情報(再構築後)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
799 unsigned char* pids, // [out] 出力対象 PID 情報
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
800 int *pos) // [in] 取得対象 PMT のバッファ中の位置
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
801 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
802 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
803 unsigned char y[LENGTH_CRC_DATA];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
804 int crc;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
805 int i;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
806 int j;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
807 int pos_i;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
808 int pid_num = 0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
809
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
810 // CRC 計算のためのデータ
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
811 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
812 // チャンネルによって変わらない部分
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
813 for (i = 0; i < LENGTH_PAT_HEADER; i++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
814 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
815 y[i] = buf[i + 5];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
816 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
817 // チャンネルによって変わる部分
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
818 for (i = 0; i < MAX_PID; i++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
819 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
820 if(pos[i] != 0)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
821 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
822 /* buf[pos_i] を y にコピー(抽出したPIDの数) */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
823 pos_i = pos[i];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
824 for (j = 0; j < 4; j++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
825 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
826 y[LENGTH_PAT_HEADER + ((4*pid_num) + j)] = buf[pos_i + j];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
827 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
828 pid_num++;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
829 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
830 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
831 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
832 /* パケットサイズ計算 */
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
833 y[2] = pid_num * 4 + 0x0d;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
834 // CRC 計算
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
835 crc = GetCrc32(y, LENGTH_PAT_HEADER + pid_num*4);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
836
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
837 // PAT 再構成
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
838 sp->pat = (unsigned char*)malloc(LENGTH_PACKET);
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
839 if(sp->pat == NULL)
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
840 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
841 fprintf(stderr, "RecreatePat() malloc error.\n");
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
842 return(TSS_NULL);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
843 }
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
844 memset(sp->pat, 0xFF, LENGTH_PACKET);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
845 for (i = 0; i < 5; i++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
846 {
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
847 (sp->pat)[i] = buf[i];
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
848 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
849 for (i = 0; i < LENGTH_PAT_HEADER + pid_num*4; i++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
850 {
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
851 (sp->pat)[i + 5] = y[i];
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
852 }
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
853 (sp->pat)[5 + LENGTH_PAT_HEADER + pid_num*4] = (crc >> 24) & 0xFF;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
854 (sp->pat)[6 + LENGTH_PAT_HEADER + pid_num*4] = (crc >> 16) & 0xFF;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
855 (sp->pat)[7 + LENGTH_PAT_HEADER + pid_num*4] = (crc >> 8) & 0xFF;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
856 (sp->pat)[8 + LENGTH_PAT_HEADER + pid_num*4] = (crc ) & 0xFF;
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
857
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
858 return(TSS_SUCCESS);
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
859 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
860
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
861
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
862 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
863 * PMT 解析処理
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
864 *
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
865 * PMT を解析し、保存対象の PID を特定する
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
866 * TSヘッダとアダプテーションフィールドの処理は DemuxTs に一任するので、
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
867 * この内部では、セクションデータの先頭ポインタをもらってくる
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
868 */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
869 static int AnalyzePmt(splitter *sp, const uint8_t *buf, int sid, const int size)
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
870 #if 0
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
871 unsigned char* buf, // [in] セクション先頭
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
872 unsigned char* pids) // [out] 出力対象 PID 情報
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
873 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
874 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
875 unsigned char Nall;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
876 unsigned char N;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
877 int pcr;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
878 int epid;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
879 int av_flag = 0;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
880 int i = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
881 int j = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
882 int pcr_found = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
883 /* デバッグ用 PMT情報表示 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
884 #define PmtDebug (1)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
885
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
886 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
887 printf("AnalyzePmt start. Tree List enable.\n");
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
888 printf("SID[%d][0x%04x]\n", sid, sid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
889 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
890
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
891 // Nall = ((buf[2] & 0x0F) << 4) + buf[3];
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
892 Nall = ((buf[2] & 0x0F) << 8) + buf[3];
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
893 // ここで受け取るのはTSパケットではなく、セクションの先頭ポインタであるのでsizeで見る
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
894 // if(Nall > LENGTH_PACKET)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
895 // Nall = LENGTH_PACKET - 8; /* xxx workaround --yaz */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
896 if(Nall > size)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
897 Nall = size -8;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
898
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
899 /* get version */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
900 sp->program[sid].pmt_version = get_pmt_version(buf);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
901 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
902 printf(" pmt_version[%02x]\n", sp->program[sid].pmt_version);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
903 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
904
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
905 // PCR
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
906 pcr = GetPid(&buf[9]);
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
907 sp->pids[pcr] = 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
908 sp->program[sid].pcr_packet_id = pcr;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
909 sp->pid_sid_table[pcr] = sid; /* PCRは重複する可能性があるので方式がよろしくない */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
910 sp->pcr_pids[pcr] = 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
911
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
912 /* PCRの重複チェック(複数ServiceID(ProgramID)) */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
913 for( i=0; i < sp->pcr_nb; i++ ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
914 if ( sp->pcr[i].pid == pcr ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
915 /* 発見 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
916 for ( j=0; j < sp->pcr[i].sid_nb; j++ ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
917 /* 同一SIDが既に登録されているか確認 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
918 if ( sp->pcr[i].sid[j] == sid ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
919 pcr_found = 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
920 break;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
921 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
922 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
923 if ( pcr_found ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
924 /* 同一SIDが既に登録されている */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
925 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
926 printf(" same sid found pcr[%d] sid[%d]\n", pcr, sid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
927 #endif
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
928 break;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
929 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
930 /* 重複PCR発見 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
931 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
932 printf(" same pcr found pcr[%d] sid[%d] sid_nb[%d], i[%d]\n", pcr, sid, sp->pcr[i].sid_nb, i);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
933 #endif
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
934 sp->pcr[i].sid[sp->pcr[i].sid_nb] = sid;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
935 sp->pcr[i].sid_nb += 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
936 pcr_found = 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
937 break;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
938 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
939 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
940
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
941 if ( ! pcr_found ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
942 /* PCR管理領域更新 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
943 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
944 printf(" new pcr found pcr[%d] sid[%d], pcr_nb[%d]\n", pcr, sid, sp->pcr_nb);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
945 #endif
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
946 sp->pcr[sp->pcr_nb].pid = pcr;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
947 sp->pcr[sp->pcr_nb].sid[0] = sid;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
948 sp->pcr[sp->pcr_nb].sid_nb = 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
949 sp->pcr_nb += 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
950 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
951 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
952 printf(" PCR PacketID[%d][0x%04x]\n", pcr, pcr);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
953 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
954
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
955 // N = ((buf[11] & 0x0F) << 4) + buf[12] + 16 + 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
956 N = ((buf[11] & 0x0F) << 8) + buf[12] + 12 + 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
957 // printf("NAll[%d] N[%d]\n", Nall, N);
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
958
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
959 // ECM
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
960 //int p = 17;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
961 int p = 13;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
962 while(p < N) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
963 if ( p > size -4) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
964 break;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
965 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
966 uint32_t cat_pid;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
967 uint32_t tag;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
968 uint32_t len;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
969
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
970 tag = buf[p];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
971 len = buf[p+1];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
972 p += 2;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
973
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
974 if(tag == 0x09 && len >= 4 && p+len <= N) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
975 // ca_pid = ((buf[p+2] << 8) | buf[p+3]) & 0x1fff;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
976 cat_pid = (AV_RB16(buf+p+2)) & 0x1fff;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
977 sp->pids[cat_pid] = 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
978 sp->cat_pids[cat_pid] = 1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
979 sp->pid_sid_table[cat_pid] = sid; /* CATも複数ServiceIDで重複がある */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
980 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
981 printf(" CAT PacketID[%d][0x%04x]\n", cat_pid, cat_pid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
982 #endif
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
983 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
984 p += len;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
985 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
986
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
987 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
988 * ISO/IEC 13818-1:2000(E) Table 2-29 - Stream type assignments
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
989 * Value Desctiption
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
990 * 0x00 ITU-T | ISO/IEC Reserved
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
991 * 0x01 ISO/IEC 11172 Video
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
992 * 0x02 ITU-T Rec. H.262 | ISO/IEC 13818-2 Video or ISO/IEC 11172-2 constrained parameter video stream
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
993 * 0x03 ISO/IEC 11172 Audio
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
994 * 0x04 ISO/IEC 13818-3 Audio
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
995 * 0x05 ITU-T Rec. H.222.0 | ISO/IEC 13818-1 private_sections
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
996 * 0x06 ITU-T Rec. H.222.0 | ISO/IEC 13818-1 PES packets containing private data
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
997 * 0x07 ISO/IEC 13522 MHEG
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
998 * 0x08 ITU-T Rec. H.222.0 | ISO/IEC 13818-1 Annex A DSM-CC
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
999 * 0x09 ITU-T Rec. H.222.1
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1000 * 0x0A ISO/IEC 13818-6 type A
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1001 * 0x0B ISO/IEC 13818-6 type B
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1002 * 0x0C ISO/IEC 13818-6 type C
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1003 * 0x0D ISO/IEC 13818-6 type D
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1004 * 0x0E ITU-T Rec. H.222.0 | ISO/IEC 13818-1 auxiliary
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1005 * 0x0F ISO/IEC 13818-7 Audio with ADTS transport syntax
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1006 * 0x10 ISO/IEC 14496-2 Visual
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1007 * 0x11 ISO/IEC 14496-3 Audio with the LATM transport syntax as defined in ISO/IEC 14496-3 / AMD 1
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1008 * 0x12 ISO/IEC 14496-1 SL-packetized stream or FlexMux stream carried in PES packets
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1009 * 0x13 ISO/IEC 14496-1 SL-packetized stream or FlexMux stream carried in ISO/IEC14496_sections.
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1010 * 0x14 ISO/IEC 13818-6 Synchronized Download Protocol
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1011 * 0x15-0x7F ITU-T Rec. H.222.0 | ISO/IEC 13818-1 Reserved
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1012 * 0x80-0xFF User Private
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1013 *
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1014 */
104
afd25d9ebef6 output ECM packet so that former workaround is no longer needed.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 101
diff changeset
1015
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1016 // ES PID
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1017 while (N < Nall + 8 - 4) {
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1018 av_flag = 0;
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
1019 // ストリーム種別が 0x0D(type D)は出力対象外
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1020 if (0x0D != buf[N]) {
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
1021 epid = GetPid(&buf[N + 1]);
100
aeba1988234f support macros to specify sid:
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 99
diff changeset
1022 sp->pids[epid] = 1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1023 sp->pid_sid_table[epid] = sid;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1024 if ( buf[N] == 0x02 ) { /* 13818-2 Video */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1025 sp->program[sid].video[sp->program[sid].video_nb] = epid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1026 sp->program[sid].video_nb += 1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1027 av_flag = TSS_STREAM_TYPE_VIDEO;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1028 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1029 printf(" VIDEO PacketID[%d][0x%04x] StreamType[0x%02x]\n", epid, epid, buf[N]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1030 #endif
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1031 } else if ( (buf[N] == 0x04) || (buf[N] == 0x0f) ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1032 /* 13818-3 Audio or 13818-7 Audio with ADTS transport syntax */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1033 sp->program[sid].audio[sp->program[sid].audio_nb] = epid;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1034 sp->program[sid].audio_nb += 1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1035 av_flag = TSS_STREAM_TYPE_AUDIO;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1036 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1037 printf(" AUDIO PacketID[%d][0x%04x] StreamType[0x%02x]\n", epid, epid, buf[N]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1038 #endif
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1039 } else {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1040 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1041 printf(" OTHER PacketID[%d][0x%04x] StreamType[0x%02x]\n", epid, epid, buf[N]);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1042 #endif
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1043 ; /* A/V どちらでもないものはとりあえずスルー */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1044 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1045 if ( av_flag && sp->esout ) {
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1046 /* ESバッファはNULLか? */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1047 if ( sp->esbuf[epid] == NULL ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1048 sp->esbuf[epid] = malloc(sizeof(splitesbuf_t));
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1049 if ( sp->esbuf[epid] == NULL ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1050 fprintf(stderr, "malloc error\n");
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1051 return TSS_NULL;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1052 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1053 sp->esbuf[epid]->size = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1054 sp->esbuf[epid]->Program = &(sp->program[sid]);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1055 sp->esbuf[epid]->fd = -1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1056 if ( creat_es_file(sp, sid, epid, av_flag) ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1057 return TSS_ERROR;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1058 }
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1059 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1060 /* PESバッファはNULLか? */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1061 if ( sp->pesbuf[epid] == NULL ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1062 sp->pesbuf[epid] = malloc(sizeof(splitpesbuf_t));
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1063 if ( sp->pesbuf[epid] == NULL ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1064 fprintf(stderr, "malloc error\n");
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1065 return TSS_NULL;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1066 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1067 sp->pesbuf[epid]->size = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1068 sp->pesbuf[epid]->Program = &(sp->program[sid]);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1069 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1070 }
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
1071 }
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1072 // N += 4 + (((buf[N + 3]) & 0x0F) << 4) + buf[N + 4] + 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1073 N += 4 + (((buf[N + 3]) & 0x0F) << 8) + buf[N + 4] + 1;
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1074 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1075 #ifdef PmtDebug
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1076 printf("AnalyzePmt finish.\n");
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1077 #endif
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1078 return TSS_SUCCESS;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1079 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1080
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1081 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1082 * CRC 計算
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1083 */
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
1084 static int GetCrc32(
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1085 unsigned char* data, // [in] CRC 計算対象データ
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1086 int len) // [in] CRC 計算対象データ長
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1087 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1088 int crc;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1089 int i, j;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1090 int c;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1091 int bit;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1092
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1093 crc = 0xFFFFFFFF;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1094 for (i = 0; i < len; i++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1095 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1096 char x;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1097 x = data[i];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1098
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1099 for (j = 0; j < 8; j++)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1100 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1101
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1102 bit = (x >> (7 - j)) & 0x1;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1103
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1104 c = 0;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1105 if (crc & 0x80000000)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1106 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1107 c = 1;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1108 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1109
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1110 crc = crc << 1;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1111
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1112 if (c ^ bit)
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1113 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1114 crc ^= 0x04C11DB7;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1115 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1116
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1117 crc &= 0xFFFFFFFF;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1118 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1119 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1120
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1121 return crc;
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1122 }
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1123
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1124 /**
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1125 * PID 取得
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1126 */
99
3a3f15b063e1 now recpt1 accepts single sid for terrestrial channels.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents: 98
diff changeset
1127 static int GetPid(
96
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1128 unsigned char* data) // [in] 取得対象データのポインタ
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1129 {
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1130 return ((data[0] & 0x1F) << 8) + data[1];
52f8e081763d add an option to specify the necessary service IDs.
Yoshiki Yazawa <yaz@honeyplanet.jp>
parents:
diff changeset
1131 }
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1132
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1133 /* return the 90kHz PCR and the extension for the 27MHz PCR. return
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1134 (-1) if not available */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1135 static int parse_pcr(int64_t *ppcr_high, int *ppcr_low,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1136 const uint8_t *packet)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1137 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1138 int afc, len, flags;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1139 const uint8_t *p;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1140 unsigned int v;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1141
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1142 afc = (packet[3] >> 4) & 3;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1143 if (afc <= 1)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1144 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1145 p = packet + 4;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1146 len = p[0];
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1147 p++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1148 if (len == 0)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1149 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1150 flags = *p++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1151 len--;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1152 if (!(flags & 0x10))
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1153 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1154 if (len < 6)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1155 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1156 v = AV_RB32(p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1157 *ppcr_high = ((int64_t)v << 1) | (p[4] >> 7);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1158 *ppcr_low = ((p[4] & 1) << 8) | p[5];
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1159 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1160 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1161
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1162 /* pesbufが空か判定 (ret. 0:not empty / 1: empty) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1163 static int pesbuf_empty(splitpesbuf_t *pesbuf){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1164 return pesbuf->size == 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1165 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1166
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1167 /* pesbufをクリア */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1168 void pesbuf_clear(splitpesbuf_t *pesbuf){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1169 pesbuf->size = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1170 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1171
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1172 /* pesbufにデータを追加 (ret. 0:success / -1:error) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1173 static int pesbuf_add(splitpesbuf_t *pesbuf, const uint8_t *data, int len){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1174 if(pesbuf->size + len > sizeof pesbuf->buffer){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1175 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1176 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1177 memcpy(pesbuf->buffer +pesbuf->size, data, len);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1178 pesbuf->size += len;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1179 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1180 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1181
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1182 /* pesbufから、PESの先頭(packet_start_code_prefix)を探す */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1183 /* (ret. >=0:offset / -1: error) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1184 static int pesbuf_packet_start_code_prefix(splitpesbuf_t *pesbuf){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1185 uint8_t packet_start_code_prefix[3] = {0x00, 0x00, 0x01};
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1186 int i = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1187
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1188 /* 小さすぎる */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1189 if(pesbuf->size < sizeof packet_start_code_prefix){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1190 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1191 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1192 /* 先頭で探す */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1193 if(!memcmp(pesbuf->buffer + i, packet_start_code_prefix, sizeof packet_start_code_prefix)){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1194 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1195 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1196
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1197 #if 0
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1198 /* 先頭以外からも探す場合は、ここのコードを有効化する。 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1199 /* ただし、MPEG-Videoのstart_codeと同じなので、深追いしない方がいいと思う... */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1200 for(i = 0; i < pesbuf->size - sizeof packet_start_code_prefix; i++){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1201 if(!memcmp(pesbuf->buffer + i, packet_start_code_prefix, sizeof packet_start_code_prefix)){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1202 return i;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1203 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1204 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1205 #endif
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1206
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1207 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1208 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1209
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1210 /**
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1211 * TSの解析とDemuxを行う
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1212 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1213 static int DemuxTs(const uint8_t *packet, splitter *sp, const int pid)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1214 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1215 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1216 * PES先頭までの長さは
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1217 * 4byte : continity counter
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1218 * 27,28bit が adaptation fileld制御
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1219 * (01:ペイロードのみ, 10:adaptation fileldのみ、11:adaptation fileld+payload、00:reserved)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1220 * ペイロード長 = 188 - TS header(4byte) -adaptation field長 -1
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1221 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1222 /* ありがとう */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1223
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1224 int payload_offset; /* ペイロードオフセット(=パケット先頭からのバイト数) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1225 int payload_length; /* ペイロード長 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1226 int pes_started;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1227 int adaptation_field_control;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1228 int payload_unit_start_indicator;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1229 // int random_access_indicator = 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1230 int sid = sp->pid_sid_table[pid]; /* SIDをPIDから引いているが、PCRとCATは重複しているので注意*/
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1231
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1232 payload_offset = LENGTH_TS_HEADER;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1233
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1234 if ( sp->pesbuf[pid] == NULL ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1235 pes_started = 0; /* malloc走る前(セクション解析だったら呼んで良い) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1236 } else {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1237 pes_started = !pesbuf_empty(sp->pesbuf[pid]); /* PES蓄積開始済み */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1238 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1239
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1240 /* adaptation_field_controlおよびadaptation_fieldを処理する */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1241 adaptation_field_control = (packet[3] & 0x30) >> 4;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1242 if ( adaptation_field_control == 0x02 || adaptation_field_control == 0x00) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1243 /* ペイロードなしの場合 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1244 return 0; /* 別にエラーではない */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1245 } else if ( adaptation_field_control == 0x03 ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1246 /* アダプテーションフィールド+ペイロードの場合 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1247 if ( packet[LENGTH_TS_HEADER] != 0 ) {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1248 // random_access_indicator = (packet[5] & 0x40) >> 6;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1249 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1250 /* ペイロード開始位置 = TSヘッダ長 + アダプテーションフィールド長 + 1 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1251 payload_offset += packet[LENGTH_TS_HEADER] + 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1252 } else {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1253 /* ペイロードのみ */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1254 ; /* 特に処理なし */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1255 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1256
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1257 /* ペイロード長を出す */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1258 payload_length = LENGTH_PACKET - payload_offset;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1259 if( payload_length <= 0 ){ /* payload長が0以下の場合 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1260 return -1; /* エラーにすべきかは微妙なところ */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1261 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1262
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1263 /* payload_unit_start_indicatorを処理(1) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1264 payload_unit_start_indicator = (packet[1] & 0x40) >> 6;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1265 /* (sectionの場合は、ここでpointer_fieldの処理などを行い、payload_offsetに反映する) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1266 if ( sp->pmt_pids[pid] == 2 ) { /* PID が録画対象の PMT であるか? */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1267 if ( get_pmt_version(packet+payload_offset) != sp->program[sid].pmt_version ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1268 /* pmt versionに差分あり */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1269 fprintf(stderr, "pmt version diff found pmt_pid[%d]"
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1270 " old_version[0x%02x]"
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1271 " new_version[0x%02x].\n",
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1272 pid,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1273 sp->program[sid].pmt_version,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1274 get_pmt_version(packet+payload_offset));
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1275 AnalyzePmt(sp, packet +payload_offset, sid, payload_length);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1276 /* payload 何byte処理したか等管理するべき */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1277 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1278 return 0; /* PMT の場合は処理終わり */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1279 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1280 if ( !sp->esout ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1281 /* ES出力しない場合はPES蓄積不要 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1282 return 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1283 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1284 if ( sp->cat_pids[pid] == 1 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1285 return 0; /* CATは蓄積しない */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1286 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1287 if ( sp->pesbuf[pid] == NULL ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1288 /* PES蓄積不要である場合も蓄積しない */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1289 return 0;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1290 }
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1291
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1292 /* payload_unit_start_indicatorを処理(2) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1293 /* 必要に応じ、蓄積済みPESの処理と、PES蓄積開始を行う */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1294 if( payload_unit_start_indicator ){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1295 /* PES開始 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1296 if ( pes_started ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1297 /* バッファにデータがあればPES終端なので処理してクリア */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1298 // pes2es(sp->pesbuf[pid], sp->esbuf[pid], pid, random_access_indicator);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1299 pes2es(sp->pesbuf[pid], sp->esbuf[pid], pid);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1300 pesbuf_clear(sp->pesbuf[pid]);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1301 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1302 else {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1303 pes_started = 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1304 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1305 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1306
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1307 /* PES蓄積処理 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1308 if ( pes_started ){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1309 /* PES蓄積開始済み(これからPES蓄積開始を含む)なら、payloadをPESとして追加 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1310 pesbuf_add(sp->pesbuf[pid], packet + payload_offset, payload_length);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1311 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1312 /* おつかれさまでした */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1313 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1314 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1315
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1316 #if 0
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1317 未使用なため削除
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1318 /* PMT_PID から Program(Service ID)を確定させる */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1319 static int search_pmt_program(splitter *sp, int pid)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1320 {
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1321 /* この関数は大変遅いのでなるべく使用しない */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1322 int i;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1323 for ( i = 0; i < MAX_SERVICE_ID; i++ ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1324 if ( sp->program[i].pmt_packet_id == pid ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1325 return i;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1326 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1327 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1328 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1329 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1330 #endif
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1331
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1332 /* esbufが空か判定 (ret. 0:not empty / 1: empty) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1333 static int esbuf_empty(splitesbuf_t *esbuf){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1334 return esbuf->size == 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1335 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1336
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1337 /* esbufをクリア */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1338 void esbuf_clear(splitesbuf_t *esbuf, uint64_t pts, uint64_t dts){
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1339 esbuf->size = 0;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1340 esbuf->pts = pts;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1341 esbuf->dts = dts;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1342 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1343
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1344 /* esbufにデータを追加 (ret. 0:success / -1:error) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1345 static int esbuf_add(splitesbuf_t *esbuf, const uint8_t *data, int len){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1346 if(esbuf->size + len > sizeof esbuf->buffer){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1347 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1348 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1349 memcpy(esbuf->buffer +esbuf->size, data, len);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1350 esbuf->size += len;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1351 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1352 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1353
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1354 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1355 * PESを解析してESを出力する
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1356 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1357 //static int pes2es(splitpesbuf_t *pesbuf, splitesbuf_t *esbuf, const int pid, int random_access_indicator)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1358 static int pes2es(splitpesbuf_t *pesbuf, splitesbuf_t *esbuf, const int pid)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1359 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1360 int len_pesh = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1361 int code = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1362 int flags = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1363 int len_pes = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1364 int len_pesh_supposed = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1365 int pes_extension_flags = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1366 int pes_extension_flags2 = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1367 int program_packet_sequence_counter_flag = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1368 int es_rate = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1369 const uint8_t *p = pesbuf->buffer;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1370 const uint8_t *p_end = pesbuf->buffer +pesbuf->size;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1371 int original_stuffing_length = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1372 int data_alignment_indicator = false;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1373 int es_started;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1374 int payload_offset = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1375 int payload_length = 0;
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1376 int audio_lipsync_offset = 0;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1377 int i = 0;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1378 int64_t audio_pts = 0;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1379 int adts_freq = 0;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1380 int64_t adts_frame_time = 0;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1381 int gop_start = -1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1382
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1383 /* ありがとう */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1384 /* ありがとうとコメントを書くと、
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1385 * 動作がよくなる
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1386 * バグが減る
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1387 * バイナリサイズが小さくなる
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1388 * 画質がよくなる
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1389 * 音質がよくなる
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1390 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1391 if ( esbuf == NULL ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1392 return -1; /* malloc走る前この関数は呼んじゃダメです */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1393 } else {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1394 es_started = !esbuf_empty(esbuf); /* ES蓄積開始済み */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1395 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1396
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1397 payload_offset = pesbuf_packet_start_code_prefix(pesbuf);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1398 if ( payload_offset == -1 ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1399 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1400 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1401 p += payload_offset;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1402 /* http://dvd.sourceforge.net/dvdinfo/pes-hdr.html
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1403 *
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1404 * Stream ID : type : extension present?
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1405 * (1011 1101) 0xBD : Private stream 1 (non MPEG audio, subpictures) : YES
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1406 * (1011 1110) 0xBE : Padding stream : NO
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1407 * (1011 1111) 0xBF : Private stream 2 (navigation data) : NO
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1408 * (110x xxxx) 0xC0 - 0xDF : MPEG-1 or MPEG-2 audio stream number x xxxx : YES
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1409 * (1110 xxxx) 0xE0 - 0xEF : MPEG-1 or MPEG-2 video stream number xxxx : YES
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1410 * note: DVD allows only 8 audio streams/DVD allows only 1 video stream
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1411 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1412 /* http://www2.arib.or.jp/johomem/pdf/2009/2009_0088.pdf
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1413 *
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1414 * 0xBC : プログラムストリームマップ
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1415 * 0xBD : プライベートストリーム1
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1416 * 0xBE : パディングストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1417 * 0xBF : プライベートストリーム2
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1418 * 0xC0 - 0xDF : ISO/IEC 13318 3、ISO/IEC 11172 3、ISO/IEC 13318 7 or ISO/IEC 14496 3 audio xxxx
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1419 * 0xE0 - 0xEF : ITU-T H.262、ISO/IEC 11172 2、ISO/IEC 14496 2 or ITU-T H264映像ストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1420 * 0xF0 : ECMストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1421 * 0xF1 : EMMストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1422 * 0xF2 : ITU-T勧告H.222.0 Annex A 又は ISO/IEC 13318 6 のDSMCCストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1423 * 0xF3 : ISO/IEC 13522ストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1424 * 0xF4 : ITU-T勧告 H.222.1 type A
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1425 * 0xF5 : ITU-T勧告 H.222.1 type B
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1426 * 0xF6 : ITU-T勧告 H.222.1 type C
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1427 * 0xF7 : ITU-T勧告 H.222.1 type D
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1428 * 0xF8 : ITU-T勧告 H.222.1 type E
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1429 * 0xF9 : 補助ストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1430 * 0xFA : ISO/IEC 14496 1SLパケット化ストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1431 * 0xFB : ISO/IEC 14496 1フレックスマックスストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1432 * 0xFC : メタデータストリーム
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1433 * 0xFD : 拡張ストリームID
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1434 * 0xFE : 未定義
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1435 * 0xFF : プログラムストリームディレクトリ
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1436 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1437 /* 上記より、ここでは
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1438 * MPEG-1 or MPEG-2 audio stream と
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1439 * MPEG-1 or MPEG-2 video stream と
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1440 * Private stream 1 と
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1441 * 0xFD(拡張ストリームID)を抽出する
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1442 * ?0xBF Private stream 2 落としてるけどよいの?
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1443 * >多分よくない。ffmpegではここに入る前に PRIVATE_STREAM2 のコードが入っている
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1444 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1445 code = (p[3] &0xff) | 0x100;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1446 if ( !((code >= 0x1c0 && code <= 0x1df) ||
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1447 (code >= 0x1e0 && code <= 0x1ef) ||
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1448 (code == 0x1bd) || (code == 0x1fd))) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1449 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1450 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1451 /* PES のデータ長 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1452 /* 動画のストリームである場合には、ES長は不定となるので0が許容される */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1453 len_pes = AV_RB16(p+4);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1454 /* PESヘッダ拡張部(byte 6) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1455 flags = p[6] & 0xff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1456 if ( flags & 0x04 ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1457 data_alignment_indicator = true;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1458 /* data alignment indicator */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1459 /* video start code or audio syncword. */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1460 /* おそらくここで区切るとピクチャ単位 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1461 //printf("data alignment indicator found pid[%d].\n", pid);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1462 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1463 flags = p[7] & 0xff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1464 /* PESヘッダデータ長(byte 8) */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1465 len_pesh = p[8] & 0xff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1466 p += LENGTH_PES_HEADER;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1467 payload_offset += LENGTH_PES_HEADER +len_pesh;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1468 if ( p +payload_offset >= p_end ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1469 /* PESヘッダ長すぎます */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1470 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1471 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1472
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1473 /* flags
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1474 * +---------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1475 * name |byte 7(flags) |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1476 * +-----+-----+-----+------+----------+----+----------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1477 * Bit |76 |5 |4 |3 |2 |1 |0 |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1478 * +-----+-----+-----+------+----------+----+----------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1479 * field|PTS |ESCR |ES |DSM |additional|PES |PES |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1480 * name |DTS |FLAG |RATE |Trick |copy info |CRC |Extension |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1481 * |flag | |flag |mode |flag |flag|flag |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1482 * +-----+-----+-----+------+----------+----+----------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1483 * Data |5,5 |6 |3 |1 |1 |2 |1 |(24)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1484 * byte | | | | | | | |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1485 * +-----+-----+-----+------+----------+----+----------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1486 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1487 if ( flags & PTS_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1488 if ( p +LENGTH_PTS >= p_end ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1489 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1490 }
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1491 pesbuf->pts = get_pts(p);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1492 p += LENGTH_PTS;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1493 len_pesh_supposed += LENGTH_PTS;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1494 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1495 if ( flags & DTS_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1496 if ( p +LENGTH_PTS >= p_end ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1497 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1498 }
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1499 pesbuf->dts = get_pts(p);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1500 p += LENGTH_PTS;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1501 len_pesh_supposed += LENGTH_PTS;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1502 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1503 if ( flags & ESCR_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1504 p += 6;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1505 len_pesh_supposed += 6;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1506 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1507 if ( flags & ES_RATE_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1508 es_rate = AV_RB24(p);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1509 es_rate = (es_rate >>1) & 0x3fffff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1510 es_rate = es_rate * 50;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1511 printf("pid[%d] es_rate[%d]Byte/Sec.\n", pid, es_rate);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1512 p += 3;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1513 len_pesh_supposed += 3;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1514 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1515 if ( flags & DSM_TRICK_MODE_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1516 p += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1517 len_pesh_supposed += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1518 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1519 if ( flags & COPY_INFO_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1520 p += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1521 len_pesh_supposed += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1522 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1523 if ( flags & CRC_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1524 p += 2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1525 len_pesh_supposed += 2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1526 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1527 if ( flags & EXTENSION_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1528 /* PES Extension flag
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1529 * +------------------------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1530 * name |PES Extension flag |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1531 * +-----------+-----------+----------------+------+---+--------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1532 * bit |7 |6 |5 |4 |321|0 |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1533 * +-----------+-----------+----------------+------+---+--------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1534 * field|PES private|pack header|program |P-STD |111|PES extension |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1535 * name |data flag |field flag |packet |buffer| |flag2 |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1536 * | | |sequence counter|flag | | |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1537 * +-----------+-----------+----------------+------+---+--------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1538 * Data |16 |1 |2 |2 | |1 |(23)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1539 * byte | | | | | | |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1540 * +-----------+-----------+----------------+------+---+--------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1541 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1542 if ( p >= p_end ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1543 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1544 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1545 pes_extension_flags = *p & 0xff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1546 p += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1547 len_pesh_supposed += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1548 if ( pes_extension_flags & PES_PRIVATE_DATA_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1549 p += 16;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1550 len_pesh_supposed += 16;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1551 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1552 if ( pes_extension_flags & PACK_HEADER_FIELD_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1553 p += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1554 len_pesh_supposed += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1555 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1556 if ( pes_extension_flags & PROGRAM_PACKET_SEQUENCE_COUNTER ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1557 if ( p >= p_end ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1558 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1559 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1560 program_packet_sequence_counter_flag = *p & 0xff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1561 original_stuffing_length = program_packet_sequence_counter_flag & 0x3f;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1562 p += 2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1563 len_pesh_supposed += 2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1564 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1565 if ( pes_extension_flags & PSTD_BUFFER_FLAG ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1566 p += 2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1567 len_pesh_supposed += 2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1568 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1569 if ( pes_extension_flags & PES_EXTENSION_FLAG2 ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1570 /* PES Extension flag2
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1571 * +------------------------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1572 * name |PES Extension flag2 |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1573 * +------+-----------------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1574 * bit |7 |6543210 |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1575 * +------+-----------------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1576 * field|marker|PES_extension_field_length |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1577 * name |bit | |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1578 * |'1' | |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1579 * +------+-----------------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1580 * Data |- |0 <= N <= 127 |(127)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1581 * byte | | |
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1582 * +------+-----------------------------------------------------------+
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1583 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1584 if ( p >= p_end ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1585 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1586 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1587 pes_extension_flags2 = *p & 0x7f;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1588 p += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1589 len_pesh_supposed += 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1590
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1591 p += pes_extension_flags2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1592 len_pesh_supposed += pes_extension_flags2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1593 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1594 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1595 if ( pid != 6417 && pid != 6418 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1596 // printf("es start? pid[%d]\n", pid);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1597 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1598 /* ES蓄積管理処理 */
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1599 payload_length = pesbuf->size -payload_offset;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1600 // if ( data_alignment_indicator ) { /* data_alignment_indicator 区切りでESを出力する */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1601 if ( es_started ) { /* ES にデータが蓄積されている */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1602 /*
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1603 * ビデオをファイル出力し始める条件(1. 2. を満たすこと)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1604 * 1. ESにGOP先頭を含む
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1605 * 2. PTSがCUEの時刻を過ぎていること( CUE <= PTS )
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1606 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1607 if ( (is_video_stream(pid, esbuf) == 0) && !(esbuf->started) ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1608 /* VIDEO0 を同期の基準とする */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1609 gop_start = search_gop_start_code(esbuf);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1610 if ( (gop_start != -1) && /* ESバッファにGOP_START_CODEが存在するか? */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1611 (esbuf->Program->cue <= esbuf->pts*300) ) { /* CUEを過ぎている? */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1612 /* 該当ストリームをファイル出力開始する */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1613 esbuf->started = 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1614 esbuf->Program->video_start = 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1615 esbuf->Program->video_pts = esbuf->pts;
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1616 printf("video stream. pid[%d] v_pts[%llu].\n", pid, esbuf->pts);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1617 } else {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1618 /* GOP先頭を含まないものはクリア */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1619 esbuf_clear(esbuf, pesbuf->pts, pesbuf->dts);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1620 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1621 } else if ( (is_video_stream(pid, esbuf) != -1) && !(esbuf->started) ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1622 /* VIDEO0 以外のものはVIDEO0 が開始するまでクリア */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1623 if ( !(esbuf->Program->video_start) ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1624 /*
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1625 * VIDEO0 が始まってない場合、
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1626 * VIDEON は常にクリア
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1627 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1628 esbuf_clear(esbuf, pesbuf->pts, pesbuf->dts);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1629 } else {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1630 /*
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1631 * VIDEO0 が始まっている場合、
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1632 * VIDEON の録画を開始
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1633 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1634 esbuf->started = 1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1635 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1636 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1637 /*
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1638 * オーディオをファイル出力し始める条件(1. 2. を満たすこと)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1639 * 1. 動画の蓄積は開始されている
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1640 * 2. 動画のGOPの1番目のIピクチャのPTSとオーディオのPTSを比較して以下のどちらかを満たすこと
143
e72dd5e8d53f Number of samples per ADTS packet instead of 1000 and 1024.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 124
diff changeset
1641 * 2.1. 差分が11msec以内(1024*90k/AACのサンプリング周波数)
e72dd5e8d53f Number of samples per ADTS packet instead of 1000 and 1024.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 124
diff changeset
1642 * 1024 : ADTSデータの1フレームのサンプル数
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1643 * 90k : PTSの周波数
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1644 * 2.2. 過ぎている(過ぎている場合はオーディオESの蓄積の継続と次のGOP狙いにする?)
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1645 * #動画よりオーディオ側の方が先にESバッファの蓄積を始めるハズなので気にすること無いかなぁ…
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1646 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1647 else if ( (is_audio_stream(pid, esbuf) != -1) && !(esbuf->started) ) {
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1648 if ( !(esbuf->Program->video_start) ) {
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1649 /*
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1650 * VIDEO が始まってない場合、
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1651 * ESバッファの余裕がある限り、オーディオをESバッファに蓄積し続ける
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1652 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1653 if ( esbuf->size + payload_length > sizeof esbuf->buffer ){
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1654 /* 溢れそうになったらクリア */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1655 esbuf_clear(esbuf, pesbuf->pts, pesbuf->dts);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1656 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1657 } else if ( esbuf->Program->video_start ) { /* video 蓄積が開始されている?*/
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1658 printf("audio stream. pid[%d] a_pts[%llu] v_pts[%llu] size[%d].\n", pid, esbuf->pts, esbuf->Program->video_pts, esbuf->size);
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1659 audio_lipsync_offset = 0;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1660 audio_pts = esbuf->pts;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1661 adts_freq = AnalyzeAdifHeader(esbuf);
143
e72dd5e8d53f Number of samples per ADTS packet instead of 1000 and 1024.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 124
diff changeset
1662 adts_frame_time = (int64_t)((float)1024*90000/adts_freq); /* PTSは90KHz */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1663 /* オーディオをフレーム単位で捨ててPTSを進める */
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1664 while ( (esbuf->Program->video_pts > audio_pts +adts_frame_time/2) ) {
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1665 /* オーディオデータを捨てると audio_pts は1フレーム分大きくなる */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1666 i = next_adts_start_code(esbuf, audio_lipsync_offset); /* 次のAACのデータを取得 */
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1667 if ( i != -1 ) { /* AACデータの終端か? */
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1668 audio_lipsync_offset += i;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1669 } else {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1670 /* バッファ終端まで進めたが、オーディオPTSの方が古い場合ESバッファはクリアする */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1671 esbuf_clear(esbuf, pesbuf->pts, pesbuf->dts);
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1672 break;
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1673 }
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1674 printf("audio stream drop. pid[%d] pts[%llu].\n", pid, audio_pts);
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1675 audio_pts += adts_frame_time; /* AACの1フレーム分、時間を進める */
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1676 }
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1677 if ( (esbuf->Program->video_pts <= audio_pts +adts_frame_time/2) ) {
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1678 printf("lipsync start. v_pts[%llu] a_pts[%llu].\n", esbuf->Program->video_pts, audio_pts);
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1679 memmove(esbuf->buffer +audio_lipsync_offset,
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1680 esbuf->buffer,
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1681 esbuf->size -audio_lipsync_offset);
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1682 esbuf->size -= audio_lipsync_offset;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1683 esbuf->started = 1; /* オーディオのファイル出力を有効化 */
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1684 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1685 } else {
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1686 ; /* 該当するものは無いはず */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1687 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1688 } else {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1689 /* 得に処理なし */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1690 ;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1691 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1692 /* バッファをファイルに出力してクリア */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1693 if ( esbuf->started ) { /* 該当ストリームはファイル出力の有効化をされている? */
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
1694 esbuf_write(esbuf);
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1695 esbuf_clear(esbuf, pesbuf->pts, pesbuf->dts);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1696 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1697 } else {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1698 /* ES蓄積を新たに開始 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1699 es_started = 1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1700 esbuf->pts = pesbuf->pts;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1701 esbuf->dts = pesbuf->dts;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1702 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1703 //}
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1704
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1705 /* ES蓄積処理 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1706 if ( es_started ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1707 /* ES蓄積開始済み(これからES蓄積開始を含む)なら、payloadをESとして追加 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1708 esbuf_add(esbuf, pesbuf->buffer +payload_offset, payload_length);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1709 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1710 /* お疲れさまでした */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1711 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1712 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1713
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1714 /* Program の N 番目の AUDIO STREAM であるかを返却する */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1715 static int is_audio_stream(const int pid, splitesbuf_t *esbuf)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1716 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1717 int i = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1718 program_t* program = esbuf->Program;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1719 while (i < program->audio_nb)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1720 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1721 if (program->audio[i] == pid) {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1722 return i;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1723 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1724 i++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1725 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1726 return -1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1727 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1728
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1729 /* Program の N 番目の VIDEO STREAM であるかを返却する */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1730 static int is_video_stream(const int pid, splitesbuf_t *esbuf)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1731 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1732 int i = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1733 program_t* program = esbuf->Program;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1734 while (i < program->video_nb)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1735 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1736 if (program->video[i] == pid) {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1737 return i;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1738 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1739 i++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1740 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1741 return -1;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1742 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1743
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1744 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1745 * ESをファイル出力する
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1746 * エラーハンドリングしてないね…
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1747 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1748 static int esbuf_write(splitesbuf_t *esbuf)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1749 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1750 int remain = esbuf->size;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1751 while(remain > 0)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1752 {
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
1753 remain -= write(esbuf->fd, esbuf->buffer+(esbuf->size-remain), remain);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1754 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1755 return 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1756 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1757
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1758 #if 0
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1759 未使用なため駆除
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1760 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1761 * packet dump
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1762 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1763 void dump_packet( const uint8_t *packet )
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1764 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1765 int i = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1766 uint8_t *p = (uint8_t*)packet;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1767 char tmp[17];
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1768
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1769 printf("HEADER 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F <ASCII>\n");
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1770 while(i < LENGTH_PACKET) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1771 if ( (i%16) == 0 ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1772 printf("0x%04X ", i);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1773 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1774 printf("%02x ", *(p+i));
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1775 if ( isprint(*(p+i)) ){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1776 tmp[i%16] = *(p+i);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1777 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1778 else {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1779 tmp[i%16] = '.';
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1780 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1781 if ((i%16) == 15) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1782 tmp[sizeof(tmp)-1] = '\0';
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1783 printf(" %s\n", tmp);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1784 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1785 i++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1786 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1787 putchar('\n');
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1788 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1789 #endif
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1790
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1791 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1792 * TOT の JST_time を解析する
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1793 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1794 static int parse_tot( const unsigned char* packet, time_t *t )
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1795 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1796 /* 注意事項
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1797 * 本当は TOT が有効かどうかをチェックするべきですがしていません
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1798 * サマータイム関係は無視しています
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1799 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1800 struct tm tm;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1801 time_t t2;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1802 int k;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1803 uint8_t *p = (uint8_t*)packet;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1804 unsigned int MJD;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1805 tm.tm_wday = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1806 tm.tm_yday = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1807 tm.tm_isdst = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1808
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1809 p += 8;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1810 MJD = (*(p) & 0xff) <<8;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1811 p++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1812 MJD |= *(p) & 0xff;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1813 printf("MJD[%x].\n", MJD);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1814
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1815 /* ARIB STD-B10 第2部 付録C の公式より MJD to YYYYMMDD */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1816 tm.tm_year = (int)floor((MJD - 15078.2)/365.25);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1817 tm.tm_mon = (int)floor((MJD - 14956.1 - floor(tm.tm_year * 365.25))/30.6001);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1818 tm.tm_mday = MJD - 14956 - floor(tm.tm_year * 365.25) - floor(tm.tm_mon * 30.6001);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1819 if ( tm.tm_mon == 14 || tm.tm_mon == 15 )
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1820 k = 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1821 else
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1822 k = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1823 tm.tm_year += k;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1824 tm.tm_mon = tm.tm_mon -1 - k * 12;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1825 tm.tm_mon--;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1826
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1827 /* HHMISSは2進化10進数 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1828 p++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1829 tm.tm_hour = ((*p & 0xf0) >>4)*10 + (*p & 0x0f);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1830 p++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1831 tm.tm_min = ((*p & 0xf0) >>4)*10 + (*p & 0x0f);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1832 p++;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1833 tm.tm_sec = ((*p & 0xf0) >>4)*10 + (*p & 0x0f);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1834
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1835 *t = mktime(&tm);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1836 time(&t2);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1837 // printf("time[%d] TOT[%d].\n", t2, *t);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1838
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1839 return TRUE;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1840 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1841
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1842 static int64_t get_pts(const uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1843 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1844 int64_t pts = (int64_t)((p[0] >> 1) & 0x07) << 30;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1845 pts |= (AV_RB16(p + 1) >> 1) << 15;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1846 pts |= AV_RB16(p + 3) >> 1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1847 return pts;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1848 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1849
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1850 static int get_pmt_version(const uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1851 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1852 return ((p[6] >> 1) & 0x1f);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1853 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1854
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1855 #if 0
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1856 未使用なため駆除
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1857 void search_mpeg_system_header(const uint8_t *packet)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1858 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1859 int i;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1860 uint8_t *p = (uint8_t*)packet;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1861 i = 0;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1862 for( i=0; i < LENGTH_PACKET-4; i++) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1863 if( p[i] == 0x00 && p[i+1] == 0x00 && p[i+2] == 0x01 && p[i+3] == 0xb8 ){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1864 dump_packet(packet );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1865 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1866 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1867 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1868 #endif
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1869
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1870 /*
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1871 * この関数では、現在の仕様では、先頭位置の「次の」ADTS start codeまでの長さを返却する
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1872 * ret == 0 : 仕様上あり得ない(esbuf先頭はヘッダ先頭であるため)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1873 * ret > 0 : 見つかった場合
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1874 * ret == -1 : 見つからなかった場合
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1875 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1876 static int next_adts_start_code(splitesbuf_t *esbuf, int offset)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1877 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1878 /*
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1879 * start code prefix のうち、先頭12bit は 1 固定
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1880 */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1881 uint16_t adts_start_code = 0xfff0;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1882 int i = offset +1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1883 uint16_t startcode = 0;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1884
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1885 /* 小さすぎる */
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1886 if(esbuf->size -offset < sizeof(adts_start_code)){
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1887 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1888 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1889 for(; i < esbuf->size - sizeof(adts_start_code); i++) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1890 startcode = AV_RB16(esbuf->buffer+i);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1891 if( startcode == adts_start_code ) { /* 該当位置から12bit連続1が立っているか? */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1892 #if 0
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1893 printf("adts start code found.i[%d]. 0[%02x] 1[%02x] 2[%02x] 3[%02x] 4[%02x] 5[%02x] 6[%02x]\n",
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1894 i, *(esbuf->buffer+i+0), *(esbuf->buffer+i+1), *(esbuf->buffer+i+2), *(esbuf->buffer+i+3), *(esbuf->buffer+i+4), *(esbuf->buffer+i+5), *(esbuf->buffer+i+6) );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1895 #endif
120
8e438d2a1529 add tiny lipsync code.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 119
diff changeset
1896 return (i-offset);
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1897 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1898 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1899 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1900 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1901
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1902 /* ADIF HEADER解析 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1903 static int AnalyzeAdifHeader(splitesbuf_t *esbuf)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1904 {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1905 int id = 0; /* 0:MPEG-4 1:MPEG-2 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1906 int layer = 0; /* 常に 0x00 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1907 int protection_absent = 0; /* 保護属性 0:保護なし 1:保護あり */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1908 int profile = 0; /* 00:MAIN 01:LC 10:SSR 11:(reserved) */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1909 int sampling_frequency_index = 0; /* サンプリング周波数テーブル値 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1910 int private_bit = 0; /* private bit */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1911 int channel_configuration = 0; /* チャンネル数 */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1912 int original_copy = 0;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1913 int home = 0; /* homeってなに? */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1914 int copyright_identification_bit = 0; /* 著作権証明ビット */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1915 int copyright_identification_start = 0; /* 著作権証明開始ビット */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1916 int aac_frame_length = 0; /* AACフレーム長 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1917 int adts_buffer_fullness = 0; /* ADTSバッファ残量 */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1918 int no_raw_data_blocks_in_frame = 0; /* データブロックまでの残量 */
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1919 /*
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
1920 * サンプリング周波数テーブル(ヘッダのsampling_frequency_indexが添字)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1921 * 単位:Hz
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1922 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1923 int sampling_frequency_table[16] =
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1924 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1925 96000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1926 88200,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1927 64000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1928 48000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1929 44100,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1930 32000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1931 24000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1932 22050,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1933 16000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1934 12000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1935 11025,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1936 8000,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1937 -1,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1938 -1,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1939 -1,
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1940 -1
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1941 };
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1942
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1943 uint8_t *p = esbuf->buffer;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1944 if ( esbuf->size < 8 ) {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1945 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1946 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1947
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1948 id = get_adif_id(p+1);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1949 layer = get_adif_layer(p+1);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1950 protection_absent = get_adif_protection_absent(p+1);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1951 profile = get_adif_profile(p+2);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1952 sampling_frequency_index = get_adif_sampling_frequency_index(p+2);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1953 private_bit = get_adif_private_bit(p+2);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1954 channel_configuration = get_adif_channel_configuration(p+3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1955 original_copy = get_adif_original_copy(p+3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1956 home = get_adif_home(p+3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1957 copyright_identification_bit = get_adif_copyright_idication_bit(p+3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1958 copyright_identification_start = get_adif_copyright_idication_start(p+3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1959 aac_frame_length = get_adif_aac_frame_length(p+3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1960 adts_buffer_fullness = get_adts_buffer_fullness(p+5);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1961 no_raw_data_blocks_in_frame = get_adts_no_raw_data_blocks_in_frame(p+5);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1962
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1963 /*
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1964 * とりあえず return は サンプリング周波数としておく
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1965 * 本当は取得した情報を構造体にして返却する方がいいのだろうけど、
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1966 * 利用する予定もないので取得するだけにしておく
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1967 */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1968 return sampling_frequency_table[sampling_frequency_index];
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1969 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1970
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1971 static int get_adif_id(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1972 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1973 return ((*p & 0x08) >>3);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1974 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1975
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1976 static int get_adif_layer(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1977 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1978 return ((*p & 0x06) >>1);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1979 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1980
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1981 static int get_adif_protection_absent(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1982 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1983 return (*p & 0x01);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1984 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1985
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1986 static int get_adif_profile(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1987 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1988 return ((*p & 0xc0) >>6);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1989 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1990
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1991 static int get_adif_sampling_frequency_index(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1992 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1993 return ((*p & 0x3c) >>2);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1994 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1995
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1996 static int get_adif_private_bit(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1997 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1998 return ((*p & 0x02) >>1);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
1999 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2000
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2001 static int get_adif_channel_configuration(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2002 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2003 return ((*p & 0x01) <<2 | (*(p+1) & 0xc0 >>6) );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2004 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2005
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2006 static int get_adif_original_copy(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2007 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2008 return (*p & 0x20 >>5 );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2009 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2010
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2011 static int get_adif_home(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2012 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2013 return (*p & 0x10 >>4 );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2014 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2015
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2016 static int get_adif_copyright_idication_bit(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2017 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2018 return (*p & 0x08 >>3 );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2019 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2020
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2021 static int get_adif_copyright_idication_start(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2022 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2023 return (*p & 0x04 >>2 );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2024 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2025
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2026 static int get_adif_aac_frame_length(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2027 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2028 return ( ((*p & 0x02) <<11) || ((*(p+1) & 0xff) <<3) || ((*(p+2) & 0xe0) >>5) );
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2029 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2030
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2031 static int get_adts_buffer_fullness(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2032 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2033 return ( ((*p & 0x1f) <<6) || ((*(p+1) &0xfc) >>2));
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2034 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2035
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2036 static int get_adts_no_raw_data_blocks_in_frame(uint8_t *p)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2037 {
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2038 return (*p & 0x03);
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2039 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2040
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2041 #define GOP_START_CODE (0x000001b8)
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2042 /* GOP START CODE を検索する */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2043 static int search_gop_start_code(splitesbuf_t *esbuf)
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2044 {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2045 uint32_t gop_start_code = GOP_START_CODE;
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2046 int i;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2047
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2048 /* 小さすぎる */
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2049 if ( esbuf->size < sizeof gop_start_code ){
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2050 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2051 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2052 for(i = 0; i < esbuf->size - sizeof gop_start_code; i++) {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2053 if ( (AV_RB32(esbuf->buffer +i)) == gop_start_code ) {
119
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2054 return i;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2055 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2056 }
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2057 return -1;
4e7aaa72e158 ES out early release version.
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 117
diff changeset
2058 }
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2059
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2060 /* ES 出力するファイルを作成する */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2061 static int creat_es_file(splitter *sp, int sid, int pid, int av_flag)
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2062 {
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2063 /*
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2064 * 出力ESファイルの命名規則は以下とする
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2065 *
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2066 * ファイル名のベースは --es オプションの引数
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2067 * 以下の形式で命名して、ファイルオープンまで実施する。
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2068 * ファイル名prefix_SID_AVのプログラム内番号.m2v
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2069 * ファイル名prefix_SID_AVのプログラム内番号.aac
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2070 *
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2071 * !!注意!!
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2072 * MPEG-2/MPEG-4 AAC 以外のオーディオが来た場合の処理が未実装
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2073 */
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2074
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2075 char filename[PATH_MAX];
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2076 int size = 0;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2077 char *suffix = NULL;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2078 int av_nb = 0;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2079 char suffix_a[] = "aac";
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2080 char suffix_v[] = "m2v";
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2081 filename[0] = '\0';
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2082
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2083 /* ちょっとこの辺のコードイケてないので後から直すかも */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2084 if ( av_flag == TSS_STREAM_TYPE_VIDEO ) {
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2085 suffix = suffix_v;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2086 av_nb = sp->program[sid].video_nb -1;
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2087 } else if ( av_flag == TSS_STREAM_TYPE_AUDIO ){
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2088 suffix = suffix_a;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2089 av_nb = sp->program[sid].audio_nb -1;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2090 } else {
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2091 /* ここはありえない */
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2092 return -1;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2093 }
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2094 size = strlen(sp->filename);
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2095
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2096 if ( size +16 < sizeof(filename) ) {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2097 snprintf(filename, sizeof(filename), "%s_%05d_%02d.%s", sp->filename, sid, av_nb, suffix);
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2098 filename[PATH_MAX-1] = '\0';
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2099 } else {
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2100 /* ファイル名つけられなくて困るでござるの巻 */
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2101 return -1;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2102 }
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2103 umask(0133);
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2104 if ( !(sp->esbuf[pid]->fd = open(filename, O_CREAT|O_APPEND|O_RDWR, 00644)) ) {
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2105 fprintf(stderr, "cannot open es out file. file[%s].\n", filename);
121
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2106 return -1;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2107 }
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2108 return 0;
e915d31c5bd9 add --es option
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 120
diff changeset
2109 }
122
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2110
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2111 static time_t cue2time(char *yyyymmddhhmiss)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2112 {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2113 struct tm cue_tm;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2114 time_t cue_time;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2115 char *p;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2116 int i, j;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2117 char str_yyyy[5];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2118 char str_mm[3];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2119 char str_dd[3];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2120 char str_hh[3];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2121 char str_mi[3];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2122 char str_ss[3];
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2123 str_yyyy[0] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2124 str_mm[0] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2125 str_dd[0] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2126 str_hh[0] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2127 str_mi[0] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2128 str_ss[0] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2129
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2130 p = yyyymmddhhmiss;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2131 i = strlen(p);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2132 j = strspn(p, LIST_DECIMAL);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2133 if ( i != j && i != 14 ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2134 /* 数字以外混ぜるな */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2135 return -1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2136 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2137 strncpy(str_yyyy, yyyymmddhhmiss, 4);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2138 strncpy(str_mm, yyyymmddhhmiss+4, 2);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2139 strncpy(str_dd, yyyymmddhhmiss+6, 2);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2140 strncpy(str_hh, yyyymmddhhmiss+8, 2);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2141 strncpy(str_mi, yyyymmddhhmiss+10, 2);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2142 strncpy(str_ss, yyyymmddhhmiss+12, 2);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2143 str_yyyy[4] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2144 str_mm[2] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2145 str_dd[2] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2146 str_hh[2] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2147 str_mi[2] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2148 str_ss[2] = '\0';
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2149
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2150 cue_tm.tm_sec = atoi(str_ss);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2151 cue_tm.tm_min = atoi(str_mi);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2152 cue_tm.tm_hour = atoi(str_hh);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2153 cue_tm.tm_mday = atoi(str_dd);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2154 cue_tm.tm_mon = atoi(str_mm)-1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2155 cue_tm.tm_year = atoi(str_yyyy)-1900;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2156 cue_tm.tm_isdst = -1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2157 cue_time = mktime(&cue_tm);
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2158 return cue_time;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2159 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2160
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2161 /* PCR の PID を検索する */
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2162 static int search_pcr_pid(splitter *sp, int pid)
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2163 {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2164 int i;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2165 for ( i=0; i < MAX_SERVICES; i++ ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2166 if ( sp->pcr[i].pid == pid ) {
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2167 return i;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2168 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2169 }
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2170 return -1;
4009737ea899 add es output arg:
Naoya OYAMA <naoya.oyama@gmail.com>
parents: 121
diff changeset
2171 }