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

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

?? pngvcrd.c

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? 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.8 - December 3, 2004 * For conditions of distribution and use, see copyright notice in png.h * Copyright (c) 1998-2004 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) {#if !defined(PNG_1_0_X)       /* this should have happened in png_init_mmx_flags() already */       png_warning(png_ptr, "asm_flags may not have been initialized");#endif       png_mmx_support();   }   if (mask == 0xff)   {      png_memcpy(row, png_ptr->row_buf + 1,       (png_size_t)PNG_ROWBYTES(png_ptr->row_info.pixel_depth,       png_ptr->width));   }   /* 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 !defined(PNG_1_0_X)            if ((png_ptr->asm_flags & PNG_ASM_FLAG_MMX_READ_COMBINE_ROW)                /* && mmx_supported */ )#else            if (mmx_supported)#endif            {               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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
《视频一区视频二区| 欧美精品1区2区3区| 狠狠色综合日日| 日韩激情在线观看| 污片在线观看一区二区| 午夜精品123| 麻豆精品在线看| 国产综合色在线视频区| 国产一区二区按摩在线观看| 国产老肥熟一区二区三区| 成人综合在线观看| 在线日韩av片| 欧美久久久久久久久久| 欧美一区二区国产| 欧美国产综合一区二区| 亚洲黄网站在线观看| 日韩精品一级二级 | 日本韩国一区二区三区| 91国模大尺度私拍在线视频| 欧美日本视频在线| 久久亚洲综合av| 亚洲综合无码一区二区| 免费观看30秒视频久久| 国产成人午夜电影网| 色综合欧美在线视频区| 欧美精品少妇一区二区三区 | 国精品**一区二区三区在线蜜桃| 免费观看在线色综合| 成人性生交大片免费看中文| 日本大香伊一区二区三区| 欧美一区二区免费观在线| 久久久久久**毛片大全| 亚洲一区欧美一区| 国产一本一道久久香蕉| 欧美性生活久久| 中文字幕欧美国产| 日本免费在线视频不卡一不卡二| 成人精品在线视频观看| 6080yy午夜一二三区久久| 国产精品电影一区二区| 日韩高清欧美激情| 91麻豆国产福利精品| 欧美成人三级电影在线| 国产欧美精品在线观看| 奇米综合一区二区三区精品视频| 色999日韩国产欧美一区二区| 日韩精品一区二区三区视频 | 97精品国产97久久久久久久久久久久| 欧美精品黑人性xxxx| 国产女同互慰高潮91漫画| 亚洲成av人片一区二区梦乃| eeuss鲁一区二区三区| 日韩免费观看高清完整版在线观看| 综合久久久久久久| 国产69精品久久久久777| 日韩一区二区在线观看视频| 亚洲一区二区三区四区在线免费观看| 国产1区2区3区精品美女| 日韩一区二区免费视频| 樱桃视频在线观看一区| 成人av在线电影| 久久精品一级爱片| 久久精品久久久精品美女| 欧美卡1卡2卡| 亚洲第一成年网| 在线视频综合导航| 自拍偷拍亚洲综合| 91无套直看片红桃| 成人免费在线播放视频| 国产91精品久久久久久久网曝门| 精品噜噜噜噜久久久久久久久试看 | 国产丶欧美丶日本不卡视频| 日韩欧美国产1| 免费成人av资源网| 日韩欧美国产小视频| 免费在线观看一区二区三区| 欧美日韩不卡一区| 丝袜国产日韩另类美女| 欧美精品乱码久久久久久按摩| 亚洲成a人片在线观看中文| 欧美天堂一区二区三区| 亚洲国产精品久久不卡毛片 | 欧美日韩一本到| 亚洲观看高清完整版在线观看 | 精品国产一区二区国模嫣然| 人人爽香蕉精品| 日韩欧美亚洲一区二区| 国产一区二区女| 国产精品久久久久国产精品日日| 一本大道久久a久久综合| 亚洲久草在线视频| 欧美美女直播网站| 精品影院一区二区久久久| 久久久久久久久久久99999| 成人美女视频在线看| 亚洲制服丝袜一区| 日韩一区二区精品葵司在线| 国产老女人精品毛片久久| 亚洲婷婷在线视频| 日韩一区二区三区电影在线观看 | 岛国精品在线播放| 一区二区三区国产| 日韩欧美国产午夜精品| 福利91精品一区二区三区| 亚洲精品欧美二区三区中文字幕| 欧美日韩成人高清| 国产成人av网站| 亚洲成人av福利| 国产片一区二区三区| 欧美婷婷六月丁香综合色| 国内精品视频666| 亚洲国产日韩一级| 久久综合久久鬼色| 在线观看国产一区二区| 国产一区二区0| 三级亚洲高清视频| 亚洲欧洲av另类| 欧美成人bangbros| 欧美日韩一二区| 成人av免费在线观看| 日韩精品久久久久久| 国产精品乱码妇女bbbb| 欧美一区国产二区| 日本韩国视频一区二区| 国产一区日韩二区欧美三区| 亚洲电影视频在线| 国产精品乱码人人做人人爱 | 免费成人结看片| 亚洲一区二三区| 国产精品国产自产拍高清av| 欧美裸体一区二区三区| 色菇凉天天综合网| 不卡一区中文字幕| 国产精品一二三四五| 麻豆专区一区二区三区四区五区| 亚洲国产中文字幕| 亚洲欧洲制服丝袜| 国产精品久久久久永久免费观看 | 男女视频一区二区| 亚洲第一综合色| 一区二区三区精密机械公司| 亚洲人亚洲人成电影网站色| 国产精品久久久久久久久免费丝袜| 精品粉嫩超白一线天av| 日韩一级成人av| 欧美男同性恋视频网站| 欧美日韩国产高清一区二区| 91国产免费观看| 欧美四级电影网| 欧美日韩国产大片| 欧美精品少妇一区二区三区| 欧美日韩一区中文字幕| 欧美麻豆精品久久久久久| 在线国产电影不卡| 欧美浪妇xxxx高跟鞋交| 欧美日韩国产一级片| 欧美日韩黄色一区二区| 欧美日韩夫妻久久| 91精品国产高清一区二区三区蜜臀| 91精品国产一区二区三区香蕉| 欧美日本国产一区| 日韩视频免费直播| 国产日韩欧美不卡| 亚洲色图视频网| 亚洲午夜久久久久久久久久久| 亚洲大片精品永久免费| 麻豆中文一区二区| 成人一区在线看| 在线观看日产精品| 欧美一区二区三区影视| 久久蜜桃香蕉精品一区二区三区| 欧美国产精品劲爆| 一区二区日韩电影| 美国一区二区三区在线播放| 丁香婷婷综合色啪| 欧美午夜电影网| 精品国产一区二区三区忘忧草| 国产日韩综合av| 亚洲综合色网站| 精久久久久久久久久久| 成人sese在线| 欧美一卡二卡在线| 国产精品麻豆网站| 午夜不卡在线视频| 丁香婷婷综合色啪| 欧美一区二区三区婷婷月色| 国产精品灌醉下药二区| 五月婷婷激情综合| 国产大片一区二区| 欧美日韩国产大片| 亚洲欧洲av在线| 激情综合一区二区三区| 91丨九色丨国产丨porny| 欧美电视剧在线看免费| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 水蜜桃久久夜色精品一区的特点| gogogo免费视频观看亚洲一| 日韩欧美一区二区视频| 一二三四社区欧美黄| 成人手机电影网|