--- /dev/null
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "sdt.h"
+#include "ts_ctl.h"
+
+int parseSDThead(unsigned char *data, SDThead *h) {
+ int boff = 0;
+
+ memset(h, 0, sizeof(SDThead));
+
+ boff = 0;
+ h->table_id = getBit(data, &boff, 8);
+ h->section_syntax_indicator = getBit(data, &boff, 1);
+ h->reserved_future_use1 = getBit(data, &boff, 1);
+ h->reserved1 = getBit(data, &boff, 2);
+ h->section_length = getBit(data, &boff, 12);
+ h->transport_stream_id = getBit(data, &boff, 16);
+ h->reserved2 = getBit(data, &boff, 2);
+ h->version_number = getBit(data, &boff, 5);
+ h->current_next_indicator = getBit(data, &boff, 1);
+ h->section_number = getBit(data, &boff, 8);
+ h->last_section_number = getBit(data, &boff, 8);
+ h->original_network_id = getBit(data, &boff, 16);
+ h->reserved_future_use2 = getBit(data, &boff, 8);
+
+ return 11;
+}
+
+int parseSDTbody(unsigned char *data, SDTbody *b) {
+ int boff = 0;
+
+ memset(b, 0, sizeof(SDTbody));
+
+ b->service_id = getBit(data, &boff, 16);
+ b->reserved_future_use1 = getBit(data, &boff, 3);
+ b->EIT_user_defined_flags = getBit(data, &boff, 3);
+ b->EIT_schedule_flag = getBit(data, &boff, 1);
+ b->EIT_present_following_flag = getBit(data, &boff, 1);
+ b->running_status = getBit(data, &boff, 3);
+ b->free_CA_mode = getBit(data, &boff, 1);
+ b->descriptors_loop_length = getBit(data, &boff, 12);
+
+ return 5;
+}
+
+int parseSVCdesc(unsigned char *data, SVCdesc *desc) {//0x48\82Ì\83T\81[\83r\83X\8bL\8fq\8eq\81A\95ú\91\97\8bÇ\82Ì\96¼\91O\82È\82Ç\82ª\93ü\82Á\82Ä\82¢\82é\82æ\82¤
+ int boff = 0;
+
+ memset(desc, 0, sizeof(SVCdesc));
+
+ desc->descriptor_tag = getBit(data, &boff, 8);
+ desc->descriptor_length = getBit(data, &boff, 8);
+ desc->service_type = getBit(data, &boff, 8);
+ desc->service_provider_name_length = getBit(data, &boff, 8);
+ getStr(desc->service_provider_name, data, &boff, desc->service_provider_name_length);
+ desc->service_name_length = getBit(data, &boff, 8);
+ getStr(desc->service_name, data, &boff, desc->service_name_length);
+
+ return desc->descriptor_length + 2;
+}
+int serachid(SVT_CONTROL *top, int service_id)
+{
+ SVT_CONTROL *cur = top ;
+ while(cur != NULL){
+ if(cur->event_id == service_id){
+ return 1 ;
+ }
+ cur = cur->next ;
+ }
+ return 0 ;
+}
+
+void enqueue_sdt(SVT_CONTROL *top, SVT_CONTROL *sdtptr)
+{
+ SVT_CONTROL *cur ;
+ if(top->next == NULL){
+ top->next = sdtptr ;
+ top->prev = top ;
+ return ;
+ }
+ cur = top->next ;
+ while(cur != NULL){
+ if(sdtptr->event_id < cur->event_id){
+ if(cur->prev != NULL){
+ cur->prev->next = sdtptr ;
+ sdtptr->prev = cur->prev ;
+ }
+ cur->prev = sdtptr ;
+ sdtptr->next = cur ;
+ return ;
+ }
+ if(cur->next == NULL){
+ cur->next = sdtptr ;
+ sdtptr->prev = cur ;
+ return ;
+ }
+ cur = cur->next ;
+ }
+ return ;
+
+}
+
+void dumpSDT(unsigned char *ptr, SVT_CONTROL *top)
+{
+
+ SDThead sdth;
+ SDTbody sdtb;
+ SVCdesc desc;
+ SVT_CONTROL *svtptr ;
+ int rc ;
+
+ int len = 0;
+ int loop_len = 0;
+
+ /* SDT */
+ len = parseSDThead(ptr, &sdth);
+ ptr += len;
+ loop_len = sdth.section_length - (len - 3 + 4); // 3¤Ï¶¦Ḁ̈إåÀĹ 4¤ÏCRC
+ while(loop_len > 0) {
+ len = parseSDTbody(ptr, &sdtb);
+ ptr += len;
+ loop_len -= len;
+ parseSVCdesc(ptr, &desc);
+
+ rc = serachid(top, sdtb.service_id);
+ if(rc == 0){
+ svtptr = calloc(1, sizeof(SVT_CONTROL));
+ svtptr->event_id = sdtb.service_id;
+ svtptr->original_network_id = sdth.original_network_id;
+ svtptr->transport_stream_id = sdth.transport_stream_id;
+ svtptr->event_id = sdtb.service_id;
+ memcpy(svtptr->servicename, desc.service_name, strlen(desc.service_name));
+ enqueue_sdt(top, svtptr);
+#if 0
+ printf("STATION=%s,%d,%d,%d,%d\n",
+ desc.service_name,sdtb.service_id,sdth.transport_stream_id,
+ sdth.original_network_id,sdtb.service_id);
+#endif
+#if 0
+ printf("SDT=%s,%d,%x,%x,%x,%x,%x,%x,%x\n",
+ desc.service_name, sdtb.service_id, sdtb.reserved_future_use1,
+ sdtb.EIT_user_defined_flags, sdtb.EIT_schedule_flag, sdtb.EIT_present_following_flag,
+ sdtb.running_status, sdtb.free_CA_mode, sdtb.descriptors_loop_length);
+/*
+0x01:\83f\83W\83^\83\8bTV\83T\81[\83r\83X
+0xA5:\83v\83\8d\83\82\81[\83V\83\87\83\93\89f\91\9c\83T\81[\83r\83X
+0x0C:\83f\81[\83^\83T\81[\83r\83X
+ */
+ printf("SDT=(%x:%x)%s,%d,%d,%d,%d,%d(%d,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x)\n",
+ sdth.table_id, desc.service_type,
+ desc.service_name, sdtb.service_id,
+ desc.descriptor_tag, desc.descriptor_length, desc.service_type,
+ desc.service_provider_name_length, desc.service_name_length,
+ sdth.table_id, sdth.section_syntax_indicator, sdth.reserved_future_use1,
+ sdth.reserved1, sdth.section_length, sdth.transport_stream_id,
+ sdth.reserved2, sdth.version_number, sdth.current_next_indicator,
+ sdth.section_number, sdth.last_section_number, sdth.original_network_id,
+ sdth.reserved_future_use2);
+#endif
+ }
+
+ ptr += sdtb.descriptors_loop_length;
+ loop_len -= sdtb.descriptors_loop_length;
+ }
+
+ return;
+}
+void dumpSDT_chout(unsigned char *ptr, SVT_CONTROL *top,STATION **station, int * station_count,char *ontvheader)
+{
+
+ SDThead sdth;
+ SDTbody sdtb;
+ SVCdesc desc;
+ SVT_CONTROL *svtptr ;
+ STATION * pStation = *station;
+ int rc ;
+
+ int len = 0;
+ int loop_len = 0;
+ char sid[80];
+ int stationi=*station_count;
+ /* SDT */
+ len = parseSDThead(ptr, &sdth);
+ ptr += len;
+ loop_len = sdth.section_length - (len - 3 + 4); // 3¤Ï¶¦Ḁ̈إåÀĹ 4¤ÏCRC
+ while(loop_len > 0) {
+ len = parseSDTbody(ptr, &sdtb);
+ ptr += len;
+ loop_len -= len;
+ parseSVCdesc(ptr, &desc);
+ rc = serachid(top, sdtb.service_id);
+ if(rc == 0){
+ svtptr = calloc(1, sizeof(SVT_CONTROL));
+ svtptr->event_id = sdtb.service_id;
+ svtptr->original_network_id = sdth.original_network_id;
+ svtptr->transport_stream_id = sdth.transport_stream_id;
+ svtptr->event_id = sdtb.service_id;
+ memcpy(svtptr->servicename, desc.service_name, strlen(desc.service_name));
+ if (desc.service_type == 1){
+ enqueue_sdt(top, svtptr);
+ pStation = realloc(pStation,(stationi+1)*sizeof(STATION));
+ if (!pStation) printf( "Realloc returned NULL!!! stationi = %d\n", stationi);
+ //char sidt[32];
+ //char *tt="_";
+ //sprintf(sidt, "%d", sdtb.service_id ); //ontv\83t\83H\81[\83}\83b\83g\82æ\82\82í\82©\82ç\82È\82¢
+ //STATION stt={NULL,NULL,sdth.transport_stream_id,
+ // sdth.original_network_id,sdtb.service_id};
+ //\88È\89º\82É\93W\8aJ\82µ\82½
+ //strcpy(sid,ontvheader);
+ //strcat(sid,tt);
+ //strcat(sid,sidt);
+ sprintf(sid, "%s_%d", ontvheader, sdtb.service_id );
+ pStation[stationi].name = malloc( strlen(desc.service_name) + 1 );
+ pStation[stationi].ontv = malloc( strlen(sid) + 1 );
+ pStation[stationi].tsId = sdth.transport_stream_id;
+ pStation[stationi].onId = sdth.original_network_id;
+ pStation[stationi].svId = sdtb.service_id;
+
+ strcpy(pStation[stationi].name, desc.service_name);
+ strcpy(pStation[stationi].ontv, sid);
+
+ //printf("%s\n",sttt.name);
+ //printf("%s\n",pStation[stationi].name);
+ //printf( "iii %d \n", stationi);
+ stationi++;
+
+ //sprintf(*lastservicename, "%s", "lastservice2" );
+#if 0
+ printf("STATION=%s,%d,%d,%d,%d,%d\n",
+ desc.service_name,sdtb.service_id,sdth.transport_stream_id,
+ sdth.original_network_id,sdtb.service_id,desc.service_type);
+#endif
+
+ }
+
+#if 0
+ printf("STATION=%s,%s,%d,%d,%d\n",
+ sttt.name,sttt.ontv,sttt.tsId,sttt.onId,sttt.svId
+ );
+#endif
+#if 0
+ printf("SDT=%s,%d,%x,%x,%x,%x,%x,%x,%x\n",
+ desc.service_name, sdtb.service_id, sdtb.reserved_future_use1,
+ sdtb.EIT_user_defined_flags, sdtb.EIT_schedule_flag, sdtb.EIT_present_following_flag,
+ sdtb.running_status, sdtb.free_CA_mode, sdtb.descriptors_loop_length);
+/*
+0x01:\83f\83W\83^\83\8bTV\83T\81[\83r\83X
+0xA5:\83v\83\8d\83\82\81[\83V\83\87\83\93\89f\91\9c\83T\81[\83r\83X
+0x0C:\83f\81[\83^\83T\81[\83r\83X
+ */
+
+ printf("SDT=(%x:%x)%s,%d,%d,%d,%d,%d(%d,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x)\n",
+ sdth.table_id, desc.service_type,
+ desc.service_name, sdtb.service_id,
+ desc.descriptor_tag, desc.descriptor_length, desc.service_type,
+ desc.service_provider_name_length, desc.service_name_length,
+ sdth.table_id, sdth.section_syntax_indicator, sdth.reserved_future_use1,
+ sdth.reserved1, sdth.section_length, sdth.transport_stream_id,
+ sdth.reserved2, sdth.version_number, sdth.current_next_indicator,
+ sdth.section_number, sdth.last_section_number, sdth.original_network_id,
+ sdth.reserved_future_use2);
+#endif
+ }
+ //ptr += sdtb.descriptors_loop_length;
+ loop_len -= sdtb.descriptors_loop_length;
+
+ if (loop_len>0){
+ ptr += sdtb.descriptors_loop_length;
+ }
+
+ }
+ *station = pStation;
+ *station_count = stationi;
+ //printf("stationi %d -",stationi);//stationi==294\82Å\97\8e\82¿\82é
+ return;
+}