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

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

?? sse2bfly29.s

?? Viterbi編碼解碼算法
?? S
字號:
/* Intel SIMD SSE2 implementation of Viterbi ACS butterflies
   for 256-state (k=9) convolutional code
   Copyright 2001 Phil Karn, KA9Q
   This code may be used under the terms of the GNU Public License

   int update_viterbi29(struct v29 *vp,unsigned char sym1,unsigned char sym2); 
*/

	# SSE2 (128-bit integer SIMD) version
	# Requires Pentium 4 or better
	# These are offsets into struct v27, defined in viterbi27.h
	.set DP,512
	.set OLDMETRICS,516
	.set NEWMETRICS,520

	.text	
	.global update_viterbi29,Branchtab29_1,Branchtab29_2
	.type update_viterbi29,@function
	.align 16
	
update_viterbi29:
	pushl %ebp
	movl %esp,%ebp
	pushl %esi
	pushl %edi
	pushl %edx
	pushl %ebx
	movl 8(%ebp),%edx	# edx = vp
	movl OLDMETRICS(%edx),%esi	# esi -> old metrics
	movl NEWMETRICS(%edx),%edi	# edi -> new metrics
	movl DP(%edx),%edx	# edx -> decisions

	movd 12(%ebp),%xmm6	# xmm6[0] = first symbol
	movd 16(%ebp),%xmm5	# xmm5[0] = second symbol
	punpcklbw %xmm6,%xmm6	# xmm6[1] = xmm6[0]
	punpcklbw %xmm5,%xmm5
	movdqa fifteens,%xmm7
	pshuflw $0,%xmm6,%xmm6	# copy low word to low 3
	pshuflw $0,%xmm5,%xmm5
	punpcklqdq %xmm6,%xmm6  # propagate to all 16
	punpcklqdq %xmm5,%xmm5
	pand %xmm7,%xmm6
	pand %xmm7,%xmm5
	# xmm6 now contains first symbol in each byte, xmm5 the second

	# each invocation of this macro does 16 butterflies in parallel
	.MACRO butterfly GROUP
	# compute branch metrics
	movdqa Branchtab29_1+(16*\GROUP),%xmm4
	movdqa Branchtab29_2+(16*\GROUP),%xmm3
	pxor %xmm6,%xmm4
	pxor %xmm5,%xmm3
	pavgb %xmm3,%xmm4	# xmm4 contains branch metrics

	movdqa (16*\GROUP)(%esi),%xmm0	# Incoming path metric, high bit = 0
	movdqa ((16*\GROUP)+128)(%esi),%xmm3	# Incoming path metric, high bit = 1
	movdqa %xmm0,%xmm2
	movdqa %xmm3,%xmm1
	paddusb %xmm4,%xmm0
	paddusb %xmm4,%xmm3
	
	# invert branch metrics. This works only because they're 4 bits
	pxor %xmm7,%xmm4
	
	paddusb %xmm4,%xmm1
	paddusb %xmm4,%xmm2
	
	# Find survivors, leave in mm0,2
	pminub %xmm1,%xmm0
	pminub %xmm3,%xmm2
	# get decisions, leave in mm1,3
	pcmpeqb %xmm0,%xmm1
	pcmpeqb %xmm2,%xmm3
	
	# interleave and store new branch metrics in mm0,2
	movdqa %xmm0,%xmm4
	punpckhbw %xmm2,%xmm0	# interleave second 16 new metrics
	punpcklbw %xmm2,%xmm4	# interleave first 16 new metrics
	movdqa %xmm0,(32*\GROUP+16)(%edi)
	movdqa %xmm4,(32*\GROUP)(%edi)

	# interleave decisions & store
	movdqa %xmm1,%xmm4
	punpckhbw %xmm3,%xmm1
	punpcklbw %xmm3,%xmm4
	# work around bug in gas due to Intel doc error
	.byte 0x66,0x0f,0xd7,0xd9	# pmovmskb %xmm1,%ebx
	shll $16,%ebx
	.byte 0x66,0x0f,0xd7,0xc4	# pmovmskb %xmm4,%eax
	orl %eax,%ebx
	movl %ebx,(4*\GROUP)(%edx)
	.endm

	# invoke macro 8 times for a total of 128 butterflies
	butterfly GROUP=0
	butterfly GROUP=1
	butterfly GROUP=2
	butterfly GROUP=3
	butterfly GROUP=4
	butterfly GROUP=5
	butterfly GROUP=6
	butterfly GROUP=7

	addl $32,%edx		# bump decision pointer
		
	# see if we have to normalize
	movl (%edi),%eax	# extract first output metric
	orl $255,%eax
	cmp $150,%eax		# is it greater than 150?
	movl $0,%eax
	jge done		# No, no need to normalize

	# Normalize by finding smallest metric and subtracting it
	# from all metrics
	movdqa (%edi),%xmm0
	pminub 16(%edi),%xmm0
	pminub 32(%edi),%xmm0
	pminub 48(%edi),%xmm0
	pminub 64(%edi),%xmm0
	pminub 80(%edi),%xmm0
	pminub 96(%edi),%xmm0	
	pminub 112(%edi),%xmm0	
	pminub 128(%edi),%xmm0
	pminub 144(%edi),%xmm0
	pminub 160(%edi),%xmm0
	pminub 176(%edi),%xmm0
	pminub 192(%edi),%xmm0
	pminub 208(%edi),%xmm0
	pminub 224(%edi),%xmm0
	pminub 240(%edi),%xmm0							

	# crunch down to single lowest metric
	movdqa %xmm0,%xmm1
	psrldq $8,%xmm0     # the count to psrldq is bytes, not bits!
	pminub %xmm1,%xmm0
	movdqa %xmm0,%xmm1
	psrlq $32,%xmm0
	pminub %xmm1,%xmm0
	movdqa %xmm0,%xmm1
	psrlq $16,%xmm0
	pminub %xmm1,%xmm0
	movdqa %xmm0,%xmm1
	psrlq $8,%xmm0
	pminub %xmm1,%xmm0

	punpcklbw %xmm0,%xmm0	# lowest 2 bytes
	pshuflw $0,%xmm0,%xmm0  # lowest 8 bytes
	punpcklqdq %xmm0,%xmm0	# all 16 bytes

	# xmm0 now contains lowest metric in all 16 bytes
	# subtract it from every output metric
	movdqa (%edi),%xmm1
	psubusb %xmm0,%xmm1
	movdqa %xmm1,(%edi)
	movdqa 16(%edi),%xmm1
	psubusb %xmm0,%xmm1
	movdqa %xmm1,16(%edi)	
	movdqa 32(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,32(%edi)	
	movdqa 48(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,48(%edi)	
	movdqa 64(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,64(%edi)	
	movdqa 80(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,80(%edi)	
	movdqa 96(%edi),%xmm1	
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,96(%edi)	
	movdqa 112(%edi),%xmm1	
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,112(%edi)	
	movdqa 128(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,128(%edi)	
	movdqa 144(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,144(%edi)	
	movdqa 160(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,160(%edi)	
	movdqa 176(%edi),%xmm1
	psubusb %xmm0,%xmm1
	movdqa %xmm1,176(%edi)	
	movdqa 192(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,192(%edi)	
	movdqa 208(%edi),%xmm1
	psubusb %xmm0,%xmm1
	movdqa %xmm1,208(%edi)	
	movdqa 224(%edi),%xmm1
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,224(%edi)	
	movdqa 240(%edi),%xmm1							
	psubusb %xmm0,%xmm1	
	movdqa %xmm1,240(%edi)	
	
	movd %xmm1,%eax
	and $0xff,%eax

done:	movl 8(%ebp),%ebx	# ebx = vp
	movl %edx,DP(%ebx)	# stash incremented value of vp->dp
	
	# swap metrics
	movl %edi,OLDMETRICS(%ebx)
	movl %esi,NEWMETRICS(%ebx)

	popl %ebx
	popl %edx
	popl %edi
	popl %esi
	popl %ebp
	ret

	
	.data
	.align 16
fifteens:	
	.byte 15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品这里都是精品| 99久久er热在这里只有精品66| 色哦色哦哦色天天综合| 日本不卡视频在线| 亚洲乱码国产乱码精品精小说| 精品久久久久久久人人人人传媒 | 日韩视频免费观看高清完整版| 国产一区二区三区av电影| 亚洲已满18点击进入久久| 欧美国产亚洲另类动漫| 日韩精品一区二区三区中文不卡 | 色哟哟亚洲精品| 国产剧情一区二区| 久久国产精品免费| 奇米色777欧美一区二区| 午夜a成v人精品| 国产精品欧美综合在线| 国产精品污www在线观看| 久久色.com| 久久综合国产精品| 久久久久国色av免费看影院| 欧美大度的电影原声| 欧美一级专区免费大片| 欧美日韩免费观看一区三区| 成+人+亚洲+综合天堂| 成人综合婷婷国产精品久久免费| 国产精品18久久久久久久久久久久| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美va在线播放| 日韩视频在线一区二区| 欧美精品一区二区三区蜜桃视频| 欧美成人video| 2021中文字幕一区亚洲| 久久这里只有精品首页| 国产日韩欧美一区二区三区综合| 久久精品夜夜夜夜久久| 国产精品久久久久婷婷| 亚洲欧美在线高清| 一区二区成人在线视频 | 亚洲人吸女人奶水| 亚洲成a天堂v人片| 裸体一区二区三区| 成人美女在线视频| 成人天堂资源www在线| 97成人超碰视| 欧美电影在哪看比较好| 26uuu国产电影一区二区| 日韩一区中文字幕| 午夜精品久久久久久久久久| 精品亚洲国内自在自线福利| 国产成人午夜高潮毛片| 色999日韩国产欧美一区二区| 欧美自拍偷拍午夜视频| 日韩欧美国产精品一区| 国产精品色婷婷久久58| 日韩在线一区二区三区| 懂色av中文字幕一区二区三区| 一本一道波多野结衣一区二区| 91.xcao| 亚洲国产精品高清| 五月激情六月综合| 国内外精品视频| 欧美中文字幕一区二区三区| 精品国产sm最大网站| 亚洲精品国产无天堂网2021| 蜜臀久久99精品久久久画质超高清| 日本不卡在线视频| 色哟哟日韩精品| 久久免费午夜影院| 午夜视黄欧洲亚洲| 成人高清视频在线观看| 欧美一二三四在线| 亚洲综合自拍偷拍| 国产成人午夜电影网| 日韩三级av在线播放| 亚洲国产日日夜夜| 99久久免费视频.com| 精品国精品国产尤物美女| 亚洲第一成人在线| 91碰在线视频| 国产精品美女视频| 国产一区二区三区av电影| 欧美三级资源在线| 亚洲精品视频一区| 国产福利电影一区二区三区| 欧美群妇大交群中文字幕| 亚洲日本va午夜在线影院| 国产成人亚洲精品青草天美| 精品久久久网站| 欧美a级一区二区| 337p亚洲精品色噜噜| 午夜精品久久久久久久| 91婷婷韩国欧美一区二区| 国产精品嫩草影院com| 国产传媒欧美日韩成人| 亚洲精品在线观| 激情文学综合丁香| 久久午夜色播影院免费高清| 日韩精品一二三区| 欧美一区二区三区视频免费播放 | 国产日韩三级在线| 国产成人日日夜夜| 日韩欧美视频在线| 国产在线观看免费一区| 久久这里只精品最新地址| 国产在线精品国自产拍免费| 久久综合五月天婷婷伊人| 国产一区二区三区免费看| 国产区在线观看成人精品| 成人手机电影网| 亚洲精品videosex极品| 在线欧美一区二区| 亚洲成在人线免费| 精品污污网站免费看| 日韩1区2区日韩1区2区| 欧美xxxxxxxx| 成人丝袜18视频在线观看| 亚洲精品成人悠悠色影视| 欧美日韩在线播放三区| 91精品国产综合久久婷婷香蕉 | 成人激情黄色小说| 五月天丁香久久| 亚洲欧洲精品天堂一级| 精品国产sm最大网站| 欧美三级一区二区| 成人精品国产免费网站| 青青草国产成人av片免费| 亚洲欧美怡红院| 久久精品人人做| 91精品国产免费| 91豆麻精品91久久久久久| 国产乱子轮精品视频| 香蕉久久夜色精品国产使用方法| 国产人久久人人人人爽| 精品国产不卡一区二区三区| 精品视频免费看| 91福利小视频| 日本韩国欧美一区二区三区| 成人在线综合网| 粉嫩蜜臀av国产精品网站| 久久草av在线| 久久99精品久久久久久久久久久久| 亚洲图片激情小说| 中文字幕一区二区视频| 国产人成一区二区三区影院| 久久婷婷综合激情| 欧美精品一区二区三区久久久| 日韩三级免费观看| 欧美电影免费观看高清完整版在线 | 欧美性三三影院| 欧美中文字幕一区二区三区亚洲| 91麻豆免费在线观看| 国产成人精品一区二区三区四区| 精品无人码麻豆乱码1区2区| 成人97人人超碰人人99| 丰满岳乱妇一区二区三区| 国产精品1024久久| 成人av先锋影音| 99精品国产视频| 欧美自拍偷拍午夜视频| 精品视频资源站| 日韩欧美精品在线视频| 久久亚洲影视婷婷| 日本一区二区三级电影在线观看 | 成人免费在线视频观看| **网站欧美大片在线观看| 国产精品美女久久久久久久久 | 亚洲天堂精品视频| 亚洲一区二区三区四区不卡| 亚洲不卡在线观看| 美腿丝袜一区二区三区| 国产一区二区在线视频| av毛片久久久久**hd| 91高清在线观看| 欧美一激情一区二区三区| 国产亚洲欧洲一区高清在线观看| 最新日韩在线视频| 午夜激情一区二区| 国产精品538一区二区在线| 97国产一区二区| 69堂成人精品免费视频| 久久久久久亚洲综合| 亚洲精品国产视频| 精品中文av资源站在线观看| 国产盗摄视频一区二区三区| 色婷婷av久久久久久久| 精品毛片乱码1区2区3区| 最新日韩在线视频| 精品一区二区三区影院在线午夜| a美女胸又www黄视频久久| 欧美午夜精品免费| 中文字幕精品综合| 天堂在线一区二区| 不卡高清视频专区| 欧美一级日韩一级| 亚洲一区二区三区四区的| 国产传媒日韩欧美成人| 555夜色666亚洲国产免| 天堂一区二区在线| 99精品欧美一区二区蜜桃免费|