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

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

?? gvmat32c.c

?? 許多壓縮算法都用到了ZLIP算法
?? C
字號:
/* gvmat32.c -- C portion of the optimized longest_match for 32 bits x86 * Copyright (C) 1995-1996 Jean-loup Gailly and Gilles Vollant. * File written by Gilles Vollant, by modifiying the longest_match *  from Jean-loup Gailly in deflate.c *  it prepare all parameters and call the assembly longest_match_gvasm *  longest_match execute standard C code is wmask != 0x7fff *     (assembly code is faster with a fixed wmask) * */#include "deflate.h"#ifdef ASMV#define NIL 0#define UNALIGNED_OK/* if your C compiler don't add underline before function name,        define ADD_UNDERLINE_ASMFUNC */#ifdef ADD_UNDERLINE_ASMFUNC#define longest_match_7fff _longest_match_7fff#define longest_match_686  _longest_match_686#define cpudetect32        _cpudetect32#endifvoid match_init(){}unsigned long cpudetect32();uInt longest_match_c(    deflate_state *s,    IPos cur_match);                             /* current match */uInt longest_match_7fff(    deflate_state *s,    IPos cur_match);                             /* current match */uInt longest_match_686(    deflate_state *s,    IPos cur_match);                             /* current match */uInt longest_match(    deflate_state *s,    IPos cur_match)                             /* current match */{    static uInt iIsPPro=2;    if ((s->w_mask == 0x7fff) && (iIsPPro==0))        return longest_match_7fff(s,cur_match);    if (iIsPPro==1)        return longest_match_686(s,cur_match);    if (iIsPPro==2)        iIsPPro = (((cpudetect32()/0x100)&0xf)>=6) ? 1 : 0;    return longest_match_c(s,cur_match);}uInt longest_match_c(s, cur_match)    deflate_state *s;    IPos cur_match;                             /* current match */{    unsigned chain_length = s->max_chain_length;/* max hash chain length */    register Bytef *scan = s->window + s->strstart; /* current string */    register Bytef *match;                       /* matched string */    register int len;                           /* length of current match */    int best_len = s->prev_length;              /* best match length so far */    int nice_match = s->nice_match;             /* stop if match long enough */    IPos limit = s->strstart > (IPos)MAX_DIST(s) ?        s->strstart - (IPos)MAX_DIST(s) : NIL;    /* Stop when cur_match becomes <= limit. To simplify the code,     * we prevent matches with the string of window index 0.     */    Posf *prev = s->prev;    uInt wmask = s->w_mask;#ifdef UNALIGNED_OK    /* Compare two bytes at a time. Note: this is not always beneficial.     * Try with and without -DUNALIGNED_OK to check.     */    register Bytef *strend = s->window + s->strstart + MAX_MATCH - 1;    register ush scan_start = *(ushf*)scan;    register ush scan_end   = *(ushf*)(scan+best_len-1);#else    register Bytef *strend = s->window + s->strstart + MAX_MATCH;    register Byte scan_end1  = scan[best_len-1];    register Byte scan_end   = scan[best_len];#endif    /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.     * It is easy to get rid of this optimization if necessary.     */    Assert(s->hash_bits >= 8 && MAX_MATCH == 258, "Code too clever");    /* Do not waste too much time if we already have a good match: */    if (s->prev_length >= s->good_match) {        chain_length >>= 2;    }    /* Do not look for matches beyond the end of the input. This is necessary     * to make deflate deterministic.     */    if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead;    Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead");    do {        Assert(cur_match < s->strstart, "no future");        match = s->window + cur_match;        /* Skip to next match if the match length cannot increase         * or if the match length is less than 2:         */#if (defined(UNALIGNED_OK) && MAX_MATCH == 258)        /* This code assumes sizeof(unsigned short) == 2. Do not use         * UNALIGNED_OK if your compiler uses a different size.         */        if (*(ushf*)(match+best_len-1) != scan_end ||            *(ushf*)match != scan_start) continue;        /* It is not necessary to compare scan[2] and match[2] since they are         * always equal when the other bytes match, given that the hash keys         * are equal and that HASH_BITS >= 8. Compare 2 bytes at a time at         * strstart+3, +5, ... up to strstart+257. We check for insufficient         * lookahead only every 4th comparison; the 128th check will be made         * at strstart+257. If MAX_MATCH-2 is not a multiple of 8, it is         * necessary to put more guard bytes at the end of the window, or         * to check more often for insufficient lookahead.         */        Assert(scan[2] == match[2], "scan[2]?");        scan++, match++;        do {        } while (*(ushf*)(scan+=2) == *(ushf*)(match+=2) &&                 *(ushf*)(scan+=2) == *(ushf*)(match+=2) &&                 *(ushf*)(scan+=2) == *(ushf*)(match+=2) &&                 *(ushf*)(scan+=2) == *(ushf*)(match+=2) &&                 scan < strend);        /* The funny "do {}" generates better code on most compilers */        /* Here, scan <= window+strstart+257 */        Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan");        if (*scan == *match) scan++;        len = (MAX_MATCH - 1) - (int)(strend-scan);        scan = strend - (MAX_MATCH-1);#else /* UNALIGNED_OK */        if (match[best_len]   != scan_end  ||            match[best_len-1] != scan_end1 ||            *match            != *scan     ||            *++match          != scan[1])      continue;        /* The check at best_len-1 can be removed because it will be made         * again later. (This heuristic is not always a win.)         * It is not necessary to compare scan[2] and match[2] since they         * are always equal when the other bytes match, given that         * the hash keys are equal and that HASH_BITS >= 8.         */        scan += 2, match++;        Assert(*scan == *match, "match[2]?");        /* We check for insufficient lookahead only every 8th comparison;         * the 256th check will be made at strstart+258.         */        do {        } while (*++scan == *++match && *++scan == *++match &&                 *++scan == *++match && *++scan == *++match &&                 *++scan == *++match && *++scan == *++match &&                 *++scan == *++match && *++scan == *++match &&                 scan < strend);        Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan");        len = MAX_MATCH - (int)(strend - scan);        scan = strend - MAX_MATCH;#endif /* UNALIGNED_OK */        if (len > best_len) {            s->match_start = cur_match;            best_len = len;            if (len >= nice_match) break;#ifdef UNALIGNED_OK            scan_end = *(ushf*)(scan+best_len-1);#else            scan_end1  = scan[best_len-1];            scan_end   = scan[best_len];#endif        }    } while ((cur_match = prev[cur_match & wmask]) > limit             && --chain_length != 0);    if ((uInt)best_len <= s->lookahead) return (uInt)best_len;    return s->lookahead;}#endif /* ASMV */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人激情av| 日韩美女视频19| 欧美日韩久久一区| 一本色道亚洲精品aⅴ| 成人性色生活片| 国产精品一区二区91| 国产一区二区三区av电影| 国产在线精品一区在线观看麻豆| 久久国产精品99久久久久久老狼| 免费人成在线不卡| 国产毛片精品一区| 成人夜色视频网站在线观看| 91视频.com| 欧美欧美欧美欧美| 2020国产精品自拍| 国产精品色哟哟网站| 亚洲午夜电影在线观看| 美国精品在线观看| 国产不卡在线视频| 欧美午夜不卡视频| 精品理论电影在线观看| 国产精品国产馆在线真实露脸 | 日韩国产欧美三级| 精品亚洲aⅴ乱码一区二区三区| 久久99久久99| 91在线码无精品| 欧美高清hd18日本| 久久综合九色综合97婷婷| 国产精品久久久久永久免费观看| 一区二区三区成人在线视频 | 精品国产一区二区三区av性色| 久久久99精品久久| 一区2区3区在线看| 精品一区二区三区免费毛片爱| 成人午夜视频在线观看| 欧美丰满少妇xxxxx高潮对白| 久久久不卡网国产精品一区| 国产精品九色蝌蚪自拍| 日本vs亚洲vs韩国一区三区二区| 国产传媒欧美日韩成人| 欧美日本在线视频| 欧美国产一区二区在线观看 | 国产精品一区二区在线看| 在线亚洲高清视频| 国产欧美一区二区精品性色 | 亚洲永久精品国产| 国产成人aaa| 欧美一区二区三区免费| 亚洲欧洲色图综合| 国产传媒日韩欧美成人| 日韩一级二级三级| 亚洲v精品v日韩v欧美v专区| av一区二区三区| 久久久久亚洲综合| 青青草视频一区| 在线亚洲精品福利网址导航| 国产精品女同一区二区三区| 国产一区欧美二区| 日韩精品一区二区三区在线观看 | 日韩精品中午字幕| 偷拍日韩校园综合在线| 一本一本大道香蕉久在线精品 | 性做久久久久久免费观看| 国产不卡在线视频| 国产亚洲污的网站| 久久9热精品视频| 日韩免费性生活视频播放| 亚洲在线中文字幕| 在线一区二区三区四区| 亚洲啪啪综合av一区二区三区| 国产99久久久国产精品潘金网站| 亚洲精品一区二区三区在线观看| 日韩电影网1区2区| 日韩视频一区二区三区| 美女脱光内衣内裤视频久久影院| 欧美日韩国产另类一区| 视频一区二区三区中文字幕| 欧美日韩国产一区| 无吗不卡中文字幕| 制服丝袜成人动漫| 麻豆精品一区二区综合av| 51精品国自产在线| 精品中文字幕一区二区小辣椒| 日韩免费成人网| 国模冰冰炮一区二区| 欧美激情一二三区| av不卡在线播放| 亚洲最新在线观看| 欧美一区二区精品| 国产一区二区h| 国产精品国产成人国产三级| 91免费观看国产| 亚洲成人综合网站| 欧美大片在线观看| 粉嫩av一区二区三区| 一区二区三区在线视频免费观看| 欧美日韩一区三区| 韩国毛片一区二区三区| 中文字幕中文字幕在线一区 | 国产精品久久久久久久久久免费看 | 久久99精品国产麻豆不卡| 精品免费日韩av| 99这里只有精品| 亚洲电影在线免费观看| 日韩精品一区二区三区中文不卡 | 中文字幕在线视频一区| 色偷偷成人一区二区三区91| 日韩中文欧美在线| 中文字幕第一页久久| 欧美色视频在线观看| 久久国产精品区| 国产欧美精品在线观看| 欧美专区日韩专区| 国产成都精品91一区二区三| 亚洲一区二区高清| 久久久99精品久久| 欧美视频一区二区三区四区| 国产精品一区在线观看你懂的| 亚洲视频在线观看一区| 欧美成人三级在线| 91福利国产成人精品照片| 久草这里只有精品视频| 亚洲黄色av一区| 久久久久国产成人精品亚洲午夜| 欧美性高清videossexo| 国产福利一区二区三区视频在线| 亚洲在线成人精品| 国产精品视频你懂的| 日韩精品一区二区三区四区| 色综合激情五月| 成人精品免费视频| 久久99精品国产麻豆婷婷洗澡| 亚洲超碰97人人做人人爱| 日韩毛片精品高清免费| 久久久99免费| 精品免费一区二区三区| 欧美乱妇20p| 欧美偷拍一区二区| 99久久精品国产导航| 成人精品小蝌蚪| 国产美女在线精品| 极品少妇xxxx精品少妇| 日本系列欧美系列| 视频在线观看一区二区三区| 一区二区免费在线| 亚洲乱码国产乱码精品精小说| 欧美国产亚洲另类动漫| 国产日韩欧美a| 久久九九影视网| 中文字幕 久热精品 视频在线| 久久久九九九九| 国产女同性恋一区二区| 2023国产精品| 国产天堂亚洲国产碰碰| 国产日韩精品视频一区| 国产欧美视频一区二区| 国产精品少妇自拍| 亚洲女女做受ⅹxx高潮| 亚洲国产另类av| 午夜激情一区二区三区| 日本午夜精品视频在线观看| 欧美96一区二区免费视频| 毛片基地黄久久久久久天堂| 理论电影国产精品| 国产精品资源在线| 91在线免费视频观看| 欧美色综合网站| 欧美一区二区三区四区高清| 欧美成人女星排名| 国产亚洲欧美日韩日本| 国产精品美女久久久久久久网站| 中文字幕日本不卡| 亚洲成人av一区| 老鸭窝一区二区久久精品| 国产激情一区二区三区| av成人老司机| 91精品国产综合久久国产大片| 日韩精品中文字幕在线不卡尤物| 国产情人综合久久777777| 亚洲欧美日韩国产综合在线| 午夜精品久久久久影视| 国内成+人亚洲+欧美+综合在线| 国产一区二区三区免费在线观看| 国产精品18久久久久久久网站| a级高清视频欧美日韩| 欧美精品久久天天躁| 久久久噜噜噜久久人人看| 一区二区三区免费看视频| 久久精品国产秦先生| 91亚洲资源网| 欧美r级电影在线观看| 中文字幕在线视频一区| 奇米影视在线99精品| 高清国产一区二区| 在线观看av一区| 欧美精品一区二区三区久久久| 有码一区二区三区| 国产精品77777| 欧美精品一卡二卡| ...xxx性欧美|