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

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

?? ts.c

?? video linux conference
?? C
?? 第 1 頁 / 共 5 頁
字號:
                                i_header_size = 0x24;                                b_data_alignment = 1;                            }                        }                        else if( p_data->i_length < 0 ||                                 p_data->i_length > 2000000 )                        {                            /* FIXME choose a better value, but anyway we                             * should never have to do that */                            p_data->i_length = 1000;                        }                        p_stream->i_pes_length += p_data->i_length;                        if( p_stream->i_pes_dts == 0 )                        {                            p_stream->i_pes_dts = p_data->i_dts;                        }                        /* Convert to pes */                        if( p_stream->i_stream_id == 0xa0 &&                            p_data->i_pts <= 0 )                        {                            /* XXX yes I know, it's awfull, but it's needed,                             * so don't remove it ... */                            p_data->i_pts = p_data->i_dts;                        }                        E_( EStoPES )( p_mux->p_sout, &p_data, p_data,                                       p_input->p_fmt, p_stream->i_stream_id,                                       1, b_data_alignment, i_header_size, 0 );                        BufferChainAppend( &p_stream->chain_pes, p_data );                        if( p_sys->b_use_key_frames && p_stream == p_pcr_stream                            && (p_data->i_flags & BLOCK_FLAG_TYPE_I)                            && !(p_data->i_flags & BLOCK_FLAG_NO_KEYFRAME)                            && (p_stream->i_pes_length > 400000) )                        {                            i_shaping_delay = p_stream->i_pes_length;                            p_stream->b_key_frame = 1;                        }                    }                }            }            if( b_ok )            {                break;            }        }        /* save */        i_pcr_dts      = p_pcr_stream->i_pes_dts;        i_pcr_length   = p_pcr_stream->i_pes_length;        p_pcr_stream->b_key_frame = 0;        /* msg_Dbg( p_mux, "starting muxing %lldms", i_pcr_length / 1000 ); */        /* 2: calculate non accurate total size of muxed ts */        i_packet_count = 0;        for( i = 0; i < p_mux->i_nb_inputs; i++ )        {            ts_stream_t *p_stream = (ts_stream_t*)p_mux->pp_inputs[i]->p_sys;            block_t *p_pes;            /* False for pcr stream but it will be enough to do PCR algo */            for( p_pes = p_stream->chain_pes.p_first; p_pes != NULL;                 p_pes = p_pes->p_next )            {                int i_size = p_pes->i_buffer;                if( p_pes->i_dts + p_pes->i_length >                    p_pcr_stream->i_pes_dts + p_pcr_stream->i_pes_length )                {                    mtime_t i_frag = p_pcr_stream->i_pes_dts +                        p_pcr_stream->i_pes_length - p_pes->i_dts;                    if( i_frag < 0 )                    {                        /* Next stream */                        break;                    }                    i_size = p_pes->i_buffer * i_frag / p_pes->i_length;                }                i_packet_count += ( i_size + 183 ) / 184;            }        }        /* add overhead for PCR (not really exact) */        i_packet_count += (8 * i_pcr_length / p_sys->i_pcr_delay + 175) / 176;        /* 3: mux PES into TS */        BufferChainInit( &chain_ts );        /* append PAT/PMT  -> FIXME with big pcr delay it won't have enough pat/pmt */        GetPAT( p_mux, &chain_ts );        GetPMT( p_mux, &chain_ts );        i_packet_pos = 0;        i_packet_count += chain_ts.i_depth;        /* msg_Dbg( p_mux, "estimated pck=%d", i_packet_count ); */        for( ;; )        {            int         i_stream;            mtime_t     i_dts;            ts_stream_t *p_stream;            sout_input_t *p_input;            block_t *p_ts;            vlc_bool_t   b_pcr;            /* Select stream (lowest dts) */            for( i = 0, i_stream = -1, i_dts = 0; i < p_mux->i_nb_inputs; i++ )            {                p_input = p_mux->pp_inputs[i];                p_stream = (ts_stream_t*)p_mux->pp_inputs[i]->p_sys;                if( p_stream->i_pes_dts == 0 )                {                    continue;                }                if( i_stream == -1 ||                    p_stream->i_pes_dts < i_dts )                {                    i_stream = i;                    i_dts = p_stream->i_pes_dts;                }            }            if( i_stream == -1 || i_dts > i_pcr_dts + i_pcr_length )            {                break;            }            p_stream = (ts_stream_t*)p_mux->pp_inputs[i_stream]->p_sys;            /* do we need to issue pcr */            b_pcr = VLC_FALSE;            if( p_stream == p_pcr_stream &&                i_pcr_dts + i_packet_pos * i_pcr_length / i_packet_count >=                p_sys->i_pcr + p_sys->i_pcr_delay )            {                b_pcr = VLC_TRUE;                p_sys->i_pcr = i_pcr_dts + i_packet_pos *                    i_pcr_length / i_packet_count;            }            /* Build the TS packet */            p_ts = TSNew( p_mux, p_stream, b_pcr );            if( p_sys->csa != NULL &&                 (p_input->p_fmt->i_cat != AUDIO_ES || p_sys->b_crypt_audio) )            {                p_ts->i_flags |= BLOCK_FLAG_SCRAMBLED;            }            i_packet_pos++;            /* */            BufferChainAppend( &chain_ts, p_ts );        }        /* 4: date and send */        TSSchedule( p_mux, &chain_ts, i_pcr_length, i_pcr_dts );    }}#define STD_PES_PAYLOAD 170static block_t *FixPES( sout_mux_t *p_mux, block_fifo_t *p_fifo ){    block_t *p_data;    int i_size;    p_data = block_FifoShow( p_fifo );    i_size = p_data->i_buffer;    if( i_size == STD_PES_PAYLOAD )    {        return block_FifoGet( p_fifo );    }    else if( i_size > STD_PES_PAYLOAD )    {        block_t *p_new = block_New( p_mux, STD_PES_PAYLOAD );        p_mux->p_vlc->pf_memcpy( p_new->p_buffer, p_data->p_buffer, STD_PES_PAYLOAD );        p_new->i_pts = p_data->i_pts;        p_new->i_dts = p_data->i_dts;        p_new->i_length = p_data->i_length * STD_PES_PAYLOAD                            / p_data->i_buffer;        p_data->i_buffer -= STD_PES_PAYLOAD;        p_data->p_buffer += STD_PES_PAYLOAD;        p_data->i_pts += p_new->i_length;        p_data->i_dts += p_new->i_length;        p_data->i_length -= p_new->i_length;        p_data->i_flags |= BLOCK_FLAG_NO_KEYFRAME;        return p_new;    }    else    {        block_t *p_next;        int i_copy;        p_data = block_FifoGet( p_fifo );        p_data = block_Realloc( p_data, 0, STD_PES_PAYLOAD );        p_next = block_FifoShow( p_fifo );        if ( p_data->i_flags & BLOCK_FLAG_NO_KEYFRAME )        {            p_data->i_flags &= ~BLOCK_FLAG_NO_KEYFRAME;            p_data->i_pts = p_next->i_pts;            p_data->i_dts = p_next->i_dts;        }        i_copy = __MIN( STD_PES_PAYLOAD - i_size, p_next->i_buffer );        p_mux->p_vlc->pf_memcpy( &p_data->p_buffer[i_size], p_next->p_buffer,                                 i_copy );        p_next->i_pts += p_next->i_length * i_copy / p_next->i_buffer;        p_next->i_dts += p_next->i_length * i_copy / p_next->i_buffer;        p_next->i_length -= p_next->i_length * i_copy / p_next->i_buffer;        p_next->i_buffer -= i_copy;        p_next->p_buffer += i_copy;        p_next->i_flags |= BLOCK_FLAG_NO_KEYFRAME;        if( !p_next->i_buffer )        {            p_next = block_FifoGet( p_fifo );            block_Release( p_next );        }        return p_data;    }}static void TSSchedule( sout_mux_t *p_mux, sout_buffer_chain_t *p_chain_ts,                        mtime_t i_pcr_length, mtime_t i_pcr_dts ){    sout_mux_sys_t  *p_sys = p_mux->p_sys;    sout_buffer_chain_t new_chain;    int i_packet_count = p_chain_ts->i_depth;    int i;    BufferChainInit( &new_chain );    if ( i_pcr_length <= 0 )    {        i_pcr_length = i_packet_count;    }    for( i = 0; i < i_packet_count; i++ )    {        block_t *p_ts = BufferChainGet( p_chain_ts );        mtime_t i_new_dts = i_pcr_dts + i_pcr_length * i / i_packet_count;        BufferChainAppend( &new_chain, p_ts );        if( p_ts->i_dts &&            p_ts->i_dts + p_sys->i_dts_delay * 2/3 < i_new_dts )        {            mtime_t i_max_diff = i_new_dts - p_ts->i_dts;            mtime_t i_cut_dts = p_ts->i_dts;            p_ts = BufferChainPeek( p_chain_ts );            i++;            i_new_dts = i_pcr_dts + i_pcr_length * i / i_packet_count;            while ( p_ts != NULL && i_new_dts - p_ts->i_dts >= i_max_diff )            {                p_ts = BufferChainGet( p_chain_ts );                i_max_diff = i_new_dts - p_ts->i_dts;                i_cut_dts = p_ts->i_dts;                BufferChainAppend( &new_chain, p_ts );                p_ts = BufferChainPeek( p_chain_ts );                i++;                i_new_dts = i_pcr_dts + i_pcr_length * i / i_packet_count;            }            msg_Dbg( p_mux, "adjusting rate at "I64Fd"/"I64Fd" (%d/%d)",                     i_cut_dts - i_pcr_dts, i_pcr_length, new_chain.i_depth,                     p_chain_ts->i_depth );            if ( new_chain.i_depth )                TSDate( p_mux, &new_chain,                        i_cut_dts - i_pcr_dts,                        i_pcr_dts );            if ( p_chain_ts->i_depth )                TSSchedule( p_mux,                            p_chain_ts, i_pcr_dts + i_pcr_length - i_cut_dts,                            i_cut_dts );            return;        }    }    if ( new_chain.i_depth )        TSDate( p_mux, &new_chain, i_pcr_length, i_pcr_dts );}static void TSDate( sout_mux_t *p_mux, sout_buffer_chain_t *p_chain_ts,                    mtime_t i_pcr_length, mtime_t i_pcr_dts ){    sout_mux_sys_t  *p_sys = p_mux->p_sys;    int i_packet_count = p_chain_ts->i_depth;    int i;    if ( i_pcr_length / 1000 > 0 )    {        int i_bitrate = ((uint64_t)i_packet_count * 188 * 8000)                          / (uint64_t)(i_pcr_length / 1000);        if ( p_sys->i_bitrate_max && p_sys->i_bitrate_max < i_bitrate )        {            msg_Warn( p_mux, "max bitrate exceeded at "I64Fd                      " (%d bi/s for %d pkt in "I64Fd" us)",                      i_pcr_dts + p_sys->i_shaping_delay * 3 / 2 - mdate(),                      i_bitrate, i_packet_count, i_pcr_length);        }#if 0        else        {            msg_Dbg( p_mux, "starting at "I64Fd                     " (%d bi/s for %d packets in "I64Fd" us)",                     i_pcr_dts + p_sys->i_shaping_delay * 3 / 2 - mdate(),                     i_bitrate, i_packet_count, i_pcr_length);        }#endif    }    else    {        /* This shouldn't happen, but happens in some rare heavy load         * and packet losses conditions. */        i_pcr_length = i_packet_count;    }    /* msg_Dbg( p_mux, "real pck=%d", i_packet_count ); */    for( i = 0; i < i_packet_count; i++ )    {        block_t *p_ts = BufferChainGet( p_chain_ts );        mtime_t i_new_dts = i_pcr_dts + i_pcr_length * i / i_packet_count;        p_ts->i_dts    = i_new_dts;        p_ts->i_length = i_pcr_length / i_packet_count;        if( p_ts->i_flags & BLOCK_FLAG_CLOCK )        {            /* msg_Dbg( p_mux, "pcr=%lld ms", p_ts->i_dts / 1000 ); */            TSSetPCR( p_ts, p_ts->i_dts - p_sys->i_dts_delay );        }        if( p_ts->i_flags & BLOCK_FLAG_SCRAMBLED )        {            csa_Encrypt( p_sys->csa, p_ts->p_buffer, 0 );        }        /* latency */        p_ts->i_dts += p_sys->i_shaping_delay * 3 / 2;        sout_AccessOutWrite( p_mux->p_access, p_ts );    }}static block_t *TSNew( sout_mux_t *p_mux, ts_stream_t *p_stream,                       vlc_bool_t b_pcr ){    block_t *p_pes = p_stream->chain_pes.p_first;    block_t *p_ts;    vlc_bool_t b_new_pes = VLC_FALSE;    vlc_bool_t b_adaptation_field = VLC_FALSE;    int        i_payload_max = 184 - ( b_pcr ? 8 : 0 );    int        i_payload;    if( p_stream->i_pes_used <= 0 )    {        b_new_pes = VLC_TRUE;    }    i_payload = __MIN( (int)p_pes->i_buffer - p_stream->i_pes_used,                       i_payload_max );    if( b_pcr || i_payload < i_payload_max )    {        b_adaptation_field = VLC_TRUE;    }    p_ts = block_New( p_mux, 188 );    p_ts->i_dts = p_pes->i_dts;    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;    p_stream->i_continuity_counter = (p_stream->i_continuity_counter+1)%16;    if( b_adaptation_field )    {        int i;        if( b_pcr )        {            int     i_stuffing = i_payload_max - i_payload;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲va综合人人澡精品| 成人免费毛片片v| 99riav一区二区三区| 精品久久久三级丝袜| 亚洲国产一二三| 成人av资源在线观看| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲欧美另类小说| 国产91精品一区二区麻豆网站| 欧美性受xxxx黑人xyx性爽| 国产精品视频九色porn| 久久国产三级精品| 欧美日韩一区小说| 亚洲精品视频观看| 欧美日本一区二区| 亚欧色一区w666天堂| 色婷婷亚洲婷婷| 一区av在线播放| 97国产一区二区| 日本午夜一本久久久综合| 91在线观看污| 1024精品合集| 91色乱码一区二区三区| 亚洲欧洲www| 色94色欧美sute亚洲线路一ni| 一区二区三区在线观看视频| 91免费看片在线观看| 亚洲精品成人少妇| 欧美一激情一区二区三区| 麻豆精品精品国产自在97香蕉| 精品成人一区二区三区四区| 韩国av一区二区三区在线观看| 日韩一级免费观看| 韩国v欧美v亚洲v日本v| 精品成人a区在线观看| 成人免费视频视频在线观看免费| 亚洲婷婷在线视频| 日韩免费电影网站| 成a人片亚洲日本久久| 亚洲另类春色国产| 在线不卡a资源高清| 成人免费看视频| 日韩影院精彩在线| 亚洲视频在线一区| 日韩一级二级三级| 色综合久久88色综合天天| 九九**精品视频免费播放| 国产精品福利av| 欧美一二三区在线观看| 99免费精品在线| 欧美aaaaaa午夜精品| 国产精品久久精品日日| 欧美三级在线视频| 国产盗摄精品一区二区三区在线| 亚洲成人av一区二区三区| 日本一区二区三区四区在线视频| 日韩欧美中文字幕一区| 欧美在线一区二区| 99久久精品国产观看| 国产一区二区精品久久| 调教+趴+乳夹+国产+精品| 亚洲免费在线观看| 国产日韩av一区| 欧美一级精品大片| 欧美色倩网站大全免费| 99精品国产一区二区三区不卡| 麻豆一区二区三| 日韩高清电影一区| 婷婷久久综合九色综合绿巨人| 亚洲欧洲成人自拍| 亚洲精品菠萝久久久久久久| 日韩一区二区三区四区五区六区| av不卡在线观看| 国产成人自拍网| 精品写真视频在线观看| 国产午夜三级一区二区三| 欧美一区二区三区喷汁尤物| 99re亚洲国产精品| 色偷偷成人一区二区三区91| 色婷婷精品久久二区二区蜜臀av| 99国产麻豆精品| 91福利在线观看| 在线观看亚洲精品视频| 色综合久久久久| 欧美色爱综合网| 精品久久久久一区二区国产| 精品国产免费一区二区三区四区| 精品国产一区二区亚洲人成毛片 | 日韩午夜电影在线观看| 欧美一区二区三区影视| 欧美日韩1区2区| 日韩一区二区在线观看视频| 久久久久国产一区二区三区四区| 久久影院午夜片一区| 亚洲国产高清aⅴ视频| 一区二区三区视频在线看| 日韩中文字幕麻豆| 国产精品18久久久久久久久久久久 | 91美女片黄在线| 欧美日本一区二区三区四区| 精品国产91久久久久久久妲己 | 午夜精品免费在线观看| 国产在线精品国自产拍免费| 日本电影亚洲天堂一区| 欧美成人福利视频| 亚洲狠狠爱一区二区三区| 天天影视涩香欲综合网| 国产精品91一区二区| 欧美日韩一区二区在线视频| 久久精品日产第一区二区三区高清版| 中文字幕不卡在线| 久久99久久久久| 色哦色哦哦色天天综合| 久久这里只有精品6| 亚洲国产婷婷综合在线精品| 国产在线视频一区二区| 一本久久精品一区二区| 欧美va亚洲va在线观看蝴蝶网| 依依成人综合视频| 成人精品鲁一区一区二区| 91精品一区二区三区在线观看| 国产清纯在线一区二区www| 视频一区国产视频| 91老师国产黑色丝袜在线| 欧美tickle裸体挠脚心vk| 久久成人羞羞网站| 成人免费在线视频观看| 一本一本大道香蕉久在线精品| 亚洲精品一区二区在线观看| 视频一区欧美精品| 777奇米四色成人影色区| 首页亚洲欧美制服丝腿| 欧美日韩dvd在线观看| 亚洲高清免费在线| 欧美视频精品在线| 亚洲一区二区成人在线观看| 91久久香蕉国产日韩欧美9色| 中文字幕综合网| 欧美在线制服丝袜| 日韩专区欧美专区| 精品欧美一区二区久久| 毛片av一区二区| 中文欧美字幕免费| 99视频在线观看一区三区| 亚洲精品国产a久久久久久| 欧美伦理影视网| 午夜国产精品一区| 欧美日韩亚洲不卡| 经典三级视频一区| 国产精品久久久久久久久快鸭| 色偷偷88欧美精品久久久| 天堂一区二区在线免费观看| 日韩欧美美女一区二区三区| 国产成人在线观看免费网站| 亚洲精品一二三四区| 欧美日韩mp4| 不卡的av网站| 美女视频网站久久| 亚洲欧洲中文日韩久久av乱码| 欧美日韩国产综合一区二区| 韩国精品主播一区二区在线观看 | 精品亚洲成av人在线观看| 中文字幕一区二区不卡| 日韩视频一区在线观看| jlzzjlzz亚洲女人18| 国产精品一区二区免费不卡 | 狠狠色丁香久久婷婷综合丁香| 国产精品国模大尺度视频| 国产精品乱码人人做人人爱| 国产精品色一区二区三区| 欧美xxxxxxxxx| 亚洲精品在线免费观看视频| 精品久久久久久久一区二区蜜臀| 欧美日韩一区久久| 日韩一区二区三区三四区视频在线观看| 欧美日韩国产一二三| 欧美一卡二卡三卡| 久久综合色播五月| 一区二区中文字幕在线| 亚洲自拍都市欧美小说| 日本aⅴ免费视频一区二区三区| 美女免费视频一区二区| 国产成人一区在线| 色综合久久天天| 欧美一级免费大片| 国产欧美一区二区精品婷婷| 亚洲精品国产a| 日本不卡视频在线| 亚洲一级片在线观看| 久久综合久久久久88| 国产91高潮流白浆在线麻豆| 婷婷久久综合九色综合绿巨人| 一区二区三区在线观看网站| 亚洲一本大道在线| 日韩高清一区二区| 国产在线精品免费av| 国产成人av电影在线| 成年人国产精品| 91福利在线导航| 3d动漫精品啪啪一区二区竹菊|