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

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

?? pngvcrd.c

?? linux下的一款播放器
?? 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一区二区三区免费野_久草精品视频
欧美一区二区三区在线看| 色噜噜偷拍精品综合在线| 天天综合日日夜夜精品| 国产老妇另类xxxxx| 欧美日韩精品一区二区在线播放| 久久色在线视频| 日本女优在线视频一区二区| av一区二区三区四区| 久久无码av三级| 亚洲综合在线视频| 琪琪一区二区三区| 国产精品一级片在线观看| 在线日韩av片| 日韩免费在线观看| 亚洲最色的网站| 国产乱人伦偷精品视频免下载| 不卡一区二区三区四区| 日韩一卡二卡三卡四卡| 1区2区3区欧美| 国产成人一区二区精品非洲| 色婷婷av久久久久久久| 精品国产不卡一区二区三区| 亚洲激情图片qvod| 国产精品一区三区| 91精品国产全国免费观看| 亚瑟在线精品视频| 成人性色生活片免费看爆迷你毛片| 成人视屏免费看| 国产精品系列在线| 国产一区二区按摩在线观看| 欧美猛男gaygay网站| 亚洲精品乱码久久久久久日本蜜臀| 国产91对白在线观看九色| 欧美岛国在线观看| 一区二区欧美国产| 美女视频网站黄色亚洲| 97久久久精品综合88久久| 自拍偷拍国产亚洲| 色婷婷亚洲综合| 亚洲一区二区三区中文字幕在线| 国产传媒一区在线| 中国av一区二区三区| 成人综合在线观看| 亚洲色图丝袜美腿| 日本乱码高清不卡字幕| 亚洲美女区一区| 欧美人成免费网站| 紧缚奴在线一区二区三区| 国产欧美一区二区精品性色超碰| 欧美性色欧美a在线播放| 成人国产一区二区三区精品| 精品亚洲国产成人av制服丝袜| 亚洲成av人影院在线观看网| 国产亚洲欧美中文| 欧美四级电影在线观看| 国产.欧美.日韩| 麻豆国产精品777777在线| 国产精品国模大尺度视频| 久久久午夜电影| 欧美疯狂做受xxxx富婆| 91污片在线观看| 国产一区二区h| 美腿丝袜一区二区三区| 亚洲免费成人av| 中文在线一区二区| 国产日韩成人精品| 欧美一区二区大片| 欧美日韩国产综合一区二区| 99国产精品视频免费观看| 久久综合色综合88| 成人av在线电影| 极品销魂美女一区二区三区| 免费看日韩精品| 欧美日韩高清在线播放| 色噜噜久久综合| 欧美一区二区福利在线| 精品国产青草久久久久福利| 精品少妇一区二区三区日产乱码| 欧美精品一区二区蜜臀亚洲| 国产精品色一区二区三区| 亚洲品质自拍视频| 国产精品久久久久久妇女6080| 一区二区三区在线播| 中文字幕一区三区| 日本丰满少妇一区二区三区| 欧美乱熟臀69xxxxxx| 国产一区二区在线观看免费| 一区二区三区美女| 日韩一区二区免费电影| 99国产精品国产精品久久| 日本不卡不码高清免费观看| 一区二区三区四区国产精品| 中文字幕 久热精品 视频在线 | 日韩美女久久久| 在线观看一区日韩| 99精品欧美一区二区三区小说| 狠狠狠色丁香婷婷综合激情| 亚洲成a人片综合在线| 亚洲少妇30p| 亚洲免费观看高清完整版在线 | 欧美性感一区二区三区| 成人精品一区二区三区中文字幕| 成人app在线观看| av电影一区二区| 欧美色图在线观看| 日韩欧美一区在线观看| 一区二区三区四区激情| 美女一区二区久久| 毛片一区二区三区| 99re在线精品| 国产成a人亚洲精品| 免费在线成人网| 亚洲乱码国产乱码精品精可以看| 亚洲欧美日韩一区| 一本到不卡免费一区二区| 欧美电影一区二区三区| 在线观看一区二区视频| 欧美日韩激情一区| 久久欧美一区二区| 亚洲婷婷综合久久一本伊一区| 一区二区久久久久久| 蜜桃91丨九色丨蝌蚪91桃色| 午夜精品久久久久久不卡8050| 国产麻豆精品一区二区| 懂色av一区二区在线播放| 久久亚洲捆绑美女| 色综合久久久久网| 91猫先生在线| 久久av中文字幕片| 91美女在线视频| 久久一留热品黄| 亚洲一线二线三线视频| 国产精品一线二线三线精华| 欧美日韩国产成人在线91| 3d动漫精品啪啪1区2区免费| 中文字幕在线观看一区| 久久精品国产秦先生| 日本电影亚洲天堂一区| 久久精品欧美一区二区三区不卡| 欧美日韩久久一区| 一本到不卡免费一区二区| 欧美日韩国产一级二级| 国产亚洲综合色| 久久精品久久99精品久久| 欧日韩精品视频| 日韩理论片在线| 成人精品gif动图一区| 日韩一区二区高清| 亚洲激情图片一区| 色综合天天综合网天天狠天天| 久久午夜羞羞影院免费观看| 日本中文字幕一区| 欧美日本在线视频| 午夜欧美2019年伦理| 91丨porny丨蝌蚪视频| 国产91精品在线观看| 精品三级av在线| 色综合色综合色综合| 成人99免费视频| 综合色天天鬼久久鬼色| 欧美性淫爽ww久久久久无| 亚洲成人免费在线观看| 3atv在线一区二区三区| 蜜臀a∨国产成人精品| 26uuu国产一区二区三区| 成人性色生活片| 亚洲成a人在线观看| 欧美大度的电影原声| 久久99精品久久只有精品| 一区二区三区资源| 一本一本久久a久久精品综合麻豆| 国产精品欧美极品| 99精品一区二区| 亚洲欧美日韩一区二区| 亚洲色图第一区| 精品国精品国产尤物美女| 精品一区二区在线视频| 久久久99精品免费观看不卡| 国产91清纯白嫩初高中在线观看| 亚洲精品视频一区| 日韩欧美亚洲国产另类| 91日韩精品一区| 国产电影一区在线| 青青草伊人久久| 亚洲激情第一区| 国产精品丝袜久久久久久app| 欧美午夜精品理论片a级按摩| 国产精品一二三在| 美女网站一区二区| 夜夜夜精品看看| 五月天久久比比资源色| 最新不卡av在线| 国产日韩精品一区| 久久久久国产精品厨房| 欧美老肥妇做.爰bbww视频| 成人av在线播放网站| 亚州成人在线电影| 久久久久久久久久久久电影| 成人欧美一区二区三区1314| 国产真实乱偷精品视频免|