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

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

?? arith_decoder_mpeg4.asm

?? 基于VisualDSP++,bf561 ,mpeg4中的算數解碼
?? ASM
?? 第 1 頁 / 共 2 頁
字號:
    
__arith_decoder_mpeg4:

    P0 = R1;                // Address of structure decoder
    [--SP] = (R7:5);        // Push R7:5
    R2 = R0-R0(NS)||R6 = [P0];
                            // fetch value of lower range register 
    BITSET(R2,16);          // set r2 = 0x8000
    R2 = R2-R0(NS)||R7 = [P0+4];
                            // R0 = probability of '0'.R2 = probability of'1' 
                            // and get Range value 
    R5 = R7>>16;            // Higher 16 bits of range register
    CC = R2<R0;             // check if  probability of '0' is greater then 
                            // probability of '1'
    IF CC R0 = R2;          // probability of LPS (CLPS)
    R3 = CC;                // R3 == Least probable symbol
    R5 = R5.L*R0.L(FU);     // Range LPS(rLPS) ==  R * CLPS
    R7 = R7-R5(NS);         // Range == Range -range of LPS
    R2 = R6+R7(NS);         // Lower value  +=  Range -range of LPS
    R0 = R3<<0||R1 = [P0+8];// fetch decoder->V register
    R1 = R1-R6(NS);         // decoder->V - decoder->L
    BITTGL(R0,0);           // opposite of LPS
    CC = R7 <= R1(IU);      // check if (decoder->R-rLPS) < = 
                            // (decoder->V-decoder->L)
    IF CC R7 = R5;          // if true Range ==  range of LPS
    IF !CC R3 = R0;
    IF !CC R2 = R6;         // if false lower range  ==  previous lower range
    [P0+4] = R7;            // store Range value in decoder->R register
    R7 = R3<<0||[P0] = R2;  // store decoder->L register
    [--SP] = RETS;          // Push RETS register before calling a function
    R0 = P0;                // argument to function decode_renormlise
    CALL __decode_renormlise;
    RETS = [SP++];          // Pop RETS register
    R0 = R7;
    (R7:5) = [SP++];        // Pop R7:5
    RTS;  
    NOP;

__arith_decoder_mpeg4.end:    
/*******************************************************************************
Prototype  : void decode_renormlise(Arcoder *decoder);

As long as decoder->R is smaller than QUATER(0x40000000), renormalization is 
performed.
If the interval(L,L+R) is within [0,HALF], the interval is scaled to [2L,2(L+R)]
and V is scald to 2V. If the interval(L,L+R) is within [HALF,1], the interval is
scaled to [2(L-HALF),2(L-HALF+R)] and V is scald to 2(V-HALF). Otherwise the 
interval is scaled to 2(L-QUATER),2(L-QUATER+R) and V is scaled to 2(V-QUATER).
After each scaling, a bit is read and copied into the least significant bit of 
register decoder->V.

Registers used : R0-R3, R6, R7, P0-P2, P5.
*******************************************************************************/
.section                       program;
.global            __decode_renormlise;
.align                               8;
__decode_renormlise:

    P0 = R0;                // Address of structure decoder 
    [--SP] = (R7:6);        // Push R7:6,P5
    [--SP] = P5;
    [--SP] = RETS;
    P5 = R0;                // Duplicate the address of coder
    R7 = R1-R1(NS)||R0 = [P0];
                            // fetch coder->L 
    R6 = R0-R0(NS)||R1 = [P0+4];
                            // fetch coder->R 
    BITSET(R7,31);          // set r7 == 0x80000000
    BITSET(R6,30);          // set r6 == 0x40000000
CHK_WHILE:
    CC = R1<R6(IU);
                            // check if code->R <0x40000000 
    IF !CC JUMP NORME_END;  // if false jump to NORME_END
    CC = R7 <= R0(IU);      // check if coder->L >0x80000000
    IF !CC JUMP CHK_ELSE_IF;
    R0 = R0-R7(NS)||R1 = [P0+8];
                            // coder->L -= 0x80000000 
    R1 = R1-R7(NS)||[P0] = R0;
                            // store coder->L value 
    [P0+8] = R1;            // decoder->V -= HALF
    JUMP END_WHILE;
