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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pngvcrd.c

?? png圖像文件格式開發(fā)包
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* pngvcrd.c - mixed C/assembler version of utilities to read a PNG file * * For Intel x86 CPU and Microsoft Visual C++ compiler * * libpng version 1.2.5 - October 2, 2002 * For conditions of distribution and use, see copyright notice in png.h * Copyright (c) 1998-2002 Glenn Randers-Pehrson * Copyright (c) 1998, Intel Corporation * * Contributed by Nirav Chhatrapati, Intel Corporation, 1998 * Interface to libpng contributed by Gilles Vollant, 1999 * * * In png_do_read_interlace() in libpng versions 1.0.3a through 1.0.4d, * a sign error in the post-MMX cleanup code for each pixel_depth resulted * in bad pixels at the beginning of some rows of some images, and also * (due to out-of-range memory reads and writes) caused heap corruption * when compiled with MSVC 6.0.  The error was fixed in version 1.0.4e. * * [png_read_filter_row_mmx_avg() bpp == 2 bugfix, GRR 20000916] * * [runtime MMX configuration, GRR 20010102] * */#define PNG_INTERNAL#include "png.h"#if defined(PNG_ASSEMBLER_CODE_SUPPORTED) && defined(PNG_USE_PNGVCRD)static int mmx_supported=2;int PNGAPIpng_mmx_support(void){  int mmx_supported_local = 0;  _asm {    push ebx          //CPUID will trash these    push ecx    push edx    pushfd            //Save Eflag to stack    pop eax           //Get Eflag from stack into eax    mov ecx, eax      //Make another copy of Eflag in ecx    xor eax, 0x200000 //Toggle ID bit in Eflag [i.e. bit(21)]    push eax          //Save modified Eflag back to stack    popfd             //Restored modified value back to Eflag reg    pushfd            //Save Eflag to stack    pop eax           //Get Eflag from stack    push ecx          // save original Eflag to stack    popfd             // restore original Eflag    xor eax, ecx      //Compare the new Eflag with the original Eflag    jz NOT_SUPPORTED  //If the same, CPUID instruction is not supported,                      //skip following instructions and jump to                      //NOT_SUPPORTED label    xor eax, eax      //Set eax to zero    _asm _emit 0x0f   //CPUID instruction  (two bytes opcode)    _asm _emit 0xa2    cmp eax, 1        //make sure eax return non-zero value    jl NOT_SUPPORTED  //If eax is zero, mmx not supported    xor eax, eax      //set eax to zero    inc eax           //Now increment eax to 1.  This instruction is                      //faster than the instruction "mov eax, 1"    _asm _emit 0x0f   //CPUID instruction    _asm _emit 0xa2    and edx, 0x00800000  //mask out all bits but mmx bit(24)    cmp edx, 0        // 0 = mmx not supported    jz  NOT_SUPPORTED // non-zero = Yes, mmx IS supported    mov  mmx_supported_local, 1  //set return value to 1NOT_SUPPORTED:    mov  eax, mmx_supported_local  //move return value to eax    pop edx          //CPUID trashed these    pop ecx    pop ebx  }  //mmx_supported_local=0; // test code for force don't support MMX  //printf("MMX : %u (1=MMX supported)\n",mmx_supported_local);  mmx_supported = mmx_supported_local;  return mmx_supported_local;}/* Combines the row recently read in with the previous row.   This routine takes care of alpha and transparency if requested.   This routine also handles the two methods of progressive display   of interlaced images, depending on the mask value.   The mask value describes which pixels are to be combined with   the row.  The pattern always repeats every 8 pixels, so just 8   bits are needed.  A one indicates the pixel is to be combined; a   zero indicates the pixel is to be skipped.  This is in addition   to any alpha or transparency value associated with the pixel.  If   you want all pixels to be combined, pass 0xff (255) in mask.  *//* Use this routine for x86 platform - uses faster MMX routine if machine   supports MMX */void /* PRIVATE */png_combine_row(png_structp png_ptr, png_bytep row, int mask){#ifdef PNG_USE_LOCAL_ARRAYS   const int png_pass_inc[7] = {8, 8, 4, 4, 2, 2, 1};#endif   png_debug(1,"in png_combine_row_asm\n");   if (mmx_supported == 2) {       /* this should have happened in png_init_mmx_flags() already */       png_warning(png_ptr, "asm_flags may not have been initialized");       png_mmx_support();   }   if (mask == 0xff)   {      png_memcpy(row, png_ptr->row_buf + 1,       (png_size_t)((png_ptr->width * png_ptr->row_info.pixel_depth + 7) >> 3));   }   /* GRR:  add "else if (mask == 0)" case?    *       or does png_combine_row() not even get called in that case? */   else   {      switch (png_ptr->row_info.pixel_depth)      {         case 1:         {            png_bytep sp;            png_bytep dp;            int s_inc, s_start, s_end;            int m;            int shift;            png_uint_32 i;            sp = png_ptr->row_buf + 1;            dp = row;            m = 0x80;#if defined(PNG_READ_PACKSWAP_SUPPORTED)            if (png_ptr->transformations & PNG_PACKSWAP)            {                s_start = 0;                s_end = 7;                s_inc = 1;            }            else#endif            {                s_start = 7;                s_end = 0;                s_inc = -1;            }            shift = s_start;            for (i = 0; i < png_ptr->width; i++)            {               if (m & mask)               {                  int value;                  value = (*sp >> shift) & 0x1;                  *dp &= (png_byte)((0x7f7f >> (7 - shift)) & 0xff);                  *dp |= (png_byte)(value << shift);               }               if (shift == s_end)               {                  shift = s_start;                  sp++;                  dp++;               }               else                  shift += s_inc;               if (m == 1)                  m = 0x80;               else                  m >>= 1;            }            break;         }         case 2:         {            png_bytep sp;            png_bytep dp;            int s_start, s_end, s_inc;            int m;            int shift;            png_uint_32 i;            int value;            sp = png_ptr->row_buf + 1;            dp = row;            m = 0x80;#if defined(PNG_READ_PACKSWAP_SUPPORTED)            if (png_ptr->transformations & PNG_PACKSWAP)            {               s_start = 0;               s_end = 6;               s_inc = 2;            }            else#endif            {               s_start = 6;               s_end = 0;               s_inc = -2;            }            shift = s_start;            for (i = 0; i < png_ptr->width; i++)            {               if (m & mask)               {                  value = (*sp >> shift) & 0x3;                  *dp &= (png_byte)((0x3f3f >> (6 - shift)) & 0xff);                  *dp |= (png_byte)(value << shift);               }               if (shift == s_end)               {                  shift = s_start;                  sp++;                  dp++;               }               else                  shift += s_inc;               if (m == 1)                  m = 0x80;               else                  m >>= 1;            }            break;         }         case 4:         {            png_bytep sp;            png_bytep dp;            int s_start, s_end, s_inc;            int m;            int shift;            png_uint_32 i;            int value;            sp = png_ptr->row_buf + 1;            dp = row;            m = 0x80;#if defined(PNG_READ_PACKSWAP_SUPPORTED)            if (png_ptr->transformations & PNG_PACKSWAP)            {               s_start = 0;               s_end = 4;               s_inc = 4;            }            else#endif            {               s_start = 4;               s_end = 0;               s_inc = -4;            }            shift = s_start;            for (i = 0; i < png_ptr->width; i++)            {               if (m & mask)               {                  value = (*sp >> shift) & 0xf;                  *dp &= (png_byte)((0xf0f >> (4 - shift)) & 0xff);                  *dp |= (png_byte)(value << shift);               }               if (shift == s_end)               {                  shift = s_start;                  sp++;                  dp++;               }               else                  shift += s_inc;               if (m == 1)                  m = 0x80;               else                  m >>= 1;            }            break;         }         case 8:         {            png_bytep srcptr;            png_bytep dstptr;            png_uint_32 len;            int m;            int diff, unmask;            __int64 mask0=0x0102040810204080;            if ((png_ptr->asm_flags & PNG_ASM_FLAG_MMX_READ_COMBINE_ROW)                /* && mmx_supported */ )            {               srcptr = png_ptr->row_buf + 1;               dstptr = row;               m = 0x80;               unmask = ~mask;               len  = png_ptr->width &~7;  //reduce to multiple of 8               diff = png_ptr->width & 7;  //amount lost               _asm               {                  movd       mm7, unmask   //load bit pattern                  psubb      mm6,mm6       //zero mm6                  punpcklbw  mm7,mm7                  punpcklwd  mm7,mm7                  punpckldq  mm7,mm7       //fill register with 8 masks                  movq       mm0,mask0                  pand       mm0,mm7       //nonzero if keep byte                  pcmpeqb    mm0,mm6       //zeros->1s, v versa                  mov        ecx,len       //load length of line (pixels)                  mov        esi,srcptr    //load source                  mov        ebx,dstptr    //load dest                  cmp        ecx,0         //lcr                  je         mainloop8endmainloop8:                  movq       mm4,[esi]                  pand       mm4,mm0                  movq       mm6,mm0                  pandn      mm6,[ebx]                  por        mm4,mm6                  movq       [ebx],mm4                  add        esi,8         //inc by 8 bytes processed                  add        ebx,8                  sub        ecx,8         //dec by 8 pixels processed                  ja         mainloop8mainloop8end:                  mov        ecx,diff                  cmp        ecx,0                  jz         end8                  mov        edx,mask                  sal        edx,24        //make low byte the high bytesecondloop8:                  sal        edx,1         //move high bit to CF                  jnc        skip8         //if CF = 0                  mov        al,[esi]                  mov        [ebx],alskip8:                  inc        esi                  inc        ebx                  dec        ecx                  jnz        secondloop8end8:

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产综合久久精品性色| 1024成人网色www| 国产精品入口麻豆原神| 天天综合色天天综合色h| 国产一区二区三区久久久| 欧美挠脚心视频网站| 国产精品成人免费在线| 极品尤物av久久免费看| 欧美电影一区二区| 亚洲一二三四区| av亚洲精华国产精华精华| 日韩欧美久久久| 日本三级韩国三级欧美三级| 在线一区二区观看| 国产精品福利一区| 国产成人免费9x9x人网站视频| 精品久久久久99| 免费高清视频精品| 欧美一区日韩一区| 日韩国产一二三区| 欧美精品久久久久久久多人混战| 亚洲欧美成人一区二区三区| 国产精品1区2区3区在线观看| 日韩一区二区免费在线电影| 天堂影院一区二区| 91精品国产综合久久精品图片| 天天色天天操综合| 这里只有精品99re| 国产福利一区在线| 日韩美女在线视频| 国产一区二区在线看| 久久综合久色欧美综合狠狠| 麻豆精品在线观看| 精品日本一线二线三线不卡| 激情综合色播激情啊| 久久婷婷综合激情| 国产成人免费视频网站| 国产精品国产三级国产aⅴ中文| 99久久久免费精品国产一区二区 | 美女网站在线免费欧美精品| 欧美一卡在线观看| 久久精品av麻豆的观看方式| 26uuu色噜噜精品一区二区| 国产综合色视频| 亚洲国产精品99久久久久久久久| 成人黄页毛片网站| 亚洲一卡二卡三卡四卡无卡久久| 欧美日韩色综合| 麻豆精品一区二区| 亚洲国产成人一区二区三区| 91网站视频在线观看| 天堂成人国产精品一区| 亚洲精品在线观看视频| 成人美女在线视频| 一区二区三区在线观看国产| 日韩一区二区在线看| 国产成人丝袜美腿| 亚洲欧美韩国综合色| 日韩免费高清av| 99久久精品免费观看| 视频一区视频二区中文字幕| 久久九九99视频| 日本韩国一区二区| 国产在线精品一区二区 | 精品国产99国产精品| 粉嫩高潮美女一区二区三区| 亚洲图片欧美一区| 欧美成人精精品一区二区频| 91在线视频18| 精品一区二区三区不卡| 亚洲黄色录像片| 久久看人人爽人人| 欧美日韩亚洲另类| 国产999精品久久久久久绿帽| 午夜天堂影视香蕉久久| 欧美极品另类videosde| 宅男噜噜噜66一区二区66| 成人a区在线观看| 日本不卡一区二区三区高清视频| 国产精品网站一区| 日韩一区二区免费在线观看| 色综合久久综合网欧美综合网| 久久精品国产免费| 亚洲成人免费在线| 亚洲天堂免费在线观看视频| 亚洲精品一区二区精华| 欧美男同性恋视频网站| 色一区在线观看| 成人av网站在线观看免费| 黄色小说综合网站| 青青草伊人久久| 亚洲一区二区三区免费视频| 国产精品久久久爽爽爽麻豆色哟哟| 欧美mv日韩mv国产| 69久久夜色精品国产69蝌蚪网| 91免费视频网| 成人动漫一区二区在线| 国产一区二区三区电影在线观看 | 精品欧美一区二区久久| 欧美三级中文字幕在线观看| 91在线porny国产在线看| 国产乱国产乱300精品| 另类小说视频一区二区| 青青国产91久久久久久| 日韩专区欧美专区| 亚洲第一精品在线| 五月天视频一区| 亚洲123区在线观看| 香蕉久久夜色精品国产使用方法| 亚洲伦理在线免费看| 亚洲精品自拍动漫在线| 亚洲欧洲精品一区二区三区| 国产精品美女久久久久久久| 亚洲国产精品激情在线观看| 国产日产欧美精品一区二区三区| 久久久久久久久久看片| 国产亚洲欧美一级| 久久久三级国产网站| 国产人久久人人人人爽| 国产精品久久久久桃色tv| 亚洲三级理论片| 一区二区三区在线免费| 日日噜噜夜夜狠狠视频欧美人| 日韩中文字幕麻豆| 蜜乳av一区二区| 国产成人aaa| 一本色道综合亚洲| 欧美日韩一级片网站| 日韩一区二区三区免费观看| 久久久久久久久岛国免费| 欧美激情一区不卡| 一区二区在线看| 日韩精品亚洲一区| 国产高清不卡二三区| 91捆绑美女网站| 91麻豆精品国产91久久久资源速度 | 欧美亚洲自拍偷拍| 56国语精品自产拍在线观看| 日韩精品自拍偷拍| 亚洲视频 欧洲视频| 天天色综合天天| 福利一区福利二区| 欧美日韩亚州综合| 国产欧美一二三区| 亚洲无人区一区| 懂色av一区二区夜夜嗨| 91浏览器在线视频| 日韩免费一区二区三区在线播放| 国产日本欧美一区二区| 亚洲第一主播视频| 3d成人动漫网站| 久久九九影视网| 午夜电影久久久| 成人一区二区三区| 欧美精品色综合| 亚洲视频一区二区在线| 精品综合久久久久久8888| 97se狠狠狠综合亚洲狠狠| 日韩视频免费观看高清完整版| 国产精品每日更新在线播放网址| 亚洲一区二区三区四区不卡| 国产福利一区二区| 欧美一级欧美三级| 亚洲精品成a人| 国产成人精品三级| 日韩一级完整毛片| 一区二区久久久久久| 国产成人aaa| 久久综合狠狠综合久久综合88| 亚洲国产精品一区二区www在线| 韩国三级在线一区| 69精品人人人人| 一区二区三区免费观看| 粉嫩久久99精品久久久久久夜| 日韩视频免费观看高清在线视频| 亚洲精品国产第一综合99久久 | 国内精品伊人久久久久av一坑| 欧美在线|欧美| 国产精品青草综合久久久久99| 美洲天堂一区二卡三卡四卡视频| 欧美三区在线观看| 亚洲一区二区视频在线| 99精品偷自拍| 国产精品久久久久aaaa| 69堂精品视频| 午夜精品爽啪视频| 欧美性色综合网| 一区二区三区91| 欧美亚州韩日在线看免费版国语版| 中文字幕在线观看一区| k8久久久一区二区三区| 国产欧美日韩视频一区二区| 精品一区二区在线观看| 欧美一级搡bbbb搡bbbb| 免费成人在线网站| 日韩三级在线免费观看| 卡一卡二国产精品| 久久亚洲一级片| 成人av资源网站| 一区二区三区欧美久久|