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

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

?? flac.c

?? mpeg4 video codec mpeg4 video codec
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * FLAC (Free Lossless Audio Codec) decoder * Copyright (c) 2003 Alex Beregszaszi * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *//** * @file flac.c * FLAC (Free Lossless Audio Codec) decoder * @author Alex Beregszaszi * * For more information on the FLAC format, visit: *  http://flac.sourceforge.net/ * * This decoder can be used in 1 of 2 ways: Either raw FLAC data can be fed * through, starting from the initial 'fLaC' signature; or by passing the * 34-byte streaminfo structure through avctx->extradata[_size] followed * by data starting with the 0xFFF8 marker. */ #include <limits.h> #include "avcodec.h"#include "bitstream.h"#include "golomb.h"#undef NDEBUG#include <assert.h>#define MAX_CHANNELS 8#define MAX_BLOCKSIZE 65535#define FLAC_STREAMINFO_SIZE 34enum decorrelation_type {    INDEPENDENT,    LEFT_SIDE,    RIGHT_SIDE,    MID_SIDE,};typedef struct FLACContext {    AVCodecContext *avctx;    GetBitContext gb;    int min_blocksize, max_blocksize;    int min_framesize, max_framesize;    int samplerate, channels;    int blocksize/*, last_blocksize*/;    int bps, curr_bps;    enum decorrelation_type decorrelation;    int32_t *decoded[MAX_CHANNELS];    uint8_t *bitstream;    int bitstream_size;    int bitstream_index;    int allocated_bitstream_size;} FLACContext;#define METADATA_TYPE_STREAMINFO 0static int sample_rate_table[] ={ 0, 0, 0, 0,  8000, 16000, 22050, 24000, 32000, 44100, 48000, 96000,  0, 0, 0, 0 }; static int sample_size_table[] = { 0, 8, 12, 0, 16, 20, 24, 0 };static int blocksize_table[] = {     0,    192, 576<<0, 576<<1, 576<<2, 576<<3,      0,      0, 256<<0, 256<<1, 256<<2, 256<<3, 256<<4, 256<<5, 256<<6, 256<<7 };static const uint8_t table_crc8[256] = {    0x00, 0x07, 0x0e, 0x09, 0x1c, 0x1b, 0x12, 0x15,    0x38, 0x3f, 0x36, 0x31, 0x24, 0x23, 0x2a, 0x2d,    0x70, 0x77, 0x7e, 0x79, 0x6c, 0x6b, 0x62, 0x65,    0x48, 0x4f, 0x46, 0x41, 0x54, 0x53, 0x5a, 0x5d,    0xe0, 0xe7, 0xee, 0xe9, 0xfc, 0xfb, 0xf2, 0xf5,    0xd8, 0xdf, 0xd6, 0xd1, 0xc4, 0xc3, 0xca, 0xcd,    0x90, 0x97, 0x9e, 0x99, 0x8c, 0x8b, 0x82, 0x85,    0xa8, 0xaf, 0xa6, 0xa1, 0xb4, 0xb3, 0xba, 0xbd,    0xc7, 0xc0, 0xc9, 0xce, 0xdb, 0xdc, 0xd5, 0xd2,    0xff, 0xf8, 0xf1, 0xf6, 0xe3, 0xe4, 0xed, 0xea,    0xb7, 0xb0, 0xb9, 0xbe, 0xab, 0xac, 0xa5, 0xa2,    0x8f, 0x88, 0x81, 0x86, 0x93, 0x94, 0x9d, 0x9a,    0x27, 0x20, 0x29, 0x2e, 0x3b, 0x3c, 0x35, 0x32,    0x1f, 0x18, 0x11, 0x16, 0x03, 0x04, 0x0d, 0x0a,    0x57, 0x50, 0x59, 0x5e, 0x4b, 0x4c, 0x45, 0x42,    0x6f, 0x68, 0x61, 0x66, 0x73, 0x74, 0x7d, 0x7a,    0x89, 0x8e, 0x87, 0x80, 0x95, 0x92, 0x9b, 0x9c,    0xb1, 0xb6, 0xbf, 0xb8, 0xad, 0xaa, 0xa3, 0xa4,    0xf9, 0xfe, 0xf7, 0xf0, 0xe5, 0xe2, 0xeb, 0xec,    0xc1, 0xc6, 0xcf, 0xc8, 0xdd, 0xda, 0xd3, 0xd4,    0x69, 0x6e, 0x67, 0x60, 0x75, 0x72, 0x7b, 0x7c,    0x51, 0x56, 0x5f, 0x58, 0x4d, 0x4a, 0x43, 0x44,    0x19, 0x1e, 0x17, 0x10, 0x05, 0x02, 0x0b, 0x0c,    0x21, 0x26, 0x2f, 0x28, 0x3d, 0x3a, 0x33, 0x34,    0x4e, 0x49, 0x40, 0x47, 0x52, 0x55, 0x5c, 0x5b,    0x76, 0x71, 0x78, 0x7f, 0x6a, 0x6d, 0x64, 0x63,    0x3e, 0x39, 0x30, 0x37, 0x22, 0x25, 0x2c, 0x2b,    0x06, 0x01, 0x08, 0x0f, 0x1a, 0x1d, 0x14, 0x13,    0xae, 0xa9, 0xa0, 0xa7, 0xb2, 0xb5, 0xbc, 0xbb,    0x96, 0x91, 0x98, 0x9f, 0x8a, 0x8d, 0x84, 0x83,    0xde, 0xd9, 0xd0, 0xd7, 0xc2, 0xc5, 0xcc, 0xcb,    0xe6, 0xe1, 0xe8, 0xef, 0xfa, 0xfd, 0xf4, 0xf3};static int64_t get_utf8(GetBitContext *gb){    uint64_t val;    int ones=0, bytes;        while(get_bits1(gb))        ones++;    if     (ones==0) bytes=0;    else if(ones==1) return -1;    else             bytes= ones - 1;        val= get_bits(gb, 7-ones);    while(bytes--){        const int tmp = get_bits(gb, 8);                if((tmp>>6) != 2)            return -1;        val<<=6;        val|= tmp&0x3F;    }    return val;}#if 0static int skip_utf8(GetBitContext *gb){    int ones=0, bytes;        while(get_bits1(gb))        ones++;    if     (ones==0) bytes=0;    else if(ones==1) return -1;    else             bytes= ones - 1;        skip_bits(gb, 7-ones);    while(bytes--){        const int tmp = get_bits(gb, 8);                if((tmp>>6) != 2)            return -1;    }    return 0;}#endifstatic int get_crc8(const uint8_t *buf, int count){    int crc=0;    int i;        for(i=0; i<count; i++){        crc = table_crc8[crc ^ buf[i]];    }    return crc;}static void metadata_streaminfo(FLACContext *s);static void dump_headers(FLACContext *s);static int flac_decode_init(AVCodecContext * avctx){    FLACContext *s = avctx->priv_data;    s->avctx = avctx;    /* initialize based on the demuxer-supplied streamdata header */    if (avctx->extradata_size == FLAC_STREAMINFO_SIZE) {        init_get_bits(&s->gb, avctx->extradata, avctx->extradata_size*8);        metadata_streaminfo(s);        dump_headers(s);    }    return 0;}static void dump_headers(FLACContext *s){    av_log(s->avctx, AV_LOG_DEBUG, "  Blocksize: %d .. %d (%d)\n", s->min_blocksize, s->max_blocksize, s->blocksize);    av_log(s->avctx, AV_LOG_DEBUG, "  Framesize: %d .. %d\n", s->min_framesize, s->max_framesize);    av_log(s->avctx, AV_LOG_DEBUG, "  Samplerate: %d\n", s->samplerate);    av_log(s->avctx, AV_LOG_DEBUG, "  Channels: %d\n", s->channels);    av_log(s->avctx, AV_LOG_DEBUG, "  Bits: %d\n", s->bps);}static void allocate_buffers(FLACContext *s){    int i;    assert(s->max_blocksize);    if(s->max_framesize == 0 && s->max_blocksize){        s->max_framesize= (s->channels * s->bps * s->max_blocksize + 7)/ 8; //FIXME header overhead    }    for (i = 0; i < s->channels; i++)    {        s->decoded[i] = av_realloc(s->decoded[i], sizeof(int32_t)*s->max_blocksize);    }    s->bitstream= av_fast_realloc(s->bitstream, &s->allocated_bitstream_size, s->max_framesize);}static void metadata_streaminfo(FLACContext *s){    /* mandatory streaminfo */    s->min_blocksize = get_bits(&s->gb, 16);    s->max_blocksize = get_bits(&s->gb, 16);    s->min_framesize = get_bits_long(&s->gb, 24);    s->max_framesize = get_bits_long(&s->gb, 24);        s->samplerate = get_bits_long(&s->gb, 20);    s->channels = get_bits(&s->gb, 3) + 1;    s->bps = get_bits(&s->gb, 5) + 1;        s->avctx->channels = s->channels;    s->avctx->sample_rate = s->samplerate;    skip_bits(&s->gb, 36); /* total num of samples */        skip_bits(&s->gb, 64); /* md5 sum */    skip_bits(&s->gb, 64); /* md5 sum */        allocate_buffers(s);}static int decode_residuals(FLACContext *s, int channel, int pred_order){    int i, tmp, partition, method_type, rice_order;    int sample = 0, samples;    method_type = get_bits(&s->gb, 2);    if (method_type != 0){        av_log(s->avctx, AV_LOG_DEBUG, "illegal residual coding method %d\n", method_type);        return -1;    }        rice_order = get_bits(&s->gb, 4);    samples= s->blocksize >> rice_order;    sample=     i= pred_order;    for (partition = 0; partition < (1 << rice_order); partition++)    {        tmp = get_bits(&s->gb, 4);        if (tmp == 15)        {            av_log(s->avctx, AV_LOG_DEBUG, "fixed len partition\n");            tmp = get_bits(&s->gb, 5);            for (; i < samples; i++, sample++)                s->decoded[channel][sample] = get_sbits(&s->gb, tmp);        }        else        {//            av_log(s->avctx, AV_LOG_DEBUG, "rice coded partition k=%d\n", tmp);            for (; i < samples; i++, sample++){                s->decoded[channel][sample] = get_sr_golomb_flac(&s->gb, tmp, INT_MAX, 0);            }        }        i= 0;    }//    av_log(s->avctx, AV_LOG_DEBUG, "partitions: %d, samples: %d\n", 1 << rice_order, sample);    return 0;}    static int decode_subframe_fixed(FLACContext *s, int channel, int pred_order){    int i;        //    av_log(s->avctx, AV_LOG_DEBUG, "  SUBFRAME FIXED\n");            /* warm up samples *///    av_log(s->avctx, AV_LOG_DEBUG, "   warm up samples: %d\n", pred_order);            for (i = 0; i < pred_order; i++)    {        s->decoded[channel][i] = get_sbits(&s->gb, s->curr_bps);//        av_log(s->avctx, AV_LOG_DEBUG, "    %d: %d\n", i, s->decoded[channel][i]);    }        if (decode_residuals(s, channel, pred_order) < 0)        return -1;    switch(pred_order)    {        case 0:            break;        case 1:            for (i = pred_order; i < s->blocksize; i++)                s->decoded[channel][i] +=   s->decoded[channel][i-1];            break;        case 2:            for (i = pred_order; i < s->blocksize; i++)                s->decoded[channel][i] += 2*s->decoded[channel][i-1]                                          - s->decoded[channel][i-2];            break;        case 3:            for (i = pred_order; i < s->blocksize; i++)                s->decoded[channel][i] += 3*s->decoded[channel][i-1]                                         - 3*s->decoded[channel][i-2]                                        +   s->decoded[channel][i-3];            break;        case 4:            for (i = pred_order; i < s->blocksize; i++)                s->decoded[channel][i] += 4*s->decoded[channel][i-1]                                         - 6*s->decoded[channel][i-2]                                        + 4*s->decoded[channel][i-3]                                        -   s->decoded[channel][i-4];            break;        default:            av_log(s->avctx, AV_LOG_ERROR, "illegal pred order %d\n", pred_order);            return -1;    }    return 0;}static int decode_subframe_lpc(FLACContext *s, int channel, int pred_order){    int sum, i, j;    int coeff_prec, qlevel;    #if __STDC_VERSION__ >= 199901L    int coeffs[pred_order];    #else    int *coeffs=(int*)_alloca(sizeof(int)*pred_order);    #endif        //    av_log(s->avctx, AV_LOG_DEBUG, "  SUBFRAME LPC\n");            /* warm up samples *///    av_log(s->avctx, AV_LOG_DEBUG, "   warm up samples: %d\n", pred_order);            for (i = 0; i < pred_order; i++)    {        s->decoded[channel][i] = get_sbits(&s->gb, s->curr_bps);//        av_log(s->avctx, AV_LOG_DEBUG, "    %d: %d\n", i, s->decoded[channel][i]);    }        coeff_prec = get_bits(&s->gb, 4) + 1;    if (coeff_prec == 16)    {        av_log(s->avctx, AV_LOG_DEBUG, "invalid coeff precision\n");        return -1;    }//    av_log(s->avctx, AV_LOG_DEBUG, "   qlp coeff prec: %d\n", coeff_prec);    qlevel = get_sbits(&s->gb, 5);//    av_log(s->avctx, AV_LOG_DEBUG, "   quant level: %d\n", qlevel);    if(qlevel < 0){        av_log(s->avctx, AV_LOG_DEBUG, "qlevel %d not supported, maybe buggy stream\n", qlevel);        return -1;    }    for (i = 0; i < pred_order; i++)    {        coeffs[i] = get_sbits(&s->gb, coeff_prec);//        av_log(s->avctx, AV_LOG_DEBUG, "    %d: %d\n", i, coeffs[i]);    }        if (decode_residuals(s, channel, pred_order) < 0)        return -1;    for (i = pred_order; i < s->blocksize; i++)    {        sum = 0;        for (j = 0; j < pred_order; j++)            sum += coeffs[j] * s->decoded[channel][i-j-1];        s->decoded[channel][i] += sum >> qlevel;    }        return 0;}static inline int decode_subframe(FLACContext *s, int channel){    int type, wasted = 0;    int i, tmp;        s->curr_bps = s->bps;    if(channel == 0){        if(s->decorrelation == RIGHT_SIDE)            s->curr_bps++;    }else{        if(s->decorrelation == LEFT_SIDE || s->decorrelation == MID_SIDE)            s->curr_bps++;    }    if (get_bits1(&s->gb))    {        av_log(s->avctx, AV_LOG_ERROR, "invalid subframe padding\n");        return -1;    }    type = get_bits(&s->gb, 6);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99视频精品在线| 国产精品久久久久永久免费观看 | 韩国午夜理伦三级不卡影院| 国产精品自拍在线| 色欲综合视频天天天| 91精品国产综合久久精品麻豆| 欧美午夜免费电影| 久久奇米777| 亚洲成人av在线电影| 国产不卡在线一区| 欧美精品777| 日韩欧美中文一区| 久久婷婷色综合| 久久久777精品电影网影网| 亚洲国产日韩综合久久精品| 舔着乳尖日韩一区| 成人av免费网站| 久久亚洲欧美国产精品乐播| 亚洲第一综合色| 99r国产精品| 欧美在线观看视频在线| 欧美日韩成人在线| 中文字幕一区二区三区蜜月| 男人操女人的视频在线观看欧美| 国内成人自拍视频| av在线免费不卡| 久久久久九九视频| 久久97超碰国产精品超碰| 欧美丝袜丝交足nylons图片| 欧美一区二区三区电影| 依依成人精品视频| 99久久精品免费看国产| 国产午夜亚洲精品理论片色戒| 日韩一区有码在线| www.亚洲精品| 日本一区二区三区在线不卡| 一区二区三区四区激情| 9久草视频在线视频精品| 国产性色一区二区| 国产精品一区三区| 欧美日产国产精品| 国产午夜精品一区二区三区嫩草| 亚洲另类一区二区| 日本高清免费不卡视频| 亚洲老妇xxxxxx| 在线观看国产91| 一区二区三区在线免费观看| 91小视频在线免费看| 国产精品白丝在线| 精品在线播放免费| 精品三级在线观看| 久久精品国产**网站演员| 日韩亚洲欧美高清| 国产精品视频麻豆| 国产69精品久久777的优势| 国产日韩欧美电影| 不卡一区二区三区四区| 中文字幕在线不卡国产视频| 99热国产精品| 亚洲资源中文字幕| 777亚洲妇女| 亚洲精品写真福利| 91官网在线免费观看| 1024成人网| 欧美日韩黄视频| 中文字幕欧美激情| 色视频欧美一区二区三区| 国产婷婷色一区二区三区 | 久久免费的精品国产v∧| 国内精品国产成人| 久久久国产一区二区三区四区小说 | 亚洲国产一区在线观看| 欧美日韩久久久| 亚洲欧美视频在线观看| 欧美日韩亚洲综合一区二区三区| 中国色在线观看另类| 91美女片黄在线观看91美女| 天天综合色天天| 久久久久久免费| 色综合视频在线观看| 国产丝袜欧美中文另类| 日本道色综合久久| 美女爽到高潮91| 国产精品国产自产拍在线| 欧美日本乱大交xxxxx| 黄页视频在线91| 亚洲人成网站色在线观看| 欧美一区二区视频在线观看 | 亚洲制服丝袜av| 北条麻妃国产九九精品视频| 无码av免费一区二区三区试看| 欧美伊人久久久久久久久影院 | 亚洲在线成人精品| 欧美大度的电影原声| 97精品国产露脸对白| 免费一级片91| 一二三区精品福利视频| 久久久久久99精品| 欧美精品乱码久久久久久按摩| 欧美96一区二区免费视频| 亚洲免费在线观看| 日本一区二区三区久久久久久久久不| 国产毛片精品视频| 美女网站视频久久| 天堂蜜桃91精品| 亚洲欧洲成人精品av97| 色天使久久综合网天天| 成人性生交大合| 美女免费视频一区二区| 亚洲一区在线视频观看| 中日韩免费视频中文字幕| 欧美va亚洲va香蕉在线| 国产一区999| 日本亚洲天堂网| 亚洲综合男人的天堂| 欧美美女一区二区| 日本道免费精品一区二区三区| 天天综合网 天天综合色| 一区二区三区中文字幕在线观看| 欧美日韩高清不卡| 欧美日免费三级在线| 色婷婷久久久亚洲一区二区三区| 日韩精品视频网站| 午夜精品成人在线视频| 亚洲与欧洲av电影| 国产日产欧美一区二区视频| 26uuu国产在线精品一区二区| 99re成人精品视频| 成人精品一区二区三区四区 | 日韩av网站在线观看| 欧美激情一区二区三区四区| 欧美在线视频全部完| 国产一区 二区| 午夜久久久久久久久| 国产欧美一区二区在线观看| 精品国产乱码久久| 26uuu亚洲| 亚洲国产成人在线| 亚洲欧美自拍偷拍色图| 亚洲蜜臀av乱码久久精品| 国产精品剧情在线亚洲| 中文字幕在线不卡| 国产精品女同互慰在线看 | 91年精品国产| 色诱亚洲精品久久久久久| 91碰在线视频| 在线亚洲欧美专区二区| 在线视频欧美精品| 欧美浪妇xxxx高跟鞋交| 欧美一区二区三区婷婷月色| 欧美一级二级在线观看| 久久影音资源网| 久久精品夜色噜噜亚洲aⅴ| 久久女同互慰一区二区三区| 国产精品国产馆在线真实露脸| 欧美一级片免费看| 国产日韩欧美制服另类| 亚洲免费电影在线| 秋霞午夜鲁丝一区二区老狼| 国产精品99久久久久久久女警| 麻豆视频观看网址久久| 高清日韩电视剧大全免费| 一本大道久久a久久精品综合| 99精品视频一区二区三区| 欧美日韩一区二区三区四区五区| 日本久久精品电影| 欧美一区二区三区小说| 555www色欧美视频| 久久久不卡影院| 亚洲自拍另类综合| 国产精品白丝jk白祙喷水网站| 精品一区二区免费视频| 91无套直看片红桃| 欧美一区二区三区四区久久| 久久精品视频在线看| 亚洲成人一二三| 成人网在线播放| 欧美一区二区在线免费播放| 欧美—级在线免费片| 日韩精品亚洲专区| 99国产精品久久久久久久久久久| 99精品久久99久久久久| 色妹子一区二区| 久久久不卡影院| 日韩精品免费专区| www.日韩在线| www激情久久| 国产精品青草综合久久久久99| 中文字幕一区三区| 久久国产乱子精品免费女| 欧美亚洲国产怡红院影院| 欧美国产日本韩| 日本中文字幕一区二区视频 | 欧美日韩视频第一区| 中文字幕第一页久久| 视频在线观看国产精品| av在线播放不卡| 久久综合99re88久久爱| 午夜精品一区二区三区三上悠亚| 免费看精品久久片|