CHK_ELSE_IF:
    R2 = R0+R1;   // Add decoder->L and decoder->R
    CC = R2 <= R7(IU);      // check if coder->L+coder->R < = 0x80000000
    IF CC JUMP END_WHILE;
    R0 = R0-R6(NS)||R1 = [P0+8];
                            // decrement coder->L by 0x40000000 
    R1 = R1-R6(NS)||[P0] = R0;
                            // store modified coder->L value 
    [P0+8] = R1;            // decoder->V -= QUATER
END_WHILE:
    R0 = [P0];
    R0 = R0<<1||R1 = [P0+4];// double coder->L
    R1 = R1<<1||[P0] = R0;  // double coder->R
    [P0+4] = R1;            // and store updated values
    R0 = P5;

    CALL __AddNextInputBit; // get next bit and copy to LSB of 
                            // decoder->V register
    R0 = [P5];
    R1 = [P5+4];            // fetch updated value of decoder->L ,R registers
    JUMP CHK_WHILE;         // repeat the procedure till coder->R < 0x40000000
    
NORME_END:
    RETS = [SP++];
    P5 = [SP++];
    (R7:6) = [SP++];        // POP RETS and R7:6,P5 register
    RTS;
    NOP;
__decode_renormlise.end:    
/******************************************************************************
Prototype : void  AddNextInputBit(ArDecoder *decoder);
In this procedure any stuffed bits are removed. One bit is read from input array
and copied to LSB of V register.

Registers used : R0-R3, P0-P2.
*******************************************************************************/
.section                 program;
.global               __AddNextInputBit;
.align                        8;
    
__AddNextInputBit:

    P0 = R0;                // address of structure decoder
    R1 = 1; 
    R3 = [P0+12];           // fetch decoder->arpipe
    R2 = R3>>30||P1 = [P0+52];
                            // fetch address of input array 
    CC = BITTST(R2,0);      // check input bit  == 1
    IF CC JUMP ELSE_CONDITION;
    R2 = [P0+24];
    R2 += -1;
    [P0+24] = R2;           // decrement decoder->nzeors by 1
    CC = R2 == 0;
    IF !CC JUMP COND_OVER;
    R0 = [P0+36];           // fetch decoder->extrabits
    R0 = R0-R1(NS)||R2 = B[P1++](Z);
                            // flush a stuffed bit 
    [P0+36] = R0;           // store decoder->extrabits  += -1
ELSE_CONDITION:
    R2 = [P0+44];           // fetch decoder->mm
    [P0+28] = R1;           // store decoder->nonzero
    [P0+24] = R2;           // store decoder->nzerof  = decoder->mm
COND_OVER:
    R0 = 31; 
    R3 = R3<<1||R1 = [P0+36];  
    R0 = R0+R1(NS)||R2 = B[P1++](Z);
                            // flush a bit 
    P2 = R0;                // offset to fetch current bit
    R2 = [P0+8];            // fetch decoder->V
    R2 = R2<<1;             // shift left decoder->nzerof by 1 and fetch nzerof
    R0 = 1;
    P2 = P2+P1;
    R1 = B[P2](Z);          // fetch a bit
    R1 = R1&R0;
    R2 = R2+R1(NS)||R0 = [P0+32];
                            // add bit to LSB of decoder->V 
    R3 = R3+R1(NS)||[P0+8] = R2;
                            // add bit to LSB of decoder->arpipe 
    CC = R1 == 0;             
    IF !CC JUMP NO_DECREMENT;
    R0 += -1;
    [P0+32] = R0;           // decrement decoder->nzerof
    CC = R0 == 0;
    IF !CC JUMP OVER;
    R0 = [P0+36];
    R0 += 1;
    [P0+36] = R0;
NO_DECREMENT:
    R0 = [P0+44];           // fetch decoder->mm
    [P0+32] = R0;           // store decoder-> nzerof as decoder->mm
OVER:
    [P0+12] = R3;           // store decoder-> arpipe
    [P0+52] = P1;           // store the current pointer of input array
    RTS;
    NOP;
__AddNextInputBit.end:    
/*******************************************************************************
Prototype : void StopArDecoder( ArDecoder *decoder);

After the last symbol has been decoded,additional bits need to be consumed which
are introduced by the encoder for proper decodability. In general 3 further bits
need to be read. However in some cases, only 2 bits need to be read. These cases
are defined by
i)  if the current interval covers entirely[QUATER-1,HALF]
ii) if the current interval covers entirely [ HALF-1, 3*QUATER].

Registers used : R0-R3, R5-R7, P0-P2, P5.
*******************************************************************************/
.section             program;
.global             __StopArDecoder;
.align                      8;
    
