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

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

?? pngvcrd.c

?? linux下的一款播放器
?? 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 3, 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:

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久97国产精华液好用吗| 美女www一区二区| 亚洲高清免费观看| 免费精品视频最新在线| 久久国产精品露脸对白| 成人av资源网站| 欧美日韩国产大片| 日韩精品自拍偷拍| 国产精品久久福利| 三级欧美在线一区| 豆国产96在线|亚洲| 欧美日韩国产一区| 国产目拍亚洲精品99久久精品| 亚洲主播在线观看| 国产在线播放一区三区四| 91久久精品国产91性色tv | 久久精品网站免费观看| 日韩码欧中文字| 蜜臀精品一区二区三区在线观看| 成人高清伦理免费影院在线观看| 欧美精品乱码久久久久久| 国产欧美日韩在线视频| 日韩精品一级中文字幕精品视频免费观看 | 免费人成精品欧美精品| 不卡视频免费播放| 欧美一卡2卡三卡4卡5免费| 国产精品久久久久久户外露出| 婷婷丁香久久五月婷婷| fc2成人免费人成在线观看播放| 3d成人h动漫网站入口| 国产精品电影一区二区| 久久精品国产网站| 欧美色网站导航| 中文字幕免费观看一区| 男男gaygay亚洲| 91福利在线免费观看| 久久久久久久久岛国免费| 亚洲国产精品人人做人人爽| 粉嫩aⅴ一区二区三区四区五区| 91精品国产入口在线| 亚洲精品成a人| 国产91丝袜在线播放0| 日韩欧美国产午夜精品| 亚洲成人一区在线| 91麻豆国产在线观看| 国产日本欧洲亚洲| 寂寞少妇一区二区三区| 91精品免费在线| 亚洲网友自拍偷拍| 91麻豆swag| 国产精品福利电影一区二区三区四区| 久久爱www久久做| 欧美高清视频在线高清观看mv色露露十八| 一区二区中文视频| 粉嫩aⅴ一区二区三区四区| xfplay精品久久| 麻豆精品一区二区| 日韩欧美亚洲国产另类| 天天色天天爱天天射综合| 在线亚洲人成电影网站色www| 国产精品麻豆一区二区| 成人午夜视频免费看| 欧美激情中文字幕| 国产成人av电影| 国产亚洲人成网站| 国产精品综合久久| 2024国产精品| 国产精品一区二区久久不卡| 久久久久久一二三区| 寂寞少妇一区二区三区| 久久综合久久99| 韩国欧美国产1区| 精品免费视频一区二区| 国内不卡的二区三区中文字幕 | 午夜天堂影视香蕉久久| 欧美图片一区二区三区| 亚洲国产成人av好男人在线观看| 欧美视频在线播放| 同产精品九九九| 欧美男人的天堂一二区| 三级精品在线观看| av在线不卡免费看| 懂色av噜噜一区二区三区av| 久久精品夜色噜噜亚洲aⅴ| 精品一区二区免费| 久久久午夜精品| 成人综合日日夜夜| 亚洲欧洲日产国码二区| 在线一区二区三区四区| 天堂蜜桃91精品| 日韩欧美亚洲另类制服综合在线| 精品一区二区精品| 中文字幕不卡的av| 日本高清免费不卡视频| 午夜精品免费在线观看| 欧美mv和日韩mv国产网站| 激情国产一区二区| 国产精品毛片大码女人| 91久久国产综合久久| 免费在线观看视频一区| 久久亚洲一区二区三区明星换脸| 成人免费高清在线观看| 亚洲国产一区二区三区| 精品国产污污免费网站入口 | 日韩一级片网址| 国产资源在线一区| 国产精品久久久一本精品 | 亚洲一区二区美女| 精品国产露脸精彩对白| 成人av免费网站| 日日欢夜夜爽一区| 国产精品久久久久久久久久免费看| 成人激情小说乱人伦| 亚洲男人的天堂在线观看| 欧美人妇做爰xxxⅹ性高电影| 久久精工是国产品牌吗| 一区在线中文字幕| 欧美女孩性生活视频| 国产二区国产一区在线观看| 一区二区三区日韩欧美| 精品av久久707| 91免费版pro下载短视频| 日韩电影在线观看一区| 国产精品免费视频观看| 正在播放亚洲一区| 成人小视频免费观看| 亚洲成人动漫在线免费观看| 久久精品视频一区| 欧美日韩国产影片| 懂色av一区二区三区蜜臀| 日韩精品视频网站| 中文字幕中文乱码欧美一区二区 | 亚洲免费av观看| 欧美一区二区三区啪啪| va亚洲va日韩不卡在线观看| 天天亚洲美女在线视频| 国产精品第四页| 欧美日韩高清在线| 97超碰欧美中文字幕| 精品一区二区三区视频在线观看| 亚洲柠檬福利资源导航| 久久先锋资源网| 91精品免费在线| 91精品国产综合久久久久久久久久 | 欧美一区二区精品久久911| aaa亚洲精品| 久久9热精品视频| 亚洲一区在线观看视频| 亚洲国产高清在线观看视频| 欧美一级一区二区| 在线观看一区二区视频| 不卡一区二区在线| 国产福利精品一区| 久久99精品一区二区三区| 亚洲成人久久影院| 亚洲激情自拍偷拍| 国产精品美日韩| 久久久99久久| 精品国产免费视频| 欧美一级免费大片| 精品视频在线免费看| 色婷婷av一区二区三区gif | 亚洲欧美另类图片小说| 国产午夜亚洲精品羞羞网站| 欧美videos中文字幕| 3d成人动漫网站| 在线观看91av| 欧美精品精品一区| 欧美视频在线一区二区三区| 色狠狠色噜噜噜综合网| av在线播放不卡| 国产白丝精品91爽爽久久| 婷婷成人激情在线网| 欧美激情一区二区三区蜜桃视频| 欧美一级视频精品观看| 欧美美女视频在线观看| 欧洲av在线精品| 91传媒视频在线播放| 91久久一区二区| 欧美主播一区二区三区美女| 色屁屁一区二区| 91福利在线导航| 欧美日韩一区二区三区四区| 欧美日韩视频专区在线播放| 欧美综合视频在线观看| 欧美自拍偷拍一区| 欧美人与禽zozo性伦| 欧美日韩在线播放一区| 91麻豆精品国产91久久久久久久久| 欧美日韩精品福利| 337p亚洲精品色噜噜噜| 欧美一区二区三区免费在线看| 91精品国产91久久久久久最新毛片| 欧美久久久久久久久中文字幕| 欧美日韩精品一区二区| 欧美一区二区在线免费播放| 精品成人一区二区三区| 国产三级精品三级| 中文字幕一区免费在线观看| 亚洲欧美福利一区二区|