12 // a_90-with-att.pdf p24 (29/99)
13 int parseDSMCChead(unsigned char *data, DSMCChead *dsmh) {
16 memset(dsmh, 0, sizeof(DSMCChead));
18 dsmh->table_id = getBit(data, &boff, 8);
19 dsmh->section_syntax_indicator = getBit(data, &boff, 1);
20 dsmh->complement_indicator = getBit(data, &boff,1);
21 dsmh->reserved1 = getBit(data, &boff, 2);
22 dsmh->section_length = getBit(data, &boff, 12);
23 dsmh->table_id_extension = getBit(data, &boff, 16);
24 dsmh->reserved2 = getBit(data, &boff, 2);
25 dsmh->version_number = getBit(data, &boff, 5);
26 dsmh->current_next_indicator = getBit(data, &boff, 1);
27 dsmh->section_number = getBit(data, &boff, 8);
28 dsmh->last_section_number = getBit(data, &boff, 8);
33 // a_90-with-att.pdf p29 (34/99)
34 // 2-STD-B24v5_4-3p3.pdf p16 (30/125)
35 int parseDSMCCbodyDII(unsigned char *data, DSMCCbodyDII *dsmbdii) {
37 DSMCCbodyDIIModule *module;
39 memset(dsmbdii, 0, sizeof(DSMCCbodyDII));
42 dsmbdii->protocolDiscriminator = getBit(data, &boff, 8);
43 dsmbdii->dsmccType = getBit(data, &boff, 8);
44 dsmbdii->messageId = getBit(data, &boff, 16);
45 dsmbdii->transaction_id = getBit(data, &boff, 32);
46 dsmbdii->reserved = getBit(data, &boff, 8);
47 dsmbdii->adaptationLength = getBit(data, &boff, 8);
48 dsmbdii->messageLength = getBit(data, &boff, 16);
49 if ( dsmbdii->adaptationLength > 0 ) {
50 dsmbdii->dsmccAdaptationHeader = allocCopy(data, &boff, dsmbdii->adaptationLength);
54 dsmbdii->downloadId = getBit(data, &boff, 32);
55 dsmbdii->blockSize = getBit(data, &boff, 16);
56 dsmbdii->windowSize = getBit(data, &boff, 8);
57 dsmbdii->ackPeriod = getBit(data, &boff, 8);
58 dsmbdii->tCDownloadWindow = getBit(data, &boff, 32);
59 dsmbdii->tCDownloadScenario = getBit(data, &boff, 32);
60 dsmbdii->compatibilityDescriptor = getBit(data, &boff, 16);
62 see http://www.atsc.org/cms/standards/a_90-with-att.pdf
64 compatibilityDescriptorLength 16
66 for(i=0;i<descriptorCount;i++) {
74 for(j=0;j<subDescriptorCount;j++) {
78 for(k=0;k<subDescriptorLength;k++) {
79 additionalInformation 8
83 boff += dsmbdii->compatibilityDescriptor * 8;
84 dsmbdii->numberOfModules = getBit(data, &boff, 16);
86 if ( dsmbdii->numberOfModules > 0 ) {
87 dsmbdii->modules = calloc(1, sizeof(DSMCCbodyDIIModule) * dsmbdii->numberOfModules + 1000);
89 for (i=0; i<dsmbdii->numberOfModules; i++) {
90 module = dsmbdii->modules + sizeof(DSMCCbodyDIIModule) * i;
91 module->moduleId = getBit(data, &boff, 16);
92 module->moduleSize = getBit(data, &boff, 32);
93 module->moduleVersion = getBit(data, &boff, 8);
94 module->moduleInfoLength = getBit(data, &boff, 8);
96 if ( *(data + boff / 8) == 0x01 ) {
97 /* Type 記述子 モジュールの型(MIME 形式等) */
98 module->descriptor_tag = getBit(data, &boff, 8);
99 module->descriptor_length = getBit(data, &boff, 8);
100 module->Type = allocCopy(data, &boff, module->descriptor_length + 1);
101 module->Type[module->descriptor_length] = '\0';
102 // +1 byte for null-terminated
104 else if ( *(data + boff / 8) == 0x02 ) {
105 /* Name 記述子 モジュール名(ファイル名) */
106 module->descriptor_tag = getBit(data, &boff, 8);
107 module->descriptor_length = getBit(data, &boff, 8);
108 module->Name = allocCopy(data, &boff, module->descriptor_length + 1);
109 module->Name[module->descriptor_length] = '\0';
111 else if ( *(data + boff / 8) == 0x03 ) {
112 /* Info 記述子 モジュール情報(文字型) */
113 module->descriptor_tag = getBit(data, &boff, 8);
114 module->descriptor_length = getBit(data, &boff, 8);
115 boff += 24; // ISO_639_language_code
116 module->Info = allocCopy(data, &boff, module->descriptor_length - 3 + 1);
117 module->Info[module->descriptor_length] = '\0';
120 module->moduleInfo = allocCopy(data, &boff, module->moduleInfoLength);
125 dsmbdii->privateDataLength = getBit(data, &boff, 8);
126 dsmbdii->privateData = allocCopy(data, &boff, dsmbdii->privateDataLength);
131 // a_90-with-att.pdf p35 (40/99)
132 int parseDSMCCbodyDDB(unsigned char *data, DSMCCbodyDDB *dsmbddb) {
135 memset(dsmbddb, 0, sizeof(DSMCCbodyDDB));
138 dsmbddb->protocolDiscriminator = getBit(data, &boff, 8);
139 dsmbddb->dsmccType = getBit(data, &boff, 8);
140 dsmbddb->messageId = getBit(data, &boff, 16);
141 dsmbddb->downloadId = getBit(data, &boff, 32);
142 dsmbddb->reserved1 = getBit(data, &boff, 8);
143 dsmbddb->adaptationLength = getBit(data, &boff, 8);
144 dsmbddb->messageLength = getBit(data, &boff, 16);
145 if ( dsmbddb->adaptationLength > 0 ) {
146 dsmbddb->dsmccAdaptationHeader = allocCopy(data, &boff, dsmbddb->adaptationLength);
150 dsmbddb->moduleId = getBit(data, &boff, 16);
151 dsmbddb->moduleVersion = getBit(data, &boff, 8);
152 dsmbddb->reserved2 = getBit(data, &boff, 8);
153 dsmbddb->blockNumber = getBit(data, &boff, 16);
154 dsmbddb->blockData = allocCopy(data, &boff, dsmbddb->messageLength);
159 void dumpDSMCC(unsigned char *ptr, int * downloadDataId, DSM_CONTROL *dsmctl)
162 DSMCCbodyDII dsmbdii;
163 DSMCCbodyDDB dsmbddb;
164 DSMCCbodyDIIModule *module;
171 len = parseDSMCChead(ptr, &dsmh);
173 //loop_len = dsmh.section_length - (len - 3 + 4); // 3は共通ヘッダ長 4はCRC
175 printf("DSMCChead=(%d:%d:%d:%d)\n",
176 dsmh.table_id, dsmh.section_length,
177 dsmh.table_id_extension, dsmh.section_number);
179 if ( dsmh.table_id == 0x3B ) {
180 len = parseDSMCCbodyDII(ptr, &dsmbdii);
182 printf("DSMCCbDII=(%d:%d:%d:%d:%d:%d) (%d:%d:%d:%d)\n",
183 dsmbdii.protocolDiscriminator, dsmbdii.dsmccType,
184 dsmbdii.messageId, dsmbdii.transaction_id,
185 dsmbdii.adaptationLength, dsmbdii.messageLength,
187 dsmbdii.downloadId , dsmbdii.blockSize , dsmbdii.compatibilityDescriptor ,
188 dsmbdii.numberOfModules);
190 for (i=0; i<dsmbdii.numberOfModules; i++) {
191 module = dsmbdii.modules + sizeof(DSMCCbodyDIIModule) * i;
195 if ( module->descriptor_tag == 0x01 ) {
196 //printf("1 %s\n", module->Type);
198 else if ( module->descriptor_tag == 0x02 ) {
199 //printf("2 %s\n", module->Name);
201 if ( !strncmp( module->Name, "LOGO", 4 ) ) {
202 //printf("%s(%d) : id = %d\n", module->Name, is_bs_cs, dsmbdii.downloadId);
203 *downloadDataId = dsmbdii.downloadId;
205 // なぜかBSにCSのロゴも載ってるため
207 else if ( !strncmp( module->Name, "CS_LOGO", 7 ) ) {
208 //printf("%s(%d) : id = %d\n", module->Name, is_bs_cs, dsmbdii.downloadId);
209 *downloadDataId = dsmbdii.downloadId;
212 else if ( module->descriptor_tag == 0x03 ) {
213 //printf("3 %s\n", module->Info);
217 else if ( dsmh.table_id == 0x3C ) {
218 len = parseDSMCCbodyDDB(ptr, &dsmbddb);
219 if ( *downloadDataId == dsmbddb.downloadId ) {
220 // if ( 33882368 == dsmbddb.downloadId ) {
223 printf("DSMCCbDDB=(%d:%d:%d:%d:%d:%d) (%d:%d:%d)\n",
224 dsmbddb.protocolDiscriminator, dsmbddb.dsmccType,
225 dsmbddb.messageId, dsmbddb.downloadId,
226 dsmbddb.adaptationLength, dsmbddb.messageLength,
228 dsmbddb.moduleId , dsmbddb.moduleVersion , dsmbddb.blockNumber);
231 for (i = 0; i < 1024; i++) {
232 if ( dsmctl[i].isUsed == 0 ) {
234 //printf("moduleId=%d as dsmctl[%d]\n", dsmbddb.moduleId, i);
235 dsmctl[i].moduleId = dsmbddb.moduleId;
236 dsmctl[i].lastBlockNumber = -1;
237 dsmctl[i].isUsed = 1;
239 if ( dsmctl[i].moduleId == dsmbddb.moduleId ) {
240 if ( dsmctl[i].lastBlockNumber + 1 == dsmbddb.blockNumber ) {
241 dsmbddb.messageLength -= 6; // length of moduleId, moduleVersion, reserved, blockNumber
242 //printf("moduleId=%d as dsmctl[%d] size %d += %d\n", dsmbddb.moduleId, i, dsmctl[i].blockSize, dsmbddb.messageLength);
243 dsmctl[i].blockData = realloc( dsmctl[i].blockData, dsmctl[i].blockSize + dsmbddb.messageLength );
244 memcpy( dsmctl[i].blockData + dsmctl[i].blockSize, dsmbddb.blockData, dsmbddb.messageLength );
245 dsmctl[i].blockSize += dsmbddb.messageLength;
246 dsmctl[i].lastBlockNumber++;
249 //printf("ignoring %d(max %d)\n", dsmbddb.blockNumber, dsmctl[i].lastBlockNumber);