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

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

?? deblock_horiz_lpf9.c

?? 本程序介紹MPEG-4解碼技術
?? C
字號:


#include "postprocess_mmx.h"




const static uint64_t mm64_0008 = 0x0008000800080008;
const static uint64_t mm64_0101 = 0x0101010101010101;
static uint64_t mm64_temp;
const static uint64_t mm64_coefs[18] =  {
	0x0001000200040006, /* p1 left */ 0x0000000000000001, /* v1 right */
	0x0001000200020004, /* v1 left */ 0x0000000000010001, /* v2 right */
	0x0002000200040002, /* v2 left */ 0x0000000100010002, /* v3 right */
	0x0002000400020002, /* v3 left */ 0x0001000100020002, /* v4 right */
	0x0004000200020001, /* v4 left */ 0x0001000200020004, /* v5 right */
	0x0002000200010001, /* v5 left */ 0x0002000200040002, /* v6 right */
	0x0002000100010000, /* v6 left */ 0x0002000400020002, /* v7 right */
	0x0001000100000000, /* v7 left */ 0x0004000200020001, /* v8 right */
	0x0001000000000000, /* v8 left */ 0x0006000400020001  /* p2 right */
};
static uint32_t mm32_p1p2;
static uint8_t *pmm1;





INLINE void deblock_horiz_lpf9(uint8_t *v, int stride, int QP) {
	int y, p1, p2;
	#ifdef PP_SELF_CHECK
	uint8_t selfcheck[9];
	int psum;
	uint8_t *vv; 
	int i;	
	#endif

	for (y=0; y<4; y++) {
		p1 = (ABS(v[0+y*stride]-v[1+y*stride]) < QP ) ?  v[0+y*stride] : v[1+y*stride];
		p2 = (ABS(v[8+y*stride]-v[9+y*stride]) < QP ) ?  v[9+y*stride] : v[8+y*stride];

		mm32_p1p2 = 0x0101 * ((p2 << 16) + p1);

		#ifdef PP_SELF_CHECK

		vv = &(v[y*stride]);
		psum = p1 + p1 + p1 + vv[1] + vv[2] + vv[3] + vv[4] + 4;
		selfcheck[1] = (((psum + vv[1]) << 1) - (vv[4] - vv[5])) >> 4;
		psum += vv[5] - p1; 
		selfcheck[2] = (((psum + vv[2]) << 1) - (vv[5] - vv[6])) >> 4;
		psum += vv[6] - p1; 
		selfcheck[3] = (((psum + vv[3]) << 1) - (vv[6] - vv[7])) >> 4;
		psum += vv[7] - p1; 
		selfcheck[4] = (((psum + vv[4]) << 1) + p1 - vv[1] - (vv[7] - vv[8])) >> 4;
		psum += vv[8] - vv[1]; 
		selfcheck[5] = (((psum + vv[5]) << 1) + (vv[1] - vv[2]) - vv[8] + p2) >> 4;
		psum += p2 - vv[2]; 
		selfcheck[6] = (((psum + vv[6]) << 1) + (vv[2] - vv[3])) >> 4;
		psum += p2 - vv[3]; 
		selfcheck[7] = (((psum + vv[7]) << 1) + (vv[3] - vv[4])) >> 4;
		psum += p2 - vv[4]; 
		selfcheck[8] = (((psum + vv[8]) << 1) + (vv[4] - vv[5])) >> 4;
		#endif

		pmm1 = (&(v[y*stride-3])); 		__asm {
			push eax
			push ebx
			mov eax, pmm1
			lea ebx, mm64_coefs

			#ifdef PREFETCH_ENABLE
			prefetcht0 32[ebx]                     
			#endif

			movd   mm0,   mm32_p1p2            
			punpcklbw mm0, mm0                 

			movq    mm2, qword ptr [eax]       
			pxor    mm7, mm7                   

			movq     mm6, mm64_0008            
			punpckhbw mm2, mm2                 

			movq     mm64_temp, mm0           

			punpcklbw mm0, mm7                 
			movq      mm5, mm6                 

			pmullw    mm0, [ebx]              

			movq      mm1, mm2                
			punpcklbw mm2, mm2                 

			punpckhbw mm1, mm1                

			#ifdef PREFETCH_ENABLE
			prefetcht0 32[ebx]                     
			#endif

			movq      mm3, mm2                
			punpcklbw mm2, mm7                

			punpckhbw mm3, mm7                
			paddw     mm6, mm0                

			movq      mm0, mm2                 

			pmullw    mm0, 8[ebx]             
			movq      mm4, mm3                 

			pmullw    mm2, 16[ebx]            

			pmullw    mm3, 32[ebx]            

			pmullw    mm4, 24[ebx]            
			paddw     mm5, mm0               

			paddw     mm6, mm2               
			movq      mm2, mm1                

			punpckhbw mm2, mm7                
			paddw     mm5, mm4               

			punpcklbw mm1, mm7               
			paddw     mm6, mm3                

			#ifdef PREFETCH_ENABLE
			prefetcht0 64[ebx]                   
			#endif
			movq      mm0, mm1                 

			pmullw    mm1, 48[ebx]            

			pmullw    mm0, 40[ebx]            
			movq      mm4, mm2               

			pmullw    mm2, 64[ebx]            
			paddw     mm6, mm1                

			pmullw    mm4, 56[ebx]            
			pxor      mm3, mm3               

			movq      mm1, 8[eax]             
			paddw     mm5, mm0                

			punpcklbw mm1, mm1                
			paddw     mm6, mm2                

			#ifdef PREFETCH_ENABLE
			prefetcht0 96[ebx]                   
			#endif

			movq      mm2, mm1                
			paddw     mm5, mm4               

			punpcklbw mm2, mm2               
			punpckhbw mm1, mm1                

			movq      mm3, mm2                
			punpcklbw mm2, mm7                

			punpckhbw mm3, mm7                
			movq      mm0, mm2                

			pmullw    mm0, 72[ebx]           
			movq      mm4, mm3                

			pmullw    mm2, 80[ebx]           

			pmullw    mm3, 96[ebx]            

			pmullw    mm4, 88[ebx]            
			paddw     mm5, mm0                

			paddw     mm6, mm2                
			movq      mm2, mm1                

			paddw     mm6, mm3                
			punpcklbw mm1, mm7                

			paddw     mm5, mm4                
			punpckhbw mm2, mm7                

			#ifdef PREFETCH_ENABLE
			prefetcht0 128[ebx]                  
			#endif

			movq      mm3, mm64_temp       
			movq      mm0, mm1                

			pmullw    mm0, 104[ebx]          
			movq      mm4, mm2                

			pmullw    mm1, 112[ebx]          
			punpckhbw mm3, mm7                

			pmullw    mm2, 128[ebx]         

			pmullw    mm4, 120[ebx]           
			paddw     mm5, mm0               

			pmullw    mm3, 136[ebx]           
			paddw     mm6, mm1               

			paddw     mm6, mm2                

			paddw     mm5, mm4                
			psrlw     mm6, 4                 

			paddw     mm5, mm3                

			psrlw     mm5, 4                 

			packuswb  mm6, mm5                

			movq      4[eax], mm6             

			pop ebx
			pop eax




		};
	
		#ifdef PP_SELF_CHECK
		for (i=1; i<=8; i++) {
			if (selfcheck[i] != v[i+y*stride]) {
				printf("ERROR: MMX version of horiz lpf9 is incorrect at %d\n", i);
			}
		}
		#endif

	}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区四区精品在线视频| 国产另类ts人妖一区二区| 免费成人在线观看视频| 成人高清视频免费观看| 欧美高清一级片在线| 国产精品久久久久影视| 免费日韩伦理电影| 欧洲日韩一区二区三区| 久久久久国产成人精品亚洲午夜| 丝袜国产日韩另类美女| 成人sese在线| 国产精品网站在线播放| 韩国精品免费视频| 91精品国产欧美一区二区18 | 亚洲国产成人av网| 国产精品正在播放| 日韩精品中文字幕在线一区| 亚洲无线码一区二区三区| 一本一道久久a久久精品| 国产精品丝袜在线| 成人免费三级在线| 国产喂奶挤奶一区二区三区| 美腿丝袜在线亚洲一区 | 国产亚洲综合在线| 精品一区二区在线免费观看| 日韩精品中文字幕在线不卡尤物| 琪琪一区二区三区| 欧美丰满嫩嫩电影| 日韩精品一二三区| 6080午夜不卡| 蜜臀av在线播放一区二区三区| 欧美精品一级二级三级| 日韩精品乱码av一区二区| 欧美情侣在线播放| 日本亚洲欧美天堂免费| 欧美一级国产精品| 精品一区二区三区在线观看国产| 日韩精品专区在线影院观看| 国内成+人亚洲+欧美+综合在线| 欧美一区二区久久| 韩国精品在线观看| 国产精品国产三级国产普通话99 | 一区二区三区中文在线观看| 91麻豆视频网站| 亚洲成人激情综合网| 69成人精品免费视频| 精品一区二区三区不卡| 精品国产第一区二区三区观看体验 | 美国毛片一区二区| 久久一夜天堂av一区二区三区| 国产成人99久久亚洲综合精品| 中文字幕av一区二区三区高| 91福利在线观看| 美脚の诱脚舐め脚责91| 亚洲国产激情av| 欧美在线色视频| 蜜臀av在线播放一区二区三区| 国产女主播在线一区二区| 91国模大尺度私拍在线视频| 久久超碰97人人做人人爱| 国产精品伦一区| 欧美性猛交xxxx乱大交退制版| 久久精工是国产品牌吗| 国产精品嫩草影院com| 欧美精品在线观看一区二区| 国产在线精品一区二区| 一区二区三区日本| 欧美成人性战久久| 91视频www| 国产在线视频一区二区| 亚洲精品菠萝久久久久久久| 精品日韩一区二区三区免费视频| 95精品视频在线| 国产一区二区0| 亚洲精品中文在线观看| 欧美不卡一区二区三区四区| 99久久久久久| 激情五月播播久久久精品| 亚洲靠逼com| 国产视频不卡一区| 日韩亚洲欧美在线| 日本韩国一区二区| 风间由美一区二区av101| 午夜影院久久久| 亚洲视频一二区| 精品国产91洋老外米糕| 精品视频1区2区| 成人免费的视频| 激情综合网天天干| 午夜精品爽啪视频| 中文字幕中文乱码欧美一区二区| 日韩精品一区二区三区swag| 欧美午夜片在线看| 9l国产精品久久久久麻豆| 久久国产视频网| 日韩黄色片在线观看| 亚洲免费成人av| 国产精品久久久久影院色老大| 精品国产乱码久久久久久夜甘婷婷| 在线免费av一区| 北条麻妃一区二区三区| 国产成人亚洲综合a∨婷婷| 美女精品自拍一二三四| 日本欧美肥老太交大片| 午夜精品成人在线| 亚洲国产美女搞黄色| 亚洲精品国产a| 亚洲精品视频在线看| 亚洲精品视频在线| 亚洲免费av在线| 一区二区三区四区中文字幕| 亚洲色图视频网| 国产精品美女一区二区| 国产清纯美女被跳蛋高潮一区二区久久w| 欧美一区二区成人6969| 日韩一区二区在线播放| 欧美一级高清片| 日韩一区二区三| 欧美不卡一区二区三区四区| 精品99一区二区三区| 久久久三级国产网站| 中文字幕国产精品一区二区| 国产精品入口麻豆原神| 中文字幕亚洲成人| 一区二区在线观看免费| 亚洲成人在线网站| 日韩高清国产一区在线| 九九视频精品免费| 国产成人午夜视频| 色综合久久综合网97色综合| 欧美亚洲一区二区三区四区| 成人免费一区二区三区视频 | 首页亚洲欧美制服丝腿| 丝袜国产日韩另类美女| 国精品**一区二区三区在线蜜桃| 黑人巨大精品欧美一区| av在线不卡免费看| 欧美日韩视频在线观看一区二区三区 | 精品国免费一区二区三区| 2020日本不卡一区二区视频| 中文欧美字幕免费| 亚洲午夜精品17c| 久久精品国产999大香线蕉| 懂色av噜噜一区二区三区av| 91在线免费看| 欧美日产在线观看| 国产三区在线成人av| 亚洲综合成人在线| 狠狠色综合播放一区二区| 99re66热这里只有精品3直播 | 一区二区三区精品视频| 蜜桃视频一区二区三区| 91视频免费播放| 精品99999| 一个色妞综合视频在线观看| 久久精品二区亚洲w码| 一本久久a久久精品亚洲| 日韩欧美激情一区| 亚洲精品欧美激情| 国产一区二区免费看| 欧美日韩一区不卡| 国产欧美一区二区精品仙草咪| 亚洲丶国产丶欧美一区二区三区| 国产精品1区2区| 在线成人免费观看| 日韩美女精品在线| 国产一区二区三区综合| 欧美三区在线观看| 国产精品国产三级国产aⅴ原创| 视频在线观看91| 色美美综合视频| 国产午夜精品久久久久久免费视 | 欧美三级一区二区| 国产欧美精品一区| 极品少妇一区二区| 91精品国产综合久久久久久久 | 蜜臀久久99精品久久久久宅男| xnxx国产精品| 日韩精品电影在线观看| 欧美在线观看视频一区二区| 国产精品无码永久免费888| 久久精工是国产品牌吗| 欧美一区在线视频| 天堂资源在线中文精品| 欧美性大战xxxxx久久久| 中文字幕一区二区三| 豆国产96在线|亚洲| 337p日本欧洲亚洲大胆色噜噜| 青青草国产精品97视觉盛宴 | 中文一区二区完整视频在线观看| 麻豆91在线播放| 欧美v国产在线一区二区三区| 天天亚洲美女在线视频| 欧美日韩精品三区| 天天综合网 天天综合色| 欧美日韩国产精品成人| 亚洲v中文字幕| 欧美女孩性生活视频| 日精品一区二区三区| 欧美一区欧美二区|