__StopArDecoder:
    P0 = R0;                // Address of decoder
    [--SP] = (R7:5,P5:5);   // Push R7:5,P5 and RETS register
    P5 = R0;                // store the address in P5
    R0 = [P0];              // get value of coder->L
    R3 = 8;    
    R7 = R0>>29||R2 = [P0+4];
                            // fetch value of coder->R 
    R6 = R0+R2;            
    R6 = R6>>29;             
    CC = R6 == 0;
    IF CC R6 = R3;
    R6 = R6-R7;
    CC = R6 == 3;
    R2 = CC;
    CC = BITTST(R7,0);      // conditional check to find how many bits to read
    R1 = CC;
    [--SP] = RETS;       
    R0 = P5;
    R7 = R2&R1;
    
    CALL __AddNextInputBit; // fetch next bits and copy to LSB of 
                            // decoder->V reg.
    CC = R6 <= 3;
    IF !CC JUMP CALL_END;
    CC = R7 == 1;
    IF CC JUMP CALL_END;
    R0 = P5;
    CALL __AddNextInputBit; // fetch next bits and copy to LSB of 
                            // decoder->V reg.
    
CALL_END:
    R0 = [P5+28];            
    CC = R0 == 0;           // check if nzeros == 0
    IF CC JUMP FLUSH_BITPLUS;
                            // if true flush a bit 
    R1 = [P5+44];
    R2 = [P5+48];           // get difference of decoder->mm-decoder->mt
    R1 = R1-R2(NS)||R0 = [P5+24];
    CC = R0<R1;
    IF !CC JUMP NO_CALL;
FLUSH_BITPLUS:
    P1 = [P5+52];          
    R0 = B[P1++](Z);
    [P5+52] = P1;           // flush the final bit
NO_CALL:
    RETS = [SP++];
    (R7:5,P5:5) = [SP++];
    RTS;
    NOP;                    //to avoid one stall if LINK or UNLINK happens to be
                            //the next instruction after RTS in the memory.    
