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

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

?? pnggccrd.c

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? C
?? 第 1 頁 / 共 5 頁
字號(hào):
static unsigned long long _mask48_4 = 0x0202020204040404LL;static unsigned long long _mask48_3 = 0x0404080808080808LL;static unsigned long long _mask48_2 = 0x1010101010102020LL;static unsigned long long _mask48_1 = 0x2020202040404040LL;static unsigned long long _mask48_0 = 0x4040808080808080LL;static unsigned long long _const4   = 0x0000000000FFFFFFLL;//static unsigned long long _const5 = 0x000000FFFFFF0000LL;     // NOT USEDstatic unsigned long long _const6   = 0x00000000000000FFLL;// These are used in the row-filter routines and should/would be local//  variables if not for gcc addressing limitations.// WARNING: Their presence probably defeats the thread safety of libpng.#ifdef PNG_THREAD_UNSAFE_OKstatic png_uint_32  _FullLength;static png_uint_32  _MMXLength;static int          _dif;static int          _patemp; // temp variables for Paeth routinestatic int          _pbtemp;static int          _pctemp;#endifvoid /* PRIVATE */png_squelch_warnings(void){#ifdef PNG_THREAD_UNSAFE_OK   _dif = _dif;   _patemp = _patemp;   _pbtemp = _pbtemp;   _pctemp = _pctemp;   _MMXLength = _MMXLength;#endif   _const4  = _const4;   _const6  = _const6;   _mask8_0  = _mask8_0;   _mask16_1 = _mask16_1;   _mask16_0 = _mask16_0;   _mask24_2 = _mask24_2;   _mask24_1 = _mask24_1;   _mask24_0 = _mask24_0;   _mask32_3 = _mask32_3;   _mask32_2 = _mask32_2;   _mask32_1 = _mask32_1;   _mask32_0 = _mask32_0;   _mask48_5 = _mask48_5;   _mask48_4 = _mask48_4;   _mask48_3 = _mask48_3;   _mask48_2 = _mask48_2;   _mask48_1 = _mask48_1;   _mask48_0 = _mask48_0;}#endif /* PNG_ASSEMBLER_CODE_SUPPORTED */static int _mmx_supported = 2;/*===========================================================================*//*                                                                           *//*                       P N G _ C O M B I N E _ R O W                       *//*                                                                           *//*===========================================================================*/#if defined(PNG_HAVE_ASSEMBLER_COMBINE_ROW)#define BPP2  2#define BPP3  3 /* bytes per pixel (a.k.a. pixel_bytes) */#define BPP4  4#define BPP6  6 /* (defined only to help avoid cut-and-paste errors) */#define BPP8  8/* 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 the x86 platform - it uses a faster MMX routine   if the machine supports MMX. */void /* PRIVATE */png_combine_row(png_structp png_ptr, png_bytep row, int mask){   png_debug(1, "in png_combine_row (pnggccrd.c)\n");#if defined(PNG_ASSEMBLER_CODE_SUPPORTED)   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();   }#endif   if (mask == 0xff)   {      png_debug(2,"mask == 0xff:  doing single png_memcpy()\n");      png_memcpy(row, png_ptr->row_buf + 1,       (png_size_t)PNG_ROWBYTES(png_ptr->row_info.pixel_depth,png_ptr->width));   }   else   /* (png_combine_row() is never called with mask == 0) */   {      switch (png_ptr->row_info.pixel_depth)      {         case 1:        /* png_ptr->row_info.pixel_depth */         {            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_ptr->row_info.pixel_depth */         {            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_ptr->row_info.pixel_depth */         {            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_ptr->row_info.pixel_depth */         {            png_bytep srcptr;            png_bytep dstptr;#if defined(PNG_ASSEMBLER_CODE_SUPPORTED) && defined(PNG_THREAD_UNSAFE_OK)#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            {               png_uint_32 len;               int diff;               int dummy_value_a;   // fix 'forbidden register spilled' error               int dummy_value_d;               int dummy_value_c;               int dummy_value_S;               int dummy_value_D;               _unmask = ~mask;            // global variable for -fPIC version               srcptr = png_ptr->row_buf + 1;               dstptr = row;               len  = png_ptr->width &~7;  // reduce to multiple of 8               diff = (int) (png_ptr->width & 7);  // amount lost               __asm__ __volatile__ (                  "movd      _unmask, %%mm7  \n\t" // load bit pattern                  "psubb     %%mm6, %%mm6    \n\t" // zero mm6                  "punpcklbw %%mm7, %%mm7    \n\t"                  "punpcklwd %%mm7, %%mm7    \n\t"                  "punpckldq %%mm7, %%mm7    \n\t" // fill reg with 8 masks                  "movq      _mask8_0, %%mm0 \n\t"                  "pand      %%mm7, %%mm0    \n\t" // nonzero if keep byte                  "pcmpeqb   %%mm6, %%mm0    \n\t" // zeros->1s, v versa// preload        "movl      len, %%ecx      \n\t" // load length of line// preload        "movl      srcptr, %%esi   \n\t" // load source// preload        "movl      dstptr, %%edi   \n\t" // load dest                  "cmpl      $0, %%ecx       \n\t" // len == 0 ?                  "je        mainloop8end    \n\t"                "mainloop8:                  \n\t"                  "movq      (%%esi), %%mm4  \n\t" // *srcptr                  "pand      %%mm0, %%mm4    \n\t"                  "movq      %%mm0, %%mm6    \n\t"                  "pandn     (%%edi), %%mm6  \n\t" // *dstptr                  "por       %%mm6, %%mm4    \n\t"

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91免费版在线| 在线播放亚洲一区| 欧美日韩你懂的| 2020国产精品自拍| 欧美日韩国产影片| 欧美浪妇xxxx高跟鞋交| 欧美日韩一区二区在线观看视频| 色av一区二区| 在线观看亚洲a| 欧美精品日韩综合在线| 欧美成人一区二区三区在线观看 | 国产精品三级电影| 久久精品在这里| 国产精品久久三| 日韩理论片在线| 亚洲综合在线免费观看| 亚洲成av人片在线观看无码| 午夜精品视频在线观看| 看电视剧不卡顿的网站| 久草在线在线精品观看| 国产成人亚洲精品狼色在线| 91丨porny丨户外露出| 欧美日韩中字一区| 日韩免费性生活视频播放| 久久精品人人做人人爽人人| 亚洲自拍另类综合| 日韩高清在线不卡| 国产精选一区二区三区| 在线看不卡av| 欧美精品一区二| 亚洲欧洲日韩av| 免费人成在线不卡| av在线这里只有精品| 欧美精品xxxxbbbb| 日本一区二区三区电影| 亚洲电影第三页| 国产一区二区三区不卡在线观看| 色婷婷久久久综合中文字幕| 欧美精品tushy高清| 国产欧美一区二区在线| 亚洲成人午夜电影| 国产成人精品网址| 欧美一二三四在线| 亚洲色图在线播放| 国内成+人亚洲+欧美+综合在线| 97成人超碰视| 精品国产伦一区二区三区免费| 亚洲欧美欧美一区二区三区| 久久99精品国产.久久久久久| 色综合天天天天做夜夜夜夜做| 日韩视频在线永久播放| 一区二区三区在线视频观看58| 激情图片小说一区| 欧日韩精品视频| 国产精品久久毛片| 激情综合五月婷婷| 欧美一区二区在线免费观看| 一区av在线播放| caoporn国产一区二区| 久久综合久久综合亚洲| 首页综合国产亚洲丝袜| 91黄色免费网站| 国产精品美女久久久久久久久| 久久精品国产澳门| 777xxx欧美| 亚洲一区二区三区中文字幕| 色综合久久99| 亚洲人成电影网站色mp4| 成人黄色片在线观看| 久久日一线二线三线suv| 蜜桃视频在线观看一区| 在线播放中文字幕一区| 亚洲成av人片在www色猫咪| 色综合天天综合网国产成人综合天| 久久综合色综合88| 久久精品国产99国产| 欧美一区二区三区在线看| 亚洲成人免费影院| 91成人网在线| 亚洲一区在线观看免费| 欧美亚洲国产怡红院影院| 亚洲午夜免费视频| 6080yy午夜一二三区久久| 日韩av电影一区| 日韩精品一区二区三区视频 | 国产日韩欧美一区二区三区乱码 | 中文字幕亚洲在| 91年精品国产| 亚洲成人中文在线| 日韩视频免费观看高清在线视频| 日本伊人色综合网| 久久影院午夜论| 粉嫩久久99精品久久久久久夜| 国产日韩欧美高清在线| 波多野结衣中文字幕一区| 亚洲精品成人精品456| 欧美精品在线观看播放| 国模冰冰炮一区二区| 国产精品久久久久影院色老大 | 欧美日韩mp4| 毛片基地黄久久久久久天堂| 国产欧美一区二区精品仙草咪| 色婷婷狠狠综合| 亚洲国产视频直播| 亚洲人成网站精品片在线观看| 国产黄色成人av| 日韩一区欧美小说| 欧美日韩mp4| 成人深夜在线观看| 亚洲第一福利一区| 国产色综合久久| 欧美在线色视频| 国产在线不卡一卡二卡三卡四卡| 中文字幕一区二区三区色视频| 欧美日韩高清一区二区| 丁香亚洲综合激情啪啪综合| 亚洲成av人在线观看| 欧美国产成人在线| 精品视频免费看| 成人性视频网站| 视频一区二区三区在线| 最好看的中文字幕久久| 精品奇米国产一区二区三区| 欧美视频中文一区二区三区在线观看| 国产自产高清不卡| 三级在线观看一区二区| 亚洲精品免费电影| 日韩成人精品在线| 精彩视频一区二区| 五月婷婷另类国产| 亚洲欧美偷拍卡通变态| 久久久国际精品| 欧美精品一区二区三区高清aⅴ| 欧美日韩一级片在线观看| 懂色av一区二区三区蜜臀| 男人的天堂亚洲一区| 亚洲美女视频一区| 国产精品久久久久久亚洲伦| 欧美一级一区二区| 91麻豆精品国产自产在线观看一区| av激情亚洲男人天堂| 懂色av中文字幕一区二区三区 | 中文字幕一区二区三区乱码在线 | 国产精品不卡在线| 欧美精品一区二区精品网| 日韩片之四级片| 91精品国产综合久久久久久漫画| 欧美性受xxxx| 色成年激情久久综合| 黄色小说综合网站| 久久国产免费看| 另类综合日韩欧美亚洲| 美女在线一区二区| 奇米精品一区二区三区在线观看一| 午夜不卡av在线| 青青草91视频| 激情都市一区二区| 国产成人午夜视频| 99久久久无码国产精品| 日本韩国精品一区二区在线观看| 一本到三区不卡视频| 欧美日韩国产一区| 日韩欧美一级二级三级| 久久九九影视网| 国产亚洲欧洲997久久综合| 中文字幕在线一区| 激情综合网av| 国产精品天天摸av网| 欧美片在线播放| 日韩欧美国产综合在线一区二区三区| 日韩丝袜美女视频| 国产亚洲自拍一区| 亚洲欧美日韩国产成人精品影院| 精品一区二区影视| 色先锋资源久久综合| 欧美一卡二卡在线| 亚洲素人一区二区| 久久精品免费看| 99国产麻豆精品| 国产成人一级电影| 国产一区在线精品| 99在线精品视频| 欧美色图在线观看| 久久久91精品国产一区二区精品| 国产精品国产三级国产a| 午夜久久久久久久久| 精彩视频一区二区| 色天天综合色天天久久| 日韩视频中午一区| 亚洲三级在线观看| 久久国产人妖系列| 欧美亚洲动漫精品| 国产调教视频一区| 亚洲高清在线精品| 国产伦精品一区二区三区视频青涩| 色婷婷亚洲综合| 日韩欧美一区在线| 国产一区二区福利| 在线播放亚洲一区| 美女www一区二区|