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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ts.c

?? video linux conference
?? C
?? 第 1 頁 / 共 5 頁
字號:
            p_ts->i_flags |= BLOCK_FLAG_CLOCK;            p_ts->p_buffer[4] = 7 + i_stuffing;            p_ts->p_buffer[5] = 0x10;   /* flags */            p_ts->p_buffer[6] = ( 0 )&0xff;            p_ts->p_buffer[7] = ( 0 )&0xff;            p_ts->p_buffer[8] = ( 0 )&0xff;            p_ts->p_buffer[9] = ( 0 )&0xff;            p_ts->p_buffer[10]= ( ( 0 )&0x80 ) | 0x7e;            p_ts->p_buffer[11]= 0;            for( i = 12; i < 12 + i_stuffing; i++ )            {                p_ts->p_buffer[i] = 0xff;            }        }        else        {            int i_stuffing = i_payload_max - i_payload;            p_ts->p_buffer[4] = i_stuffing - 1;            if( i_stuffing > 1 )            {                p_ts->p_buffer[5] = 0x00;                for( i = 6; i < 6 + i_stuffing - 2; i++ )                {                    p_ts->p_buffer[i] = 0xff;                }            }        }    }    /* copy payload */    memcpy( &p_ts->p_buffer[188 - i_payload],            &p_pes->p_buffer[p_stream->i_pes_used], i_payload );    p_stream->i_pes_used += i_payload;    p_stream->i_pes_dts = p_pes->i_dts + p_pes->i_length *        p_stream->i_pes_used / p_pes->i_buffer;    p_stream->i_pes_length -= p_pes->i_length * i_payload / p_pes->i_buffer;    if( p_stream->i_pes_used >= (int)p_pes->i_buffer )    {        p_pes = BufferChainGet( &p_stream->chain_pes );        block_Release( p_pes );        p_pes = p_stream->chain_pes.p_first;        if( p_pes )        {            p_stream->i_pes_dts    = p_pes->i_dts;            p_stream->i_pes_length = 0;            while( p_pes )            {                p_stream->i_pes_length += p_pes->i_length;                p_pes = p_pes->p_next;            }        }        else        {            p_stream->i_pes_dts = 0;            p_stream->i_pes_length = 0;        }        p_stream->i_pes_used = 0;    }    return p_ts;}static void TSSetPCR( block_t *p_ts, mtime_t i_dts ){    mtime_t i_pcr = 9 * i_dts / 100;    p_ts->p_buffer[6]  = ( i_pcr >> 25 )&0xff;    p_ts->p_buffer[7]  = ( i_pcr >> 17 )&0xff;    p_ts->p_buffer[8]  = ( i_pcr >> 9  )&0xff;    p_ts->p_buffer[9]  = ( i_pcr >> 1  )&0xff;    p_ts->p_buffer[10]|= ( i_pcr << 7  )&0x80;}#if 0static void TSSetConstraints( sout_mux_t *p_mux, sout_buffer_chain_t *c,                              mtime_t i_length, int i_bitrate_min,                              int i_bitrate_max ){    sout_mux_sys_t  *p_sys = p_mux->p_sys;    sout_buffer_chain_t s = *c;    int i_packets = 0;    int i_packets_min = 0;    int i_packets_max = 0;    if( i_length <= 0 )    {        return;    }    i_packets     = c->i_depth;    i_packets_min = ( (int64_t)i_bitrate_min * i_length / 8 / 1000000  + 187 ) / 188;    i_packets_max = ( (int64_t)i_bitrate_max * i_length / 8 / 1000000  + 187 ) / 188;    if( i_packets < i_packets_min && i_packets_min > 0 )    {        block_t *p_pk;        int i_div = ( i_packets_min - i_packets ) / i_packets;        int i_mod = ( i_packets_min - i_packets ) % i_packets;        int i_rest = 0;        /* We need to pad with null packets (pid=0x1fff)         * We try to melt null packets with true packets */        msg_Dbg( p_mux,                 "packets=%d but min=%d -> adding %d packets of padding",                 i_packets, i_packets_min, i_packets_min - i_packets );        BufferChainInit( c );        while( ( p_pk = BufferChainGet( &s ) ) )        {            int i, i_null;            BufferChainAppend( c, p_pk );            i_null = i_div + ( i_rest + i_mod ) / i_packets;            for( i = 0; i < i_null; i++ )            {                block_t *p_null;                p_null = sout_BufferNew( p_mux->p_sout, 188 );                p_null->p_buffer[0] = 0x47;                p_null->p_buffer[1] = 0x1f;                p_null->p_buffer[2] = 0xff;                p_null->p_buffer[3] = 0x10 | p_sys->i_null_continuity_counter;                memset( &p_null->p_buffer[4], 0, 184 );                p_sys->i_null_continuity_counter =                    ( p_sys->i_null_continuity_counter + 1 ) % 16;                BufferChainAppend( c, p_null );            }            i_rest = ( i_rest + i_mod ) % i_packets;        }    }    else if( i_packets > i_packets_max && i_packets_max > 0 )    {        block_t *p_pk;        int           i;        /* Arg, we need to drop packets, I don't do something clever (like         * dropping complete pid, b frames, ... ), I just get the right amount         * of packets and discard the others */        msg_Warn( p_mux,                  "packets=%d but max=%d -> removing %d packets -> stream broken",                  i_packets, i_packets_max, i_packets - i_packets_max );        BufferChainInit( c );        for( i = 0; i < i_packets_max; i++ )        {            BufferChainAppend( c, BufferChainGet( &s ) );        }        while( ( p_pk = BufferChainGet( &s ) ) )        {            sout_BufferDelete( p_mux->p_sout, p_pk );        }    }}#endifstatic void PEStoTS( sout_instance_t *p_sout,                     sout_buffer_chain_t *c, block_t *p_pes,                     ts_stream_t *p_stream ){    uint8_t *p_data;    int     i_size;    int     b_new_pes;    /* get PES total size */    i_size = p_pes->i_buffer;    p_data = p_pes->p_buffer;    b_new_pes = VLC_TRUE;    for( ;; )    {        int           b_adaptation_field;        int           i_copy;        block_t *p_ts;        p_ts = block_New( p_sout, 188 );        /* write header         * 8b   0x47    sync byte         * 1b           transport_error_indicator         * 1b           payload_unit_start         * 1b           transport_priority         * 13b          pid         * 2b           transport_scrambling_control         * 2b           if adaptation_field 0x03 else 0x01         * 4b           continuity_counter         */        i_copy    = __MIN( i_size, 184 );        b_adaptation_field = i_size < 184 ? VLC_TRUE : VLC_FALSE;        p_ts->p_buffer[0] = 0x47;        p_ts->p_buffer[1] = ( b_new_pes ? 0x40 : 0x00 )|                            ( ( p_stream->i_pid >> 8 )&0x1f );        p_ts->p_buffer[2] = p_stream->i_pid & 0xff;        p_ts->p_buffer[3] = ( b_adaptation_field ? 0x30 : 0x10 )|                            p_stream->i_continuity_counter;        b_new_pes = VLC_FALSE;        p_stream->i_continuity_counter = (p_stream->i_continuity_counter+1)%16;        if( b_adaptation_field )        {            int i_stuffing = 184 - i_copy;            int i;            p_ts->p_buffer[4] = i_stuffing - 1;            if( i_stuffing > 1 )            {                p_ts->p_buffer[5] = 0x00;                for( i = 6; i < 6 + i_stuffing - 2; i++ )                {                    p_ts->p_buffer[i] = 0xff;                }            }        }        /* copy payload */        memcpy( &p_ts->p_buffer[188 - i_copy], p_data, i_copy );        p_data += i_copy;        i_size -= i_copy;        BufferChainAppend( c, p_ts );        if( i_size <= 0 )        {            block_t *p_next = p_pes->p_next;            p_pes->p_next = NULL;            block_Release( p_pes );            if( p_next == NULL )            {                break;            }            b_new_pes = VLC_TRUE;            p_pes = p_next;            i_size = p_pes->i_buffer;            p_data = p_pes->p_buffer;        }    }    return;}static block_t *WritePSISection( sout_instance_t *p_sout,                                       dvbpsi_psi_section_t* p_section ){    block_t   *p_psi, *p_first = NULL;    while( p_section )    {        int             i_size;        i_size =  (uint32_t)( p_section->p_payload_end - p_section->p_data )+                  ( p_section->b_syntax_indicator ? 4 : 0 );        p_psi = block_New( p_sout, i_size + 1 );        p_psi->i_pts = 0;        p_psi->i_dts = 0;        p_psi->i_length = 0;        p_psi->i_buffer = i_size + 1;        p_psi->p_buffer[0] = 0; // pointer        memcpy( p_psi->p_buffer + 1,                p_section->p_data,                i_size );        block_ChainAppend( &p_first, p_psi );        p_section = p_section->p_next;    }    return( p_first );}static void GetPAT( sout_mux_t *p_mux,                    sout_buffer_chain_t *c ){    sout_mux_sys_t       *p_sys = p_mux->p_sys;    block_t        *p_pat;    dvbpsi_pat_t         pat;    dvbpsi_psi_section_t *p_section;    dvbpsi_InitPAT( &pat, p_sys->i_tsid, p_sys->i_pat_version_number,                    1 );      // b_current_next    /* add all program (only one) */    dvbpsi_PATAddProgram( &pat,                          p_sys->i_pmt_program_number,                    // i_number                          p_sys->pmt.i_pid );   // i_pid    p_section = dvbpsi_GenPATSections( &pat,                                       0 );     // max program per section    p_pat = WritePSISection( p_mux->p_sout, p_section );    PEStoTS( p_mux->p_sout, c, p_pat, &p_sys->pat );    dvbpsi_DeletePSISections( p_section );    dvbpsi_EmptyPAT( &pat );}static uint32_t GetDescriptorLength24b( int i_length ){    uint32_t i_l1, i_l2, i_l3;    i_l1 = i_length&0x7f;    i_l2 = ( i_length >> 7 )&0x7f;    i_l3 = ( i_length >> 14 )&0x7f;    return( 0x808000 | ( i_l3 << 16 ) | ( i_l2 << 8 ) | i_l1 );}static void GetPMT( sout_mux_t *p_mux,                    sout_buffer_chain_t *c ){    sout_mux_sys_t  *p_sys = p_mux->p_sys;    block_t   *p_pmt;    dvbpsi_pmt_t        pmt;    dvbpsi_pmt_es_t     *p_es;    dvbpsi_psi_section_t *p_section;    int                 i_stream;    dvbpsi_InitPMT( &pmt,                    p_sys->i_pmt_program_number,   // program number                    p_sys->i_pmt_version_number,                    1,      // b_current_next                    p_sys->i_pcr_pid );    if( p_sys->i_mpeg4_streams > 0 )    {        uint8_t iod[4096];        bits_buffer_t bits;        bits_buffer_t bits_fix_IOD;        /* Make valgrind happy : it works at byte level not bit one so         * bit_write confuse it (but DON'T CHANGE the way that bit_write is         * working (needed when fixing some bits) */        memset( iod, 0, 4096 );        bits_initwrite( &bits, 4096, iod );	// IOD_label_scope        bits_write( &bits, 8,   0x11 );        // IOD_label        bits_write( &bits, 8,   0x01 );        // InitialObjectDescriptor        bits_align( &bits );        bits_write( &bits, 8,   0x02 );     // tag        bits_fix_IOD = bits;    // save states to fix length later        bits_write( &bits, 24,            GetDescriptorLength24b( 0 ) ); // variable length (fixed later)        bits_write( &bits, 10,  0x01 );     // ObjectDescriptorID        bits_write( &bits, 1,   0x00 );     // URL Flag        bits_write( &bits, 1,   0x00 );     // includeInlineProfileLevelFlag        bits_write( &bits, 4,   0x0f );     // reserved        bits_write( &bits, 8,   0xff );     // ODProfile (no ODcapability )        bits_write( &bits, 8,   0xff );     // sceneProfile        bits_write( &bits, 8,   0xfe );     // audioProfile (unspecified)        bits_write( &bits, 8,   0xfe );     // visualProfile( // )        bits_write( &bits, 8,   0xff );     // graphicProfile (no )        for( i_stream = 0; i_stream < p_mux->i_nb_inputs; i_stream++ )        {            ts_stream_t *p_stream;            p_stream = (ts_stream_t*)p_mux->pp_inputs[i_stream]->p_sys;            if( p_stream->i_stream_id == 0xfa ||                p_stream->i_stream_id == 0xfb ||                p_stream->i_stream_id == 0xfe )            {   

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久婷婷综合激情| 日本一区免费视频| jlzzjlzz国产精品久久| 麻豆久久久久久久| 亚洲综合无码一区二区| 久久亚洲综合av| 欧美日韩成人综合在线一区二区| 国产福利一区二区三区视频在线| 亚洲成人免费在线| 亚洲欧洲成人精品av97| 26uuu色噜噜精品一区| 欧美人牲a欧美精品| 色88888久久久久久影院野外| 国产精品亚洲一区二区三区妖精| 日韩成人精品视频| 一区二区三国产精华液| 国产精品久久毛片| 国产欧美中文在线| 久久理论电影网| 欧美电影精品一区二区| 欧美区一区二区三区| 欧美在线不卡视频| 在线观看免费成人| 色婷婷一区二区| av在线综合网| 成人高清免费在线播放| 国产精品1024| 久久超碰97人人做人人爱| 性久久久久久久久| 亚洲国产日韩a在线播放| 亚洲国产精品激情在线观看| 国产欧美一区二区在线观看| 久久久久久99精品| 久久久久亚洲蜜桃| 国产欧美日本一区二区三区| 国产日韩欧美综合在线| 日本一区二区三区国色天香| 国产精品入口麻豆九色| 国产精品色婷婷| 国产精品女人毛片| 成人欧美一区二区三区1314| 中文字幕欧美一| 亚洲人成网站色在线观看| 亚洲人成7777| 亚洲国产视频a| 日本中文字幕不卡| 精品在线播放午夜| 国产一区二区三区综合| 国产91在线看| www.亚洲在线| 欧美午夜精品久久久久久孕妇| 欧美中文字幕一二三区视频| 欧美日韩情趣电影| 欧美一区二区三区在线电影 | 国产精品亚洲第一区在线暖暖韩国| 国内精品久久久久影院一蜜桃| 国产高清久久久久| 色综合 综合色| 日韩一区二区视频在线观看| 欧美大黄免费观看| 久久久久久麻豆| 中文字幕一区日韩精品欧美| 亚洲综合成人网| 奇米影视一区二区三区小说| 丁香另类激情小说| 色婷婷av一区| 精品国产凹凸成av人导航| 国产精品久久二区二区| 一区二区三区国产精华| 久久精品99国产国产精| 成人一级片网址| 91激情在线视频| 精品噜噜噜噜久久久久久久久试看 | 香蕉成人伊视频在线观看| 麻豆国产精品官网| 成人午夜私人影院| 欧美三级电影网站| 久久精品人人做人人爽97 | 国内精品久久久久影院色| 99久久伊人网影院| 欧美一卡2卡三卡4卡5免费| 亚洲国产精品黑人久久久| 日韩国产一二三区| 99久免费精品视频在线观看| 欧美一级艳片视频免费观看| 国产精品无遮挡| 免费看欧美女人艹b| 99精品国产99久久久久久白柏| 91精品国产综合久久久蜜臀粉嫩 | 国产精品一区二区久久不卡| 日本久久精品电影| 欧美精品在欧美一区二区少妇| 国产日韩精品一区二区浪潮av| 亚洲成人动漫在线免费观看| 国产伦精品一区二区三区视频青涩| 欧美三级日本三级少妇99| 国产免费成人在线视频| 男人的天堂久久精品| 色综合久久66| 中日韩av电影| 国产一本一道久久香蕉| 欧美一级艳片视频免费观看| 亚洲激情五月婷婷| 国产成人午夜精品影院观看视频| 欧美精品一二三区| 自拍av一区二区三区| 国产一区视频网站| 日韩欧美二区三区| 午夜精品视频一区| 日本高清视频一区二区| 国产精品亲子伦对白| 韩国中文字幕2020精品| 日韩一区二区精品在线观看| 亚洲精品久久久久久国产精华液| 高清不卡一二三区| 久久网站最新地址| 九色porny丨国产精品| 制服丝袜在线91| 午夜精品久久久久久久久久| 91欧美激情一区二区三区成人| 国产欧美日韩在线| 国产成人综合亚洲网站| 久久久www成人免费毛片麻豆| 日本不卡一区二区三区| 欧美亚洲国产怡红院影院| 一区二区三区精密机械公司| 色婷婷久久久久swag精品| 最新日韩av在线| jiyouzz国产精品久久| 国产精品电影一区二区三区| voyeur盗摄精品| 国产精品福利影院| 91麻豆自制传媒国产之光| 一区在线中文字幕| 99re成人在线| 亚洲精品乱码久久久久久黑人| 91黄色免费网站| 一区二区三区国产精品| 91国产丝袜在线播放| 亚洲第一主播视频| 欧美一区中文字幕| 精品一区二区三区免费播放| 精品电影一区二区三区| 国产剧情一区二区三区| 欧美国产精品久久| 99re这里都是精品| 亚洲在线视频一区| 欧美日韩五月天| 久久国产精品一区二区| 精品国内片67194| 成人一二三区视频| 亚洲精品国产视频| 制服丝袜一区二区三区| 国产乱码一区二区三区| 国产精品免费视频网站| 欧洲日韩一区二区三区| 免费成人在线观看| 国产精品天美传媒| 色8久久精品久久久久久蜜| 免费日韩伦理电影| 中文子幕无线码一区tr| 色一区在线观看| 伦理电影国产精品| 国产精品久久网站| 欧美色视频在线观看| 亚洲成人av免费| 久久久99免费| 欧美在线视频全部完| 老司机精品视频导航| 亚洲欧美日本韩国| 欧美大尺度电影在线| 播五月开心婷婷综合| 奇米影视在线99精品| 亚洲欧洲成人av每日更新| 56国语精品自产拍在线观看| 成人自拍视频在线| 丝袜诱惑制服诱惑色一区在线观看| 26uuu亚洲婷婷狠狠天堂| 一本久道中文字幕精品亚洲嫩| 免费久久精品视频| 亚洲品质自拍视频| 欧美不卡一二三| 色先锋资源久久综合| 精品一区二区三区在线播放| 国产精品久久一级| 日韩视频一区二区在线观看| av日韩在线网站| 久久成人羞羞网站| 亚洲影视资源网| 国产精品久久久久影院| 日韩欧美国产高清| 欧美在线观看18| 成人v精品蜜桃久久一区| 婷婷综合久久一区二区三区| 中文字幕亚洲一区二区va在线| 日韩欧美黄色影院| 欧美日韩一级二级| av资源网一区| 国产91丝袜在线播放| 免费成人性网站|