__StopArDecoder.end:

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆成人av在线| 国产成人综合网站| 国产精品白丝jk白祙喷水网站 | 色94色欧美sute亚洲线路一久 | 亚洲视频综合在线| 国产福利91精品一区| 欧美无人高清视频在线观看| 国产午夜精品理论片a级大结局| 亚洲曰韩产成在线| 国产高清不卡二三区| 欧美精品在线观看一区二区| 最新欧美精品一区二区三区| 国产一区二区中文字幕| 日韩一区二区电影网| 亚洲一区二区三区在线看| av高清不卡在线| 日韩精品一区二区三区四区视频 | 国产欧美一区二区三区在线老狼| 一区二区三区免费看视频| av资源站一区| 国产精品丝袜一区| 国产成人在线视频免费播放| 精品国精品国产| 久久国产精品99久久久久久老狼 | 亚洲成人午夜影院| 一本久久a久久精品亚洲| 国产欧美日韩视频一区二区| 久久国产欧美日韩精品| 欧美tickling网站挠脚心| 日韩国产一区二| 91精品国产色综合久久不卡蜜臀| 午夜国产精品影院在线观看| 91福利视频在线| 亚洲一区二区三区影院| 色综合久久久久综合99| 国产精品不卡在线| 99re这里都是精品| 亚洲精品第一国产综合野| 91精彩视频在线| 日韩精品一级中文字幕精品视频免费观看| 91香蕉视频污| 亚洲午夜一二三区视频| 欧美日韩一区高清| 日韩av电影免费观看高清完整版 | 亚洲另类在线一区| 色综合久久天天综合网| 亚洲精品国产a久久久久久| 99久久精品国产导航| 亚洲欧美偷拍卡通变态| 一本色道久久加勒比精品| 一区二区三区在线视频免费观看| 欧洲视频一区二区| 日韩va欧美va亚洲va久久| 91精品国产综合久久精品图片| 日韩国产在线观看一区| 精品电影一区二区| yourporn久久国产精品| 亚洲一区二区三区在线播放| 欧美一区二区美女| 国产夫妻精品视频| 精品一区二区三区在线观看| 日韩午夜在线观看视频| 国产91精品一区二区麻豆网站| 国产精品国产馆在线真实露脸| 欧美中文字幕亚洲一区二区va在线| 婷婷综合五月天| 国产欧美精品一区二区三区四区| 91在线你懂得| 美腿丝袜亚洲一区| 综合久久国产九一剧情麻豆| 欧美日韩五月天| 国产主播一区二区| 亚洲一区二区在线播放相泽| 精品91自产拍在线观看一区| 成人美女视频在线观看| 午夜精品久久久久久久99樱桃| 欧美激情在线免费观看| 欧美巨大另类极品videosbest | 日韩精品一区二区三区在线播放| www.亚洲色图.com| 麻豆成人在线观看| 亚洲成人自拍偷拍| 国产精品女同一区二区三区| 91精品久久久久久久99蜜桃 | 狠狠色丁香九九婷婷综合五月| 亚洲国产精品成人综合 | 欧美撒尿777hd撒尿| 国产成人av电影在线播放| 亚洲不卡在线观看| 中文字幕一区av| 亚洲精品在线网站| 欧美乱妇一区二区三区不卡视频| 成人黄色网址在线观看| 韩国成人在线视频| 亚洲欧美怡红院| 国产欧美日韩另类一区| 99久久综合狠狠综合久久| 亚洲欧美偷拍另类a∨色屁股| 欧美电影免费观看高清完整版在| 国产成人aaaa| 蜜臀av国产精品久久久久| 成人va在线观看| 国产真实乱子伦精品视频| 日韩—二三区免费观看av| 亚洲小少妇裸体bbw| 亚洲免费色视频| 亚洲精品一二三| 亚洲欧美激情小说另类| 亚洲欧洲国产专区| 中国色在线观看另类| 国产日产欧美一区二区视频| www激情久久| 久久品道一品道久久精品| 精品久久久久久无| 欧美精品一区二区三区在线| 欧美成人国产一区二区| 精品国产一区二区三区av性色| 日韩丝袜美女视频| 日韩三区在线观看| 精品国产91洋老外米糕| 久久久青草青青国产亚洲免观| 欧美精品一区二区三区视频| 日本一区二区三区四区在线视频 | 国产精品区一区二区三| 中文字幕精品一区二区精品绿巨人| 国产日本亚洲高清| 亚洲欧洲精品一区二区三区不卡| 亚洲日本成人在线观看| 亚洲精品网站在线观看| 三级欧美韩日大片在线看| 奇米影视一区二区三区| 国产一区二区在线影院| 91小视频在线免费看| 在线观看一区二区视频| 欧美精品自拍偷拍| wwwwww.欧美系列| 国产精品乱人伦| 亚洲一区二区高清| 麻豆一区二区99久久久久| 国产一区二区三区不卡在线观看| 欧美二区在线观看| 欧美xxxx在线观看| 国产精品久久久久一区| 亚洲一区在线播放| 精品一区二区在线免费观看| 国产不卡视频一区二区三区| 在线视频欧美精品| 欧美xxxxxxxx| 亚洲日韩欧美一区二区在线| 日韩精品每日更新| 国产精品18久久久久久久久 | 成人国产在线观看| 色哦色哦哦色天天综合| 日韩三级在线免费观看| 国产精品毛片大码女人| 日韩精品免费视频人成| 成人av免费网站| 7777精品久久久大香线蕉| 中文字幕欧美国产| 日本欧美一区二区| 91丨porny丨首页| 精品国产亚洲一区二区三区在线观看 | 久99久精品视频免费观看| 北条麻妃一区二区三区| 欧美一级高清大全免费观看| 国产精品嫩草久久久久| 男人操女人的视频在线观看欧美| 福利91精品一区二区三区| 91精品国产高清一区二区三区蜜臀| 日本一区二区三区视频视频| 亚洲超丰满肉感bbw| 一本大道久久a久久综合| 精品噜噜噜噜久久久久久久久试看| 一区二区三区中文字幕| 成人开心网精品视频| 日韩一区二区三区电影在线观看 | 制服丝袜日韩国产| 免费观看成人av| 欧美视频一区在线观看| 久久精品视频在线免费观看| 国产成人免费网站| 日韩三级高清在线| 午夜精品视频在线观看| 91在线一区二区三区| 中文字幕一区日韩精品欧美| 国产成人在线网站| 国产日产欧美一区二区视频| 国产乱人伦精品一区二区在线观看| 国产欧美日韩综合| 精品一区二区精品| 狠狠色综合色综合网络| 51精品视频一区二区三区| 亚洲精品视频在线看| 色婷婷综合视频在线观看| 中文字幕二三区不卡| 国产 日韩 欧美大片| 久久综合九色综合久久久精品综合| 免费成人结看片| 日韩一级完整毛片| 久99久精品视频免费观看|