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

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

?? pnggccrd.c

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? C
?? 第 1 頁 / 共 5 頁
字號:
                  "movl      %%eax, %%ecx     \n\t"                  "cmpl      $0, %%ecx        \n\t"                  "jz        end24            \n\t"// preload        "movl      mask, %%edx      \n\t"                  "sall      $24, %%edx       \n\t" // make low byte, high byte                "secondloop24:                \n\t"                  "sall      %%edx            \n\t" // move high bit to CF                  "jnc       skip24           \n\t" // if CF = 0                  "movw      (%%esi), %%ax    \n\t"                  "movw      %%ax, (%%edi)    \n\t"                  "xorl      %%eax, %%eax     \n\t"                  "movb      2(%%esi), %%al   \n\t"                  "movb      %%al, 2(%%edi)   \n\t"                "skip24:                      \n\t"                  "addl      $3, %%esi        \n\t"                  "addl      $3, %%edi        \n\t"                  "decl      %%ecx            \n\t"                  "jnz       secondloop24     \n\t"                "end24:                       \n\t"                  "EMMS                       \n\t" // DONE                  : "=a" (dummy_value_a),           // output regs (dummy)                    "=d" (dummy_value_d),                    "=c" (dummy_value_c),                    "=S" (dummy_value_S),                    "=D" (dummy_value_D)                  : "3" (srcptr),      // esi       // input regs                    "4" (dstptr),      // edi                    "0" (diff),        // eax// was (unmask)     "b"    RESERVED    // ebx       // Global Offset Table idx                    "2" (len),         // ecx                    "1" (mask)         // edx#if 0  /* MMX regs (%mm0, etc.) not supported by gcc 2.7.2.3 or egcs 1.1 */                  : "%mm0", "%mm1", "%mm2"          // clobber list                  , "%mm4", "%mm5", "%mm6", "%mm7"#endif               );            }            else /* mmx _not supported - Use modified C routine */#endif /* PNG_ASSEMBLER_CODE_SUPPORTED */            {               register png_uint_32 i;               png_uint_32 initial_val = BPP3 * png_pass_start[png_ptr->pass];                 /* png.c:  png_pass_start[] = {0, 4, 0, 2, 0, 1, 0}; */               register int stride = BPP3 * png_pass_inc[png_ptr->pass];                 /* png.c:  png_pass_inc[] = {8, 8, 4, 4, 2, 2, 1}; */               register int rep_bytes = BPP3 * png_pass_width[png_ptr->pass];                 /* png.c:  png_pass_width[] = {8, 4, 4, 2, 2, 1, 1}; */               png_uint_32 len = png_ptr->width &~7;  /* reduce to mult. of 8 */               int diff = (int) (png_ptr->width & 7); /* amount lost */               register png_uint_32 final_val = BPP3 * len;   /* GRR bugfix */               srcptr = png_ptr->row_buf + 1 + initial_val;               dstptr = row + initial_val;               for (i = initial_val; i < final_val; i += stride)               {                  png_memcpy(dstptr, srcptr, rep_bytes);                  srcptr += stride;                  dstptr += stride;               }               if (diff)  /* number of leftover pixels:  3 for pngtest */               {                  final_val+=diff*BPP3;                  for (; i < final_val; i += stride)                  {                     if (rep_bytes > (int)(final_val-i))                        rep_bytes = (int)(final_val-i);                     png_memcpy(dstptr, srcptr, rep_bytes);                     srcptr += stride;                     dstptr += stride;                  }               }            } /* end of else (_mmx_supported) */            break;         }       /* end 24 bpp */         case 32:       /* 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      _mask32_0, %%mm0 \n\t"                  "movq      _mask32_1, %%mm1 \n\t"                  "movq      _mask32_2, %%mm2 \n\t"                  "movq      _mask32_3, %%mm3 \n\t"                  "pand      %%mm7, %%mm0     \n\t"                  "pand      %%mm7, %%mm1     \n\t"                  "pand      %%mm7, %%mm2     \n\t"                  "pand      %%mm7, %%mm3     \n\t"                  "pcmpeqb   %%mm6, %%mm0     \n\t"                  "pcmpeqb   %%mm6, %%mm1     \n\t"                  "pcmpeqb   %%mm6, %%mm2     \n\t"                  "pcmpeqb   %%mm6, %%mm3     \n\t"// 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" // lcr                  "jz        mainloop32end    \n\t"                "mainloop32:                  \n\t"                  "movq      (%%esi), %%mm4   \n\t"                  "pand      %%mm0, %%mm4     \n\t"                  "movq      %%mm0, %%mm6     \n\t"                  "movq      (%%edi), %%mm7   \n\t"                  "pandn     %%mm7, %%mm6     \n\t"                  "por       %%mm6, %%mm4     \n\t"                  "movq      %%mm4, (%%edi)   \n\t"                  "movq      8(%%esi), %%mm5  \n\t"                  "pand      %%mm1, %%mm5     \n\t"                  "movq      %%mm1, %%mm7     \n\t"                  "movq      8(%%edi), %%mm6  \n\t"                  "pandn     %%mm6, %%mm7     \n\t"                  "por       %%mm7, %%mm5     \n\t"                  "movq      %%mm5, 8(%%edi)  \n\t"                  "movq      16(%%esi), %%mm6 \n\t"                  "pand      %%mm2, %%mm6     \n\t"                  "movq      %%mm2, %%mm4     \n\t"                  "movq      16(%%edi), %%mm7 \n\t"                  "pandn     %%mm7, %%mm4     \n\t"                  "por       %%mm4, %%mm6     \n\t"                  "movq      %%mm6, 16(%%edi) \n\t"                  "movq      24(%%esi), %%mm7 \n\t"                  "pand      %%mm3, %%mm7     \n\t"                  "movq      %%mm3, %%mm5     \n\t"                  "movq      24(%%edi), %%mm4 \n\t"                  "pandn     %%mm4, %%mm5     \n\t"                  "por       %%mm5, %%mm7     \n\t"                  "movq      %%mm7, 24(%%edi) \n\t"                  "addl      $32, %%esi       \n\t" // inc by 32 bytes processed                  "addl      $32, %%edi       \n\t"                  "subl      $8, %%ecx        \n\t" // dec by 8 pixels processed                  "ja        mainloop32       \n\t"                "mainloop32end:               \n\t"// preload        "movl      diff, %%ecx      \n\t" // (diff is in eax)                  "movl      %%eax, %%ecx     \n\t"                  "cmpl      $0, %%ecx        \n\t"                  "jz        end32            \n\t"// preload        "movl      mask, %%edx      \n\t"                  "sall      $24, %%edx       \n\t" // low byte => high byte                "secondloop32:                \n\t"                  "sall      %%edx            \n\t" // move high bit to CF                  "jnc       skip32           \n\t" // if CF = 0                  "movl      (%%esi), %%eax   \n\t"                  "movl      %%eax, (%%edi)   \n\t"                "skip32:                      \n\t"                  "addl      $4, %%esi        \n\t"                  "addl      $4, %%edi        \n\t"                  "decl      %%ecx            \n\t"                  "jnz       secondloop32     \n\t"                "end32:                       \n\t"                  "EMMS                       \n\t" // DONE                  : "=a" (dummy_value_a),           // output regs (dummy)                    "=d" (dummy_value_d),                    "=c" (dummy_value_c),                    "=S" (dummy_value_S),                    "=D" (dummy_value_D)                  : "3" (srcptr),      // esi       // input regs                    "4" (dstptr),      // edi                    "0" (diff),        // eax// was (unmask)     "b"    RESERVED    // ebx       // Global Offset Table idx                    "2" (len),         // ecx                    "1" (mask)         // edx#if 0  /* MMX regs (%mm0, etc.) not supported by gcc 2.7.2.3 or egcs 1.1 */                  : "%mm0", "%mm1", "%mm2", "%mm3"  // clobber list                  , "%mm4", "%mm5", "%mm6", "%mm7"#endif               );            }            else /* mmx _not supported - Use modified C routine */#endif /* PNG_ASSEMBLER_CODE_SUPPORTED */            {               register png_uint_32 i;               png_uint_32 initial_val = BPP4 * png_pass_start[png_ptr->pass];                 /* png.c:  png_pass_start[] = {0, 4, 0, 2, 0, 1, 0}; */               register int stride = BPP4 * png_pass_inc[png_ptr->pass];                 /* png.c:  png_pass_inc[] = {8, 8, 4, 4, 2, 2, 1}; */               register int rep_bytes = BPP4 * png_pass_width[png_ptr->pass];                 /* png.c:  png_pass_width[] = {8, 4, 4, 2, 2, 1, 1}; */               png_uint_32 len = png_ptr->width &~7;  /* reduce to mult. of 8 */               int diff = (int) (png_ptr->width & 7); /* amount lost */               register png_uint_32 final_val = BPP4 * len;   /* GRR bugfix */               srcptr = png_ptr->row_buf + 1 + initial_val;               dstptr = row + initial_val;               for (i = initial_val; i < final_val; i += stride)               {                  png_memcpy(dstptr, srcptr, rep_bytes);                  srcptr += stride;                  dstptr += stride;               }               if (diff)  /* number of leftover pixels:  3 for pngtest */               {                  final_val+=diff*BPP4;                  for (; i < final_val; i += stride)                  {                     if (rep_bytes > (int)(final_val-i))                        rep_bytes = (int)(final_val-i);                     png_memcpy(dstptr, srcptr, rep_bytes);                     srcptr += stride;                     dstptr += stride;                  }               }            } /* end of else (_mmx_supported) */            break;         }       /* end 32 bpp */         case 48:       /* 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      _mask48_0, %%mm0 \n\t"                  "movq      _mask48_1, %%mm1 \n\t"                  "movq      _mask48_2, %%mm2 \n\t"                  "movq      _mask48_3, %%mm3 \n\t"                  "movq      _mask48_4, %%mm4 \n\t"                  "movq      _mask48_5, %%mm5 \n\t"                  "pand      %%mm7, %%mm0     \n\t"                  "pand      %%mm7, %%mm1     \n\t"                  "pand      %%mm7, %%mm2     \n\t"                  "pand      %%mm7, %%mm3     \n\t"                  "pand      %%mm7, %%mm4     \n\t"                  "pand      %%mm7, %%mm5     \n\t"                  "pcmpeqb   %%mm6, %%mm0     \n\t"                  "pcmpeqb   %%mm6, %%mm1     \n\t"                  "pcmpeqb   %%mm6, %%mm2     \n\t"                  "pcmpeqb   %%mm6, %%mm3     \n\t"                  "pcmpeqb   %%mm6, %%mm4     \n\t"                  "pcmpeqb   %%mm6, %%mm5     \n\t"// 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"                  "jz        mainloop48end    \n\t"                "mainloop48:                  \n\t"                  "movq      (%%esi), %%mm7   \n\t"                  "pand      %%mm0, %%mm7     \n\t"                  "movq      %%mm0, %%mm6     \n\t"                  "pandn     (%%edi), %%mm6   \n\t"                  "por       %%mm6, %%mm7     \n\t"                  "movq      %%mm7, (%%edi)   \n\t"

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91色porny蝌蚪| 亚洲综合激情另类小说区| 欧美三级电影在线观看| 国产成人免费在线观看不卡| 婷婷成人综合网| 视频一区在线视频| 亚洲国产日韩a在线播放性色| 中文字幕乱码亚洲精品一区| 久久九九影视网| 91成人看片片| 极品少妇xxxx精品少妇| 久久免费精品国产久精品久久久久 | 亚洲第一综合色| 亚洲免费在线视频一区 二区| 亚洲国产精品t66y| 亚洲乱码中文字幕| 亚洲三级免费观看| 首页国产欧美久久| 亚洲自拍偷拍图区| 日韩电影免费在线看| 精品亚洲免费视频| 99久久久精品免费观看国产蜜| 91亚洲国产成人精品一区二区三| 91日韩一区二区三区| 欧美色图激情小说| 26uuu成人网一区二区三区| 国产三级一区二区| 26uuu国产日韩综合| 亚洲三级小视频| 美女视频免费一区| 色婷婷av一区| 久久久精品国产99久久精品芒果| 精品国产乱码久久久久久影片| 这里只有精品视频在线观看| 亚洲国产精品精华液2区45| 亚洲一区在线视频观看| 亚洲 欧美综合在线网络| 成人国产一区二区三区精品| 91精品国产91久久久久久最新毛片| 国产欧美一区二区三区沐欲| 亚洲精品伦理在线| 毛片一区二区三区| 欧美日韩成人一区| 亚洲欧美日韩国产一区二区三区| 老汉av免费一区二区三区| 欧美在线影院一区二区| 国产精品嫩草影院com| 九九九精品视频| 欧美日韩国产不卡| 亚洲国产精品一区二区久久恐怖片 | 国产成人啪免费观看软件| 日韩欧美一级二级三级久久久| 亚洲主播在线播放| 欧美性生活一区| 一区二区三区免费| 欧美日韩中字一区| 日产精品久久久久久久性色| 欧美日韩高清一区二区不卡| 亚洲亚洲精品在线观看| 欧美日韩免费观看一区二区三区| 久久精品视频一区二区三区| 国产99久久久国产精品免费看| 国产欧美一区二区三区鸳鸯浴| 国产酒店精品激情| 国产精品国产成人国产三级| 欧美日本在线一区| 欧美aaaaa成人免费观看视频| 日韩一区二区电影在线| 国产成人精品亚洲午夜麻豆| 国产亚洲午夜高清国产拍精品| 99在线精品免费| 看国产成人h片视频| 中文字幕视频一区| 久久久亚洲精华液精华液精华液| 国产精品乱码人人做人人爱 | 亚洲一区二区在线播放相泽 | 亚洲国产欧美在线| 精品毛片乱码1区2区3区| 成人激情小说网站| 日韩不卡一二三区| 中文字幕亚洲一区二区av在线| 欧美日韩成人在线一区| www.一区二区| 国产黄人亚洲片| 亚洲成av人在线观看| 国产欧美日韩在线看| 欧美一区午夜视频在线观看| av电影在线观看完整版一区二区| 亚洲五月六月丁香激情| 中文字幕亚洲在| 久久五月婷婷丁香社区| 日韩一级大片在线| 99久久精品国产精品久久| 不卡高清视频专区| 成人深夜视频在线观看| 国产91色综合久久免费分享| 国产激情视频一区二区三区欧美| 久久国产尿小便嘘嘘尿| 久久精品72免费观看| 蓝色福利精品导航| 国产精品夜夜爽| 亚洲一区二区三区视频在线播放 | 国产精品久久久久久久久免费丝袜 | 成人午夜在线播放| 国产iv一区二区三区| 91在线小视频| 91成人免费电影| 91精品国产综合久久福利| 精品剧情v国产在线观看在线| 精品国产91亚洲一区二区三区婷婷 | 蜜桃一区二区三区在线观看| 免费在线观看成人| 成人国产精品免费观看动漫| 91网站在线播放| 日韩你懂的在线播放| 日本一区二区三区高清不卡| 亚洲综合男人的天堂| 精品中文字幕一区二区小辣椒| 久久se精品一区二区| av一二三不卡影片| 欧美sm极限捆绑bd| 日韩欧美视频在线| 亚洲精品视频自拍| 国产成人综合自拍| 成人午夜视频网站| 91精品啪在线观看国产60岁| 国产精品久久精品日日| 国产精品进线69影院| 蜜桃av噜噜一区| 欧美久久一二区| 中文字幕日本不卡| 久久97超碰色| 亚洲国产精品传媒在线观看| 精品欧美一区二区久久| 中文字幕av一区二区三区| 一区二区三区成人| 成人动漫在线一区| 成人精品国产一区二区4080| 久久精品国产成人一区二区三区| 亚洲精品视频在线看| 日韩电影一二三区| 99久精品国产| 日韩一区二区在线播放| 亚洲欧美偷拍卡通变态| 国产在线观看一区二区| 欧美日韩情趣电影| ●精品国产综合乱码久久久久| 国产在线视频一区二区三区| 精品国产亚洲在线| 亚洲欧美乱综合| 成人激情av网| 国产欧美一区二区在线| 人禽交欧美网站| 91视频在线观看| 亚洲午夜久久久久久久久电影院| 成人av在线播放网址| 亚洲午夜电影在线观看| 欧美α欧美αv大片| 91在线视频网址| 国产麻豆午夜三级精品| 麻豆国产欧美日韩综合精品二区| 国产精品夫妻自拍| 国产精品综合av一区二区国产馆| 国产精品资源站在线| 欧美一级高清片| 强制捆绑调教一区二区| 国产精品无遮挡| 五月天久久比比资源色| 精品一区二区影视| 日韩免费成人网| 亚洲在线视频免费观看| 本田岬高潮一区二区三区| 久久精品夜色噜噜亚洲a∨| 老司机精品视频导航| 日韩欧美卡一卡二| 久久99精品国产麻豆婷婷| 日韩视频免费直播| 久久国产夜色精品鲁鲁99| 久久影视一区二区| 久久精品国产99国产精品| 1区2区3区精品视频| 在线一区二区三区四区五区 | 91麻豆精品久久久久蜜臀 | 中文字幕一区二区三中文字幕| 成人短视频下载 | 91麻豆精品国产91久久久资源速度 | 欧美久久久久久久久久| 欧美不卡一二三| 一区二区三区精品在线观看| 国产资源精品在线观看| 精品视频在线免费看| 亚洲国产精品国自产拍av| 蜜桃av噜噜一区二区三区小说| 在线观看视频91| 国产精品久久久爽爽爽麻豆色哟哟| 久久精品国产亚洲a| 欧美性大战久久| 亚洲第一久久影院| 91福利精品视频| 一区二区三区四区激情 |