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

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

?? pngvcrd.c

?? png圖像文件格式開發包
?? C
?? 第 1 頁 / 共 5 頁
字號:
         {            png_bytep sp, dp;            int sshift, dshift;            int s_start, s_end, s_inc;            png_uint_32 i;            sp = row + (png_size_t)((row_info->width - 1) >> 1);            dp = row + (png_size_t)((final_width - 1) >> 1);#if defined(PNG_READ_PACKSWAP_SUPPORTED)            if (transformations & PNG_PACKSWAP)            {               sshift = (png_size_t)(((row_info->width + 1) & 1) << 2);               dshift = (png_size_t)(((final_width + 1) & 1) << 2);               s_start = 4;               s_end = 0;               s_inc = -4;            }            else#endif            {               sshift = (png_size_t)((1 - ((row_info->width + 1) & 1)) << 2);               dshift = (png_size_t)((1 - ((final_width + 1) & 1)) << 2);               s_start = 0;               s_end = 4;               s_inc = 4;            }            for (i = row_info->width; i; i--)            {               png_byte v;               int j;               v = (png_byte)((*sp >> sshift) & 0xf);               for (j = 0; j < png_pass_inc[pass]; j++)               {                  *dp &= (png_byte)((0xf0f >> (4 - dshift)) & 0xff);                  *dp |= (png_byte)(v << dshift);                  if (dshift == s_end)                  {                     dshift = s_start;                     dp--;                  }                  else                     dshift += s_inc;               }               if (sshift == s_end)               {                  sshift = s_start;                  sp--;               }               else                  sshift += s_inc;            }            break;         }         default:         // This is the place where the routine is modified         {            __int64 const4 = 0x0000000000FFFFFF;            // __int64 const5 = 0x000000FFFFFF0000;  // unused...            __int64 const6 = 0x00000000000000FF;            png_bytep sptr, dp;            png_uint_32 i;            png_size_t pixel_bytes;            int width = row_info->width;            pixel_bytes = (row_info->pixel_depth >> 3);            sptr = row + (width - 1) * pixel_bytes;            dp = row + (final_width - 1) * pixel_bytes;            // New code by Nirav Chhatrapati - Intel Corporation            // sign fix by GRR            // NOTE:  there is NO MMX code for 48-bit and 64-bit images            // use MMX routine if machine supports it            if ((png_ptr->asm_flags & PNG_ASM_FLAG_MMX_READ_INTERLACE)                /* && mmx_supported */ )            {               if (pixel_bytes == 3)               {                  if (((pass == 0) || (pass == 1)) && width)                  {                     _asm                     {                        mov esi, sptr                        mov edi, dp                        mov ecx, width                        sub edi, 21   // (png_pass_inc[pass] - 1)*pixel_bytesloop_pass0:                        movd mm0, [esi]     ; X X X X X v2 v1 v0                        pand mm0, const4    ; 0 0 0 0 0 v2 v1 v0                        movq mm1, mm0       ; 0 0 0 0 0 v2 v1 v0                        psllq mm0, 16       ; 0 0 0 v2 v1 v0 0 0                        movq mm2, mm0       ; 0 0 0 v2 v1 v0 0 0                        psllq mm0, 24       ; v2 v1 v0 0 0 0 0 0                        psrlq mm1, 8        ; 0 0 0 0 0 0 v2 v1                        por mm0, mm2        ; v2 v1 v0 v2 v1 v0 0 0                        por mm0, mm1        ; v2 v1 v0 v2 v1 v0 v2 v1                        movq mm3, mm0       ; v2 v1 v0 v2 v1 v0 v2 v1                        psllq mm0, 16       ; v0 v2 v1 v0 v2 v1 0 0                        movq mm4, mm3       ; v2 v1 v0 v2 v1 v0 v2 v1                        punpckhdq mm3, mm0  ; v0 v2 v1 v0 v2 v1 v0 v2                        movq [edi+16] , mm4                        psrlq mm0, 32       ; 0 0 0 0 v0 v2 v1 v0                        movq [edi+8] , mm3                        punpckldq mm0, mm4  ; v1 v0 v2 v1 v0 v2 v1 v0                        sub esi, 3                        movq [edi], mm0                        sub edi, 24                        //sub esi, 3                        dec ecx                        jnz loop_pass0                        EMMS                     }                  }                  else if (((pass == 2) || (pass == 3)) && width)                  {                     _asm                     {                        mov esi, sptr                        mov edi, dp                        mov ecx, width                        sub edi, 9   // (png_pass_inc[pass] - 1)*pixel_bytesloop_pass2:                        movd mm0, [esi]     ; X X X X X v2 v1 v0                        pand mm0, const4    ; 0 0 0 0 0 v2 v1 v0                        movq mm1, mm0       ; 0 0 0 0 0 v2 v1 v0                        psllq mm0, 16       ; 0 0 0 v2 v1 v0 0 0                        movq mm2, mm0       ; 0 0 0 v2 v1 v0 0 0                        psllq mm0, 24       ; v2 v1 v0 0 0 0 0 0                        psrlq mm1, 8        ; 0 0 0 0 0 0 v2 v1                        por mm0, mm2        ; v2 v1 v0 v2 v1 v0 0 0                        por mm0, mm1        ; v2 v1 v0 v2 v1 v0 v2 v1                        movq [edi+4], mm0   ; move to memory                        psrlq mm0, 16       ; 0 0 v2 v1 v0 v2 v1 v0                        movd [edi], mm0     ; move to memory                        sub esi, 3                        sub edi, 12                        dec ecx                        jnz loop_pass2                        EMMS                     }                  }                  else if (width) /* && ((pass == 4) || (pass == 5)) */                  {                     int width_mmx = ((width >> 1) << 1) - 8;                     if (width_mmx < 0)                         width_mmx = 0;                     width -= width_mmx;        // 8 or 9 pix, 24 or 27 bytes                     if (width_mmx)                     {                        _asm                        {                           mov esi, sptr                           mov edi, dp                           mov ecx, width_mmx                           sub esi, 3                           sub edi, 9loop_pass4:                           movq mm0, [esi]     ; X X v2 v1 v0 v5 v4 v3                           movq mm7, mm0       ; X X v2 v1 v0 v5 v4 v3                           movq mm6, mm0       ; X X v2 v1 v0 v5 v4 v3                           psllq mm0, 24       ; v1 v0 v5 v4 v3 0 0 0                           pand mm7, const4    ; 0 0 0 0 0 v5 v4 v3                           psrlq mm6, 24       ; 0 0 0 X X v2 v1 v0                           por mm0, mm7        ; v1 v0 v5 v4 v3 v5 v4 v3                           movq mm5, mm6       ; 0 0 0 X X v2 v1 v0                           psllq mm6, 8        ; 0 0 X X v2 v1 v0 0                           movq [edi], mm0     ; move quad to memory                           psrlq mm5, 16       ; 0 0 0 0 0 X X v2                           pand mm5, const6    ; 0 0 0 0 0 0 0 v2                           por mm6, mm5        ; 0 0 X X v2 v1 v0 v2                           movd [edi+8], mm6   ; move double to memory                           sub esi, 6                           sub edi, 12                           sub ecx, 2                           jnz loop_pass4                           EMMS                        }                     }                     sptr -= width_mmx*3;                     dp -= width_mmx*6;                     for (i = width; i; i--)                     {                        png_byte v[8];                        int j;                        png_memcpy(v, sptr, 3);                        for (j = 0; j < png_pass_inc[pass]; j++)                        {                           png_memcpy(dp, v, 3);                           dp -= 3;                        }                        sptr -= 3;                     }                  }               } /* end of pixel_bytes == 3 */               else if (pixel_bytes == 1)               {                  if (((pass == 0) || (pass == 1)) && width)                  {                     int width_mmx = ((width >> 2) << 2);                     width -= width_mmx;                     if (width_mmx)                     {                        _asm                        {                           mov esi, sptr                           mov edi, dp                           mov ecx, width_mmx                           sub edi, 31                           sub esi, 3loop1_pass0:                           movd mm0, [esi]     ; X X X X v0 v1 v2 v3                           movq mm1, mm0       ; X X X X v0 v1 v2 v3                           punpcklbw mm0, mm0  ; v0 v0 v1 v1 v2 v2 v3 v3                           movq mm2, mm0       ; v0 v0 v1 v1 v2 v2 v3 v3                           punpcklwd mm0, mm0  ; v2 v2 v2 v2 v3 v3 v3 v3                           movq mm3, mm0       ; v2 v2 v2 v2 v3 v3 v3 v3                           punpckldq mm0, mm0  ; v3 v3 v3 v3 v3 v3 v3 v3                           punpckhdq mm3, mm3  ; v2 v2 v2 v2 v2 v2 v2 v2                           movq [edi], mm0     ; move to memory v3                           punpckhwd mm2, mm2  ; v0 v0 v0 v0 v1 v1 v1 v1                           movq [edi+8], mm3   ; move to memory v2                           movq mm4, mm2       ; v0 v0 v0 v0 v1 v1 v1 v1                           punpckldq mm2, mm2  ; v1 v1 v1 v1 v1 v1 v1 v1                           punpckhdq mm4, mm4  ; v0 v0 v0 v0 v0 v0 v0 v0                           movq [edi+16], mm2  ; move to memory v1                           movq [edi+24], mm4  ; move to memory v0                           sub esi, 4                           sub edi, 32                           sub ecx, 4                           jnz loop1_pass0                           EMMS                        }                     }                     sptr -= width_mmx;                     dp -= width_mmx*8;                     for (i = width; i; i--)                     {                        int j;                       /* I simplified this part in version 1.0.4e                        * here and in several other instances where                        * pixel_bytes == 1  -- GR-P                        *                        * Original code:                        *                        * png_byte v[8];                        * png_memcpy(v, sptr, pixel_bytes);                        * for (j = 0; j < png_pass_inc[pass]; j++)                        * {                        *    png_memcpy(dp, v, pixel_bytes);                        *    dp -= pixel_bytes;                        * }                        * sptr -= pixel_bytes;                        *                        * Replacement code is in the next three lines:                        */                        for (j = 0; j < png_pass_inc[pass]; j++)                           *dp-- = *sptr;                        sptr--;                     }                  }                  else if (((pass == 2) || (pass == 3)) && width)                  {                     int width_mmx = ((width >> 2) << 2);                     width -= width_mmx;                     if (width_mmx)                     {                        _asm                        {                           mov esi, sptr                           mov edi, dp                           mov ecx, width_mmx                           sub edi, 15                           sub esi, 3loop1_pass2:                           movd mm0, [esi]     ; X X X X v0 v1 v2 v3                           punpcklbw mm0, mm0  ; v0 v0 v1 v1 v2 v2 v3 v3                           movq mm1, mm0       ; v0 v0 v1 v1 v2 v2 v3 v3                           punpcklwd mm0, mm0  ; v2 v2 v2 v2 v3 v3 v3 v3                           punpckhwd mm1, mm1  ; v0 v0 v0 v0 v1 v1 v1 v1                           movq [edi], mm0     ; move to memory v2 and v3                           sub esi, 4                           movq [edi+8], mm1   ; move to memory v1     and v0                           sub edi, 16                           sub ecx, 4                           jnz loop1_pass2                           EMMS                        }                     }                     sptr -= width_mmx;                     dp -= width_mmx*4;                     for (i = width; i; i--)                     {                        int j;                        for (j = 0; j < png_pass_inc[pass]; j++)                        {                           *dp-- = *sptr;                        }                        sptr --;                     }                  }                  else if (width) /* && ((pass == 4) || (pass == 5))) */                  {                     int width_mmx = ((width >> 3) << 3);                     width -= width_mmx;                     if (width_mmx)                     {                        _asm                        {                           mov esi, sptr                           mov edi, dp                           mov ecx, width_mmx                           sub edi, 15                           sub esi, 7loop1_pass4:                           movq mm0, [esi]     ; v0 v1 v2 v3 v4 v5 v6 v7                           movq mm1, mm0       ; v0 v1 v2 v3 v4 v5 v6 v7                           punpcklbw mm0, mm0  ; v4 v4 v5 v5 v6 v6 v7 v7                           //movq mm1, mm0     ; v0 v0 v1 v1 v2 v2 v3 v3                           punpckhbw mm1, mm1  ;v0 v0 v1 v1 v2 v2 v3 v3                           movq [edi+8], mm1   ; move to memory v0 v1 v2 and v3                           sub esi, 8                           movq [edi], mm0     ; move to memory v4 v5 v6 and v7                           //sub esi, 4                           sub edi, 16                           sub ecx, 8                           jnz loop1_pass4                           EMMS                        }                     }                     sptr -= width_mmx;                     dp -= width_mmx*2;                     for (i = width; i; i--)                     {                        int j;                        for (j = 0; j < png_pass_inc[pass]; j++)                        {                           *dp-- = *sptr;                        }                        sptr --;                     }                  }               } /* end of pixel_bytes == 1 */               else if (pixel_bytes == 2)               {                  if (((pass == 0) || (pass == 1)) && width)                  {                     int width_mmx = ((width >> 1) << 1);                     width -= width_mmx;                     if (width_mmx)                     {                        _asm                        {                           mov esi, sptr                           mov edi, dp                           mov ecx, width_mmx                           sub esi, 2                           sub edi, 30loop2_pass0:                           movd mm0, [esi]        ; X X X X v1 v0 v3 v2

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩亚洲欧美在线观看| 久久99久久99精品免视看婷婷| 欧美大黄免费观看| 欧美三区在线观看| 欧美日韩国产综合一区二区三区 | 69久久夜色精品国产69蝌蚪网| 成人激情午夜影院| 成人不卡免费av| 99国产精品一区| 99免费精品在线| 99视频一区二区三区| 成人免费毛片aaaaa**| 成人黄色综合网站| 波多野结衣欧美| 国产成人自拍网| 91丨九色丨尤物| 欧美午夜不卡视频| 日韩精品一区在线| 中文字幕欧美日韩一区| 国产欧美一区二区三区网站| 国产欧美1区2区3区| 亚洲欧洲国产日韩| 亚洲电影在线播放| 亚洲大片免费看| 老司机午夜精品| 国产成人精品aa毛片| 91丨porny丨国产入口| 欧美日韩一区不卡| 欧美成人乱码一区二区三区| 亚洲精品一区二区三区蜜桃下载| 久久亚洲捆绑美女| 亚洲欧洲在线观看av| 亚洲成人激情社区| 紧缚奴在线一区二区三区| 成人午夜视频在线| 欧美日韩一级大片网址| 欧美成人精品高清在线播放| 国产精品国产a| 日韩电影一区二区三区| 成人妖精视频yjsp地址| 欧美日韩免费观看一区二区三区 | 国产成人自拍网| 欧美日韩在线三区| 欧美国产日韩a欧美在线观看| 亚洲综合丁香婷婷六月香| 视频一区欧美精品| 不卡电影免费在线播放一区| 欧美一级国产精品| 亚洲精品免费在线观看| 国产成人精品午夜视频免费| 在线成人av网站| 亚洲色图制服诱惑| 国产91在线观看| 欧美一区二区二区| 亚洲国产精品麻豆| www.久久精品| 欧美精品一区二区蜜臀亚洲| 偷窥少妇高潮呻吟av久久免费| 丰满少妇久久久久久久| 欧美变态口味重另类| 亚洲成人1区2区| 91久久精品日日躁夜夜躁欧美| 久久精品一区二区| 久久国产精品99久久人人澡| 欧美图片一区二区三区| 亚洲激情自拍偷拍| 92精品国产成人观看免费| 精品日韩99亚洲| 亚洲韩国一区二区三区| 91福利社在线观看| 亚洲免费三区一区二区| 99视频一区二区| 国产精品久久一级| 成人h动漫精品一区二区| 中文字幕精品一区二区三区精品 | 亚洲欧美另类在线| 丁香天五香天堂综合| 日韩免费福利电影在线观看| 一区二区三区四区在线播放| 一本到三区不卡视频| 中文字幕佐山爱一区二区免费| 成人一区二区三区视频| 国产精品国产三级国产有无不卡| 国产精品综合av一区二区国产馆| 2023国产精品自拍| 国产精品一区二区在线播放 | 亚洲精品欧美综合四区| 欧美婷婷六月丁香综合色| 尤物在线观看一区| www.色综合.com| 一区二区在线免费观看| 欧美性感一区二区三区| 水野朝阳av一区二区三区| 日韩欧美的一区| 国产a视频精品免费观看| 亚洲欧美在线视频观看| 日本高清免费不卡视频| 午夜精品福利久久久| 欧美成人性战久久| 成人v精品蜜桃久久一区| 国产精品色噜噜| 色婷婷国产精品综合在线观看| 亚洲与欧洲av电影| 欧美成人r级一区二区三区| 成人性色生活片免费看爆迷你毛片| 国产精品进线69影院| 欧美日韩亚洲另类| 国产激情视频一区二区三区欧美 | 99久久国产免费看| 一区二区不卡在线播放 | 亚洲成国产人片在线观看| 欧美一区二区三区系列电影| 大尺度一区二区| 亚洲成a天堂v人片| 国产精品蜜臀在线观看| 538在线一区二区精品国产| 成人免费视频播放| 奇米亚洲午夜久久精品| 中文字幕中文字幕在线一区 | 精品一区在线看| 最新国产成人在线观看| 欧美一区二区三区在线| www.亚洲在线| 韩国一区二区视频| 亚洲一区二区三区在线| 国产日产亚洲精品系列| 欧美日韩国产不卡| 91亚洲国产成人精品一区二区三| 奇米色777欧美一区二区| 成人欧美一区二区三区1314| 精品免费国产一区二区三区四区| 99riav一区二区三区| 韩国成人在线视频| 调教+趴+乳夹+国产+精品| 中文字幕第一页久久| 欧美videos中文字幕| 欧美在线你懂得| 91在线视频在线| 国产盗摄女厕一区二区三区| 亚洲123区在线观看| 久久久无码精品亚洲日韩按摩| 色偷偷久久人人79超碰人人澡| 日本三级亚洲精品| 亚洲成av人片在线观看无码| **欧美大码日韩| 欧美理论片在线| 欧美亚洲高清一区二区三区不卡| 国产成人免费视| 国产91在线观看丝袜| 国产成人av一区二区| 国产精品一区三区| 国产精品一区专区| 国产一区二区三区蝌蚪| 激情偷乱视频一区二区三区| 日韩av在线免费观看不卡| 一区二区日韩av| 亚洲与欧洲av电影| 香蕉久久夜色精品国产使用方法| 亚洲一线二线三线视频| 国产精品欧美极品| 中文字幕亚洲电影| 曰韩精品一区二区| 亚洲va韩国va欧美va精品| 一区二区三区 在线观看视频| 亚洲一区二区三区四区五区中文 | 日本二三区不卡| 欧美天堂一区二区三区| 欧美日韩精品三区| 日韩免费一区二区三区在线播放| 日韩一级视频免费观看在线| 久久综合九色综合97_久久久| 久久亚洲捆绑美女| 最好看的中文字幕久久| 一区二区三区久久| 日本亚洲欧美天堂免费| 国产在线看一区| 成人免费视频播放| 欧美日韩另类一区| 精品福利二区三区| 国产精品国产三级国产专播品爱网| 樱桃国产成人精品视频| 美女在线观看视频一区二区| 国产91高潮流白浆在线麻豆| 91亚洲精品久久久蜜桃网站| 欧美日韩另类一区| 国产偷国产偷精品高清尤物| 一区二区欧美精品| 国产在线一区观看| 在线免费观看视频一区| 日韩午夜在线观看| 亚洲天堂成人在线观看| 全国精品久久少妇| eeuss国产一区二区三区| 在线综合视频播放| 国产精品视频一二三区| 日本一道高清亚洲日美韩| 成人精品国产一区二区4080| 欧美丰满一区二区免费视频| 中文久久乱码一区二区| 免费成人性网站|