亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? mpegts.c

?? mediastreamer2是開源的網(wǎng)絡(luò)傳輸媒體流的庫
?? C
?? 第 1 頁 / 共 3 頁
字號:
    clear_program(ts, h->id);    pcr_pid = get16(&p, p_end) & 0x1fff;    if (pcr_pid < 0)        return;    add_pid_to_pmt(ts, h->id, pcr_pid);#ifdef DEBUG_SI    av_log(ts->stream, AV_LOG_DEBUG, "pcr_pid=0x%x\n", pcr_pid);#endif    program_info_length = get16(&p, p_end) & 0xfff;    if (program_info_length < 0)        return;    p += program_info_length;    if (p >= p_end)        return;    for(;;) {        language[0] = 0;        st = 0;        stream_type = get8(&p, p_end);        if (stream_type < 0)            break;        pid = get16(&p, p_end) & 0x1fff;        if (pid < 0)            break;        desc_list_len = get16(&p, p_end) & 0xfff;        if (desc_list_len < 0)            break;        desc_list_end = p + desc_list_len;        if (desc_list_end > p_end)            break;        for(;;) {            desc_tag = get8(&p, desc_list_end);            if (desc_tag < 0)                break;            if (stream_type == STREAM_TYPE_PRIVATE_DATA) {                if((desc_tag == 0x6A) || (desc_tag == 0x7A)) {                    /*assume DVB AC-3 Audio*/                    stream_type = STREAM_TYPE_AUDIO_AC3;                } else if(desc_tag == 0x7B) {                    /* DVB DTS audio */                    stream_type = STREAM_TYPE_AUDIO_DTS;                }            }            desc_len = get8(&p, desc_list_end);            desc_end = p + desc_len;            if (desc_end > desc_list_end)                break;#ifdef DEBUG_SI            av_log(ts->stream, AV_LOG_DEBUG, "tag: 0x%02x len=%d\n",                   desc_tag, desc_len);#endif            switch(desc_tag) {            case DVB_SUBT_DESCID:                if (stream_type == STREAM_TYPE_PRIVATE_DATA)                    stream_type = STREAM_TYPE_SUBTITLE_DVB;                language[0] = get8(&p, desc_end);                language[1] = get8(&p, desc_end);                language[2] = get8(&p, desc_end);                language[3] = 0;                get8(&p, desc_end);                comp_page = get16(&p, desc_end);                anc_page = get16(&p, desc_end);                break;            case 0x0a: /* ISO 639 language descriptor */                language[0] = get8(&p, desc_end);                language[1] = get8(&p, desc_end);                language[2] = get8(&p, desc_end);                language[3] = 0;                break;            default:                break;            }            p = desc_end;        }        p = desc_list_end;#ifdef DEBUG_SI        av_log(ts->stream, AV_LOG_DEBUG, "stream_type=%d pid=0x%x\n",               stream_type, pid);#endif        /* now create ffmpeg stream */        switch(stream_type) {        case STREAM_TYPE_AUDIO_MPEG1:        case STREAM_TYPE_AUDIO_MPEG2:        case STREAM_TYPE_VIDEO_MPEG1:        case STREAM_TYPE_VIDEO_MPEG2:        case STREAM_TYPE_VIDEO_MPEG4:        case STREAM_TYPE_VIDEO_H264:        case STREAM_TYPE_VIDEO_VC1:        case STREAM_TYPE_AUDIO_AAC:        case STREAM_TYPE_AUDIO_AC3:        case STREAM_TYPE_AUDIO_DTS:        case STREAM_TYPE_SUBTITLE_DVB:            if(ts->pids[pid] && ts->pids[pid]->type == MPEGTS_PES){                pes= ts->pids[pid]->u.pes_filter.opaque;                st= pes->st;            }else{                if (ts->pids[pid]) mpegts_close_filter(ts, ts->pids[pid]); //wrongly added sdt filter probably                pes = add_pes_stream(ts, pid, pcr_pid, stream_type);                if (pes)                    st = new_pes_av_stream(pes, 0);            }            add_pid_to_pmt(ts, h->id, pid);            if(st)                av_program_add_stream_index(ts->stream, h->id, st->index);            break;        default:            /* we ignore the other streams */            break;        }        if (st) {            if (language[0] != 0) {                memcpy(st->language, language, 4);            }            if (stream_type == STREAM_TYPE_SUBTITLE_DVB) {                st->codec->sub_id = (anc_page << 16) | comp_page;            }        }    }    /* all parameters are there */    ts->stop_parse++;    mpegts_close_filter(ts, filter);}static void pat_cb(MpegTSFilter *filter, const uint8_t *section, int section_len){    MpegTSContext *ts = filter->u.section_filter.opaque;    SectionHeader h1, *h = &h1;    const uint8_t *p, *p_end;    int sid, pmt_pid;#ifdef DEBUG_SI    av_log(ts->stream, AV_LOG_DEBUG, "PAT:\n");    av_hex_dump_log(ts->stream, AV_LOG_DEBUG, (uint8_t *)section, section_len);#endif    p_end = section + section_len - 4;    p = section;    if (parse_section_header(h, &p, p_end) < 0)        return;    if (h->tid != PAT_TID)        return;    clear_programs(ts);    for(;;) {        sid = get16(&p, p_end);        if (sid < 0)            break;        pmt_pid = get16(&p, p_end) & 0x1fff;        if (pmt_pid < 0)            break;#ifdef DEBUG_SI        av_log(ts->stream, AV_LOG_DEBUG, "sid=0x%x pid=0x%x\n", sid, pmt_pid);#endif        if (sid == 0x0000) {            /* NIT info */        } else {            av_new_program(ts->stream, sid);            ts->stop_parse--;            mpegts_open_section_filter(ts, pmt_pid, pmt_cb, ts, 1);            add_pat_entry(ts, sid);            add_pid_to_pmt(ts, sid, 0); //add pat pid to program            add_pid_to_pmt(ts, sid, pmt_pid);        }    }    /* not found */    ts->stop_parse++;    mpegts_close_filter(ts, filter);}static void mpegts_set_service(MpegTSContext *ts){    mpegts_open_section_filter(ts, PAT_PID,                                                pat_cb, ts, 1);}static void sdt_cb(MpegTSFilter *filter, const uint8_t *section, int section_len){    MpegTSContext *ts = filter->u.section_filter.opaque;    SectionHeader h1, *h = &h1;    const uint8_t *p, *p_end, *desc_list_end, *desc_end;    int onid, val, sid, desc_list_len, desc_tag, desc_len, service_type;    char *name, *provider_name;#ifdef DEBUG_SI    av_log(ts->stream, AV_LOG_DEBUG, "SDT:\n");    av_hex_dump_log(ts->stream, AV_LOG_DEBUG, (uint8_t *)section, section_len);#endif    p_end = section + section_len - 4;    p = section;    if (parse_section_header(h, &p, p_end) < 0)        return;    if (h->tid != SDT_TID)        return;    onid = get16(&p, p_end);    if (onid < 0)        return;    val = get8(&p, p_end);    if (val < 0)        return;    for(;;) {        sid = get16(&p, p_end);        if (sid < 0)            break;        val = get8(&p, p_end);        if (val < 0)            break;        desc_list_len = get16(&p, p_end) & 0xfff;        if (desc_list_len < 0)            break;        desc_list_end = p + desc_list_len;        if (desc_list_end > p_end)            break;        for(;;) {            desc_tag = get8(&p, desc_list_end);            if (desc_tag < 0)                break;            desc_len = get8(&p, desc_list_end);            desc_end = p + desc_len;            if (desc_end > desc_list_end)                break;#ifdef DEBUG_SI            av_log(ts->stream, AV_LOG_DEBUG, "tag: 0x%02x len=%d\n",                   desc_tag, desc_len);#endif            switch(desc_tag) {            case 0x48:                service_type = get8(&p, p_end);                if (service_type < 0)                    break;                provider_name = getstr8(&p, p_end);                if (!provider_name)                    break;                name = getstr8(&p, p_end);                if (name) {                    AVProgram *program = av_new_program(ts->stream, sid);                    if(program)                        av_set_program_name(program, provider_name, name);                }                break;            default:                break;            }            p = desc_end;        }        p = desc_list_end;    }}/* scan services in a transport stream by looking at the SDT */static void mpegts_scan_sdt(MpegTSContext *ts){    mpegts_open_section_filter(ts, SDT_PID,                                                sdt_cb, ts, 1);}static int64_t get_pts(const uint8_t *p){    int64_t pts = (int64_t)((p[0] >> 1) & 0x07) << 30;    pts |= (AV_RB16(p + 1) >> 1) << 15;    pts |=  AV_RB16(p + 3) >> 1;    return pts;}/* return non zero if a packet could be constructed */static void mpegts_push_data(MpegTSFilter *filter,                             const uint8_t *buf, int buf_size, int is_start){    PESContext *pes = filter->u.pes_filter.opaque;    MpegTSContext *ts = pes->ts;    const uint8_t *p;    int len, code;    if(!ts->pkt)        return;    if (is_start) {        pes->state = MPEGTS_HEADER;        pes->data_index = 0;    }    p = buf;    while (buf_size > 0) {        switch(pes->state) {        case MPEGTS_HEADER:            len = PES_START_SIZE - pes->data_index;            if (len > buf_size)                len = buf_size;            memcpy(pes->header + pes->data_index, p, len);            pes->data_index += len;            p += len;            buf_size -= len;            if (pes->data_index == PES_START_SIZE) {                /* we got all the PES or section header. We can now                   decide */#if 0                av_hex_dump_log(pes->stream, AV_LOG_DEBUG, pes->header, pes->data_index);#endif                if (pes->header[0] == 0x00 && pes->header[1] == 0x00 &&                    pes->header[2] == 0x01) {                    /* it must be an mpeg2 PES stream */                    code = pes->header[3] | 0x100;                    if (!((code >= 0x1c0 && code <= 0x1df) ||                          (code >= 0x1e0 && code <= 0x1ef) ||                          (code == 0x1bd) || (code == 0x1fd)))                        goto skip;                    if (!pes->st) {                        /* allocate stream */                        new_pes_av_stream(pes, code);                    }                    pes->state = MPEGTS_PESHEADER_FILL;                    pes->total_size = AV_RB16(pes->header + 4);                    /* NOTE: a zero total size means the PES size is                       unbounded */                    if (pes->total_size)                        pes->total_size += 6;                    pes->pes_header_size = pes->header[8] + 9;                } else {                    /* otherwise, it should be a table */                    /* skip packet */                skip:                    pes->state = MPEGTS_SKIP;                    continue;                }            }            break;            /**********************************************/            /* PES packing parsing */        case MPEGTS_PESHEADER_FILL:            len = pes->pes_header_size - pes->data_index;            if (len > buf_size)                len = buf_size;            memcpy(pes->header + pes->data_index, p, len);            pes->data_index += len;            p += len;            buf_size -= len;            if (pes->data_index == pes->pes_header_size) {                const uint8_t *r;                unsigned int flags;                flags = pes->header[7];                r = pes->header + 9;                pes->pts = AV_NOPTS_VALUE;                pes->dts = AV_NOPTS_VALUE;                if ((flags & 0xc0) == 0x80) {                    pes->pts = get_pts(r);                    r += 5;                } else if ((flags & 0xc0) == 0xc0) {                    pes->pts = get_pts(r);                    r += 5;                    pes->dts = get_pts(r);                    r += 5;                }                /* we got the full header. We parse it and get the payload */                pes->state = MPEGTS_PAYLOAD;            }            break;        case MPEGTS_PAYLOAD:            if (pes->total_size) {                len = pes->total_size - pes->data_index;                if (len > buf_size)                    len = buf_size;            } else {                len = buf_size;            }            if (len > 0) {                AVPacket *pkt = ts->pkt;                if (pes->st && av_new_packet(pkt, len) == 0) {                    memcpy(pkt->data, p, len);                    pkt->stream_index = pes->st->index;                    pkt->pts = pes->pts;                    pkt->dts = pes->dts;                    /* reset pts values */                    pes->pts = AV_NOPTS_VALUE;                    pes->dts = AV_NOPTS_VALUE;                    ts->stop_parse = 1;                    return;                }            }            buf_size = 0;            break;        case MPEGTS_SKIP:            buf_size = 0;            break;        }    }}static AVStream* new_pes_av_stream(PESContext *pes, uint32_t code){    AVStream *st;    int codec_type, codec_id;    switch(pes->stream_type){    case STREAM_TYPE_AUDIO_MPEG1:    case STREAM_TYPE_AUDIO_MPEG2:        codec_type = CODEC_TYPE_AUDIO;        codec_id = CODEC_ID_MP3;        break;    case STREAM_TYPE_VIDEO_MPEG1:    case STREAM_TYPE_VIDEO_MPEG2:        codec_type = CODEC_TYPE_VIDEO;        codec_id = CODEC_ID_MPEG2VIDEO;        break;    case STREAM_TYPE_VIDEO_MPEG4:        codec_type = CODEC_TYPE_VIDEO;        codec_id = CODEC_ID_MPEG4;        break;    case STREAM_TYPE_VIDEO_H264:        codec_type = CODEC_TYPE_VIDEO;        codec_id = CODEC_ID_H264;        break;    case STREAM_TYPE_VIDEO_VC1:        codec_type = CODEC_TYPE_VIDEO;        codec_id = CODEC_ID_VC1;        break;    case STREAM_TYPE_AUDIO_AAC:        codec_type = CODEC_TYPE_AUDIO;        codec_id = CODEC_ID_AAC;        break;    case STREAM_TYPE_AUDIO_AC3:        codec_type = CODEC_TYPE_AUDIO;        codec_id = CODEC_ID_AC3;        break;    case STREAM_TYPE_AUDIO_DTS:        codec_type = CODEC_TYPE_AUDIO;        codec_id = CODEC_ID_DTS;        break;    case STREAM_TYPE_SUBTITLE_DVB:        codec_type = CODEC_TYPE_SUBTITLE;        codec_id = CODEC_ID_DVB_SUBTITLE;        break;    default:        if (code >= 0x1c0 && code <= 0x1df) {            codec_type = CODEC_TYPE_AUDIO;            codec_id = CODEC_ID_MP2;        } else if (code == 0x1bd) {            codec_type = CODEC_TYPE_AUDIO;            codec_id = CODEC_ID_AC3;        } else {            codec_type = CODEC_TYPE_VIDEO;            codec_id = CODEC_ID_MPEG1VIDEO;        }        break;    }    st = av_new_stream(pes->stream, pes->pid);    if (st) {        av_set_pts_info(st, 33, 1, 90000);        st->priv_data = pes;        st->codec->codec_type = codec_type;        st->codec->codec_id = codec_id;        st->need_parsing = AVSTREAM_PARSE_FULL;        pes->st = st;    }    return st;}static PESContext *add_pes_stream(MpegTSContext *ts, int pid, int pcr_pid, int stream_type){    MpegTSFilter *tss;    PESContext *pes;    /* if no pid found, then add a pid context */    pes = av_mallocz(sizeof(PESContext));    if (!pes)        return 0;    pes->ts = ts;    pes->stream = ts->stream;    pes->pid = pid;    pes->pcr_pid = pcr_pid;    pes->stream_type = stream_type;    tss = mpegts_open_pes_filter(ts, pid, mpegts_push_data, pes);    if (!tss) {        av_free(pes);        return 0;    }    return pes;}/* handle one TS packet */static void handle_packet(MpegTSContext *ts, const uint8_t *packet){    AVFormatContext *s = ts->stream;    MpegTSFilter *tss;    int len, pid, cc, cc_ok, afc, is_start;    const uint8_t *p, *p_end;    pid = AV_RB16(packet + 1) & 0x1fff;    if(pid && discard_pid(ts, pid))        return;    is_start = packet[1] & 0x40;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区在线观看| 色播五月激情综合网| 欧美刺激午夜性久久久久久久| 亚洲大片精品永久免费| 欧美私人免费视频| 石原莉奈一区二区三区在线观看| 日韩欧美的一区二区| 激情五月婷婷综合网| 国产日本欧洲亚洲| 一本久久a久久免费精品不卡| 一区二区三区久久久| 在线成人高清不卡| 国产老妇另类xxxxx| 国产精品理论在线观看| 欧美性大战xxxxx久久久| 免费在线看一区| 久久精品无码一区二区三区| av不卡免费在线观看| 亚洲成人在线免费| 久久网站热最新地址| 91麻豆国产香蕉久久精品| 视频一区欧美精品| 国产精品少妇自拍| 欧美日韩国产精选| 国产精品77777竹菊影视小说| 亚洲人成网站色在线观看| 日韩亚洲欧美在线观看| eeuss影院一区二区三区| 亚洲午夜久久久久| 中文幕一区二区三区久久蜜桃| 欧美亚洲综合一区| 国产麻豆一精品一av一免费| 亚洲国产一区二区视频| 国产喷白浆一区二区三区| 欧美二区乱c少妇| 成人国产免费视频| 极品销魂美女一区二区三区| 亚洲综合一区二区精品导航| 亚洲精品一区二区三区福利 | 欧美96一区二区免费视频| 久久久国产精华| 91精品在线观看入口| 91在线精品一区二区| 国内外精品视频| 亚洲第一成人在线| 亚洲色图20p| 国产精品欧美精品| 精品99999| 这里只有精品99re| 色婷婷精品大在线视频| 国产风韵犹存在线视精品| 麻豆精品久久久| 日韩精品高清不卡| 亚洲乱码国产乱码精品精的特点| www国产亚洲精品久久麻豆| 欧美喷潮久久久xxxxx| 色偷偷一区二区三区| 成人精品亚洲人成在线| 国产乱码精品一区二区三| 免费高清在线一区| 日韩 欧美一区二区三区| 亚洲资源中文字幕| 亚洲精品视频在线观看网站| 国产精品成人免费| 亚洲欧洲日韩综合一区二区| 国产日韩欧美制服另类| 久久久久国产精品麻豆ai换脸 | 亚洲午夜免费福利视频| 亚洲欧美另类小说| 亚洲激情欧美激情| 一二三区精品视频| 亚洲精品成人少妇| 一区二区三区国产精华| 一区二区免费在线播放| 一区二区三区在线视频免费观看| 国产精品国产自产拍在线| 中文字幕不卡三区| 国产精品电影一区二区三区| 国产精品免费看片| 国产精品久久久久久久久快鸭 | 国产亚洲成av人在线观看导航 | 欧美一区二区在线看| 91精品国模一区二区三区| 欧美一区二区三区不卡| 91精品国产一区二区三区蜜臀| 欧美喷水一区二区| 欧美一区二区三区色| 欧美电视剧在线看免费| 久久久久九九视频| 中文字幕亚洲欧美在线不卡| 亚洲欧美日韩国产综合在线| 亚洲一二三专区| 日韩不卡在线观看日韩不卡视频| 日本91福利区| 国产xxx精品视频大全| 91在线国产福利| 欧美色爱综合网| 日韩午夜激情免费电影| 国产婷婷精品av在线| 亚洲男同性恋视频| 日本sm残虐另类| 成人免费视频网站在线观看| 日韩免费高清av| 欧美激情中文字幕| 一区二区三区欧美日| 久久精品国产在热久久| 成人性生交大片免费看中文| 在线观看av一区| 精品人在线二区三区| 国产精品美女视频| 亚洲国产精品尤物yw在线观看| 久久精品国产一区二区三区免费看| 国产盗摄视频一区二区三区| 91福利精品第一导航| 亚洲精品一区二区三区影院 | 欧美国产日韩一二三区| 亚洲精品免费在线| 国产一区二区中文字幕| 欧美在线一区二区| 国产色婷婷亚洲99精品小说| 亚洲午夜精品网| 成人av网在线| 欧美一区二区三区视频免费播放 | 美女网站色91| 成人a级免费电影| 日韩欧美国产综合| 亚洲精品日韩专区silk| 国产精品一区二区无线| 欧美日韩国产电影| 亚洲日本韩国一区| 国产精品一区二区三区四区| 欧美猛男gaygay网站| 欧美激情在线一区二区| 日韩电影在线观看一区| 91美女视频网站| 国产女人aaa级久久久级| 日韩电影一区二区三区| 欧美主播一区二区三区| 国产精品久久久久四虎| 国产美女一区二区| 精品少妇一区二区三区在线视频| 亚洲一区二区三区四区不卡| 成人黄色网址在线观看| 久久蜜桃av一区二区天堂| 午夜精品免费在线| 91黄色免费观看| 国产精品国产三级国产aⅴ无密码| 美国一区二区三区在线播放| 欧美在线一区二区三区| 亚洲精品乱码久久久久久日本蜜臀| 极品少妇xxxx精品少妇偷拍| 日韩一二在线观看| 蜜桃视频第一区免费观看| 欧美日韩成人在线一区| 亚洲www啪成人一区二区麻豆| 一本色道久久综合狠狠躁的推荐| 国产欧美精品在线观看| 国产一区二区不卡| 久久久精品综合| 国产成人精品影视| 国产日本亚洲高清| 不卡的电视剧免费网站有什么| 国产亚洲va综合人人澡精品| 国产乱码精品一区二区三区av | 欧美一区二区播放| 天天操天天综合网| 8v天堂国产在线一区二区| 丝袜诱惑制服诱惑色一区在线观看| 欧亚洲嫩模精品一区三区| 一个色在线综合| 欧美乱熟臀69xxxxxx| 美女网站色91| 国产三级久久久| 成人午夜伦理影院| 亚洲天堂成人在线观看| 欧美午夜在线观看| 日韩国产欧美三级| 精品国产免费一区二区三区四区 | 亚洲成人精品影院| 91精品欧美一区二区三区综合在 | 日韩视频不卡中文| 久久er99精品| 国产精品丝袜91| 欧美专区日韩专区| 久久国产欧美日韩精品| 久久久久久免费毛片精品| 波多野结衣91| 亚洲国产精品天堂| 日韩美女在线视频 | 玉米视频成人免费看| 欧美系列亚洲系列| 激情文学综合丁香| 亚洲欧美一区二区三区国产精品| 欧美午夜不卡在线观看免费| eeuss鲁片一区二区三区 | 免费欧美高清视频| 中文字幕+乱码+中文字幕一区| 99国产精品久久久久久久久久久| 亚洲精品成a人| 欧美大白屁股肥臀xxxxxx|