nb_kernel113_x86_64_sse2.intel_syntax.s

来自「最著名最快的分子模拟软件」· S 代码 · 共 2,046 行 · 第 1/4 页

S
2,046
字号
	movhpd xmm3, [rsi + rbx*8]	movapd xmm4, xmm3	mulpd  xmm3, [rsp + nb113nf_iqM]	mulpd  xmm4, [rsp + nb113nf_iqH]	movd  mm0, eax		;# use mmx registers as temp storage 	movd  mm1, ebx	movapd  [rsp + nb113nf_qqM], xmm3	movapd  [rsp + nb113nf_qqH], xmm4		mov rsi, [rbp + nb113nf_type]	mov eax, [rsi + rax*4]	mov ebx, [rsi + rbx*4]	mov rsi, [rbp + nb113nf_vdwparam]	shl eax, 1		shl ebx, 1		mov edi, [rsp + nb113nf_ntia]	add eax, edi	add ebx, edi	movlpd xmm6, [rsi + rax*8]	;# c6a	movlpd xmm7, [rsi + rbx*8]	;# c6b	movhpd xmm6, [rsi + rax*8 + 8]	;# c6a c12a 	movhpd xmm7, [rsi + rbx*8 + 8]	;# c6b c12b 	movapd xmm4, xmm6	unpcklpd xmm4, xmm7	unpckhpd xmm6, xmm7		movd  eax, mm0	movd  ebx, mm1	movapd [rsp + nb113nf_c6], xmm4	movapd [rsp + nb113nf_c12], xmm6		mov rsi, [rbp + nb113nf_pos]       ;# base of pos[] 	lea   rax, [rax + rax*2]     ;# replace jnr with j3 	lea   rbx, [rbx + rbx*2]		;# move two coordinates to xmm0-xmm2 	movlpd xmm0, [rsi + rax*8]	movlpd xmm1, [rsi + rax*8 + 8]	movlpd xmm2, [rsi + rax*8 + 16]	movhpd xmm0, [rsi + rbx*8]	movhpd xmm1, [rsi + rbx*8 + 8]	movhpd xmm2, [rsi + rbx*8 + 16]			;# move ixO-izO to xmm4-xmm6 	movapd xmm4, [rsp + nb113nf_ixO]	movapd xmm5, [rsp + nb113nf_iyO]	movapd xmm6, [rsp + nb113nf_izO]	;# calc dr 	subpd xmm4, xmm0	subpd xmm5, xmm1	subpd xmm6, xmm2	;# square it 	mulpd xmm4,xmm4	mulpd xmm5,xmm5	mulpd xmm6,xmm6	addpd xmm4, xmm5	addpd xmm4, xmm6	movapd xmm7, xmm4	;# rsqO in xmm7 	;# move ixH1-izH1 to xmm4-xmm6 	movapd xmm4, [rsp + nb113nf_ixH1]	movapd xmm5, [rsp + nb113nf_iyH1]	movapd xmm6, [rsp + nb113nf_izH1]	;# calc dr 	subpd xmm4, xmm0	subpd xmm5, xmm1	subpd xmm6, xmm2	;# square it 	mulpd xmm4,xmm4	mulpd xmm5,xmm5	mulpd xmm6,xmm6	addpd xmm6, xmm5	addpd xmm6, xmm4	;# rsqH1 in xmm6 	;# move ixH2-izH2 to xmm3-xmm5  	movapd xmm3, [rsp + nb113nf_ixH2]	movapd xmm4, [rsp + nb113nf_iyH2]	movapd xmm5, [rsp + nb113nf_izH2]	;# calc dr 	subpd xmm3, xmm0	subpd xmm4, xmm1	subpd xmm5, xmm2	;# square it 	mulpd xmm3,xmm3	mulpd xmm4,xmm4	mulpd xmm5,xmm5	addpd xmm5, xmm4	addpd xmm5, xmm3	;# move ixM-izM to xmm2-xmm4  	movapd xmm3, [rsp + nb113nf_iyM]	movapd xmm4, [rsp + nb113nf_izM]	subpd  xmm3, xmm1	subpd  xmm4, xmm2	movapd xmm2, [rsp + nb113nf_ixM]	subpd  xmm2, xmm0		;# square it 	mulpd xmm2,xmm2	mulpd xmm3,xmm3	mulpd xmm4,xmm4	addpd xmm4, xmm3	addpd xmm4, xmm2		;# rsqM in xmm4, rsqH2 in xmm5, rsqH1 in xmm6, rsqO in xmm7 	;# start with rsqH1 - put seed in xmm2 	cvtpd2ps xmm2, xmm6		rsqrtps xmm2, xmm2	cvtps2pd xmm2, xmm2		movapd  xmm3, xmm2	mulpd   xmm2, xmm2	movapd  xmm1, [rsp + nb113nf_three]	mulpd   xmm2, xmm6	;# rsq*lu*lu 	subpd   xmm1, xmm2	;# 30-rsq*lu*lu 	mulpd   xmm1, xmm3	;# lu*(3-rsq*lu*lu) 	mulpd   xmm1, [rsp + nb113nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulpd xmm1, xmm1	;# lu*lu 	mulpd xmm6, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb113nf_three]	subpd xmm1, xmm6	;# 3-rsq*lu*lu 	mulpd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulpd xmm1, [rsp + nb113nf_half] ;# rinv 	movapd  xmm6, xmm1	;# rinvH1	;# rsqH2 - seed in xmm2 	cvtpd2ps xmm2, xmm5		rsqrtps xmm2, xmm2	cvtps2pd xmm2, xmm2	movapd  xmm3, xmm2	mulpd   xmm2, xmm2	movapd  xmm1, [rsp + nb113nf_three]	mulpd   xmm2, xmm5	;# rsq*lu*lu 	subpd   xmm1, xmm2	;# 30-rsq*lu*lu 	mulpd   xmm1, xmm3	;# lu*(3-rsq*lu*lu) 	mulpd   xmm1, [rsp + nb113nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulpd xmm1, xmm1	;# lu*lu 	mulpd xmm5, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb113nf_three]	subpd xmm1, xmm5	;# 3-rsq*lu*lu 	mulpd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulpd xmm1, [rsp + nb113nf_half] ;# rinv 	movapd  xmm5, xmm1	;# rinvH2		;# rsqM - seed in xmm2 	cvtpd2ps xmm2, xmm4		rsqrtps xmm2, xmm2	cvtps2pd xmm2, xmm2	movapd  xmm3, xmm2	mulpd   xmm2, xmm2	movapd  xmm1, [rsp + nb113nf_three]	mulpd   xmm2, xmm4	;# rsq*lu*lu 	subpd   xmm1, xmm2	;# 30-rsq*lu*lu 	mulpd   xmm1, xmm3	;# lu*(3-rsq*lu*lu) 	mulpd   xmm1, [rsp + nb113nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulpd xmm1, xmm1	;# lu*lu 	mulpd xmm4, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb113nf_three]	subpd xmm1, xmm4	;# 3-rsq*lu*lu 	mulpd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulpd xmm1, [rsp + nb113nf_half] ;# rinv 	movapd  xmm4, xmm1	;# rinvM	;# calculate coulomb potentials from rinv.	addpd   xmm6, xmm5	;# rinvH1+rinvH2	mulpd	xmm4, [rsp + nb113nf_qqM]	mulpd	xmm6, [rsp + nb113nf_qqH]	addpd   xmm4, xmm6	addpd   xmm4, [rsp + nb113nf_vctot]	movapd  [rsp + nb113nf_vctot], xmm4	;# do O interactions - rsqO is in xmm7	cvtpd2ps xmm2, xmm7	movapd   xmm6, xmm7	rcpps    xmm2, xmm2	cvtps2pd xmm2, xmm2	movapd   xmm1, [rsp + nb113nf_two]	movapd   xmm0, xmm1	mulpd   xmm7, xmm2	subpd   xmm1, xmm7	mulpd   xmm2, xmm1 ;# iter1 	mulpd   xmm6, xmm2	subpd   xmm0, xmm6	mulpd   xmm0, xmm2 ;# xmm0=rinvsq	movapd  xmm1, xmm0		mulpd   xmm1, xmm1 ;# rinv4	mulpd   xmm1, xmm0 ;#rinvsix	movapd  xmm2, xmm1	mulpd	xmm2, xmm2 ;# rinvtwelve	mulpd  xmm1, [rsp + nb113nf_c6]	mulpd  xmm2, [rsp + nb113nf_c12]	movapd xmm3, xmm2	subpd  xmm3, xmm1	;# Vvdw=Vvdw12-Vvdw6 			addpd  xmm3, [rsp + nb113nf_Vvdwtot]	movapd [rsp + nb113nf_Vvdwtot], xmm3	;# should we do one more iteration? 	sub dword ptr [rsp + nb113nf_innerk],  2	jl   .nb113nf_checksingle	jmp  .nb113nf_unroll_loop.nb113nf_checksingle:		add dword ptr [rsp + nb113nf_innerk],  2	jnz  .nb113nf_dosingle	jmp  .nb113nf_updateouterdata.nb113nf_dosingle:	mov   rdx, [rsp + nb113nf_innerjjnr]     ;# pointer to jjnr[k] 	mov   eax, [rdx]		add qword ptr [rsp + nb113nf_innerjjnr],  4		mov rsi, [rbp + nb113nf_charge]    ;# base of charge[] 	xorpd xmm3, xmm3	movlpd xmm3, [rsi + rax*8]	movapd xmm4, xmm3	mulpd  xmm3, [rsp + nb113nf_iqM]	mulpd  xmm4, [rsp + nb113nf_iqH]	movd  mm0, eax		;# use mmx registers as temp storage 	movapd  [rsp + nb113nf_qqM], xmm3	movapd  [rsp + nb113nf_qqH], xmm4		mov rsi, [rbp + nb113nf_type]	mov eax, [rsi + rax*4]	mov rsi, [rbp + nb113nf_vdwparam]	shl eax, 1		mov edi, [rsp + nb113nf_ntia]	add eax, edi	movlpd xmm6, [rsi + rax*8]	;# c6a	movhpd xmm6, [rsi + rax*8 + 8]	;# c6a c12a 	xorpd xmm7, xmm7	movapd xmm4, xmm6	unpcklpd xmm4, xmm7	unpckhpd xmm6, xmm7		movd  eax, mm0	movd  ebx, mm1	movapd [rsp + nb113nf_c6], xmm4	movapd [rsp + nb113nf_c12], xmm6		mov rsi, [rbp + nb113nf_pos]       ;# base of pos[] 	lea   rax, [rax + rax*2]     ;# replace jnr with j3 	;# move coordinates to xmm0-xmm2 	movlpd xmm0, [rsi + rax*8]	movlpd xmm1, [rsi + rax*8 + 8]	movlpd xmm2, [rsi + rax*8 + 16]	;# move ixO-izO to xmm4-xmm6 	movapd xmm4, [rsp + nb113nf_ixO]	movapd xmm5, [rsp + nb113nf_iyO]	movapd xmm6, [rsp + nb113nf_izO]	;# calc dr 	subsd xmm4, xmm0	subsd xmm5, xmm1	subsd xmm6, xmm2	;# square it 	mulsd xmm4,xmm4	mulsd xmm5,xmm5	mulsd xmm6,xmm6	addsd xmm4, xmm5	addsd xmm4, xmm6	movapd xmm7, xmm4	;# rsqO in xmm7 	;# move ixH1-izH1 to xmm4-xmm6 	movapd xmm4, [rsp + nb113nf_ixH1]	movapd xmm5, [rsp + nb113nf_iyH1]	movapd xmm6, [rsp + nb113nf_izH1]	;# calc dr 	subsd xmm4, xmm0	subsd xmm5, xmm1	subsd xmm6, xmm2	;# square it 	mulsd xmm4,xmm4	mulsd xmm5,xmm5	mulsd xmm6,xmm6	addsd xmm6, xmm5	addsd xmm6, xmm4	;# rsqH1 in xmm6 	;# move ixH2-izH2 to xmm3-xmm5  	movapd xmm3, [rsp + nb113nf_ixH2]	movapd xmm4, [rsp + nb113nf_iyH2]	movapd xmm5, [rsp + nb113nf_izH2]	;# calc dr 	subsd xmm3, xmm0	subsd xmm4, xmm1	subsd xmm5, xmm2	;# square it 	mulsd xmm3,xmm3	mulsd xmm4,xmm4	mulsd xmm5,xmm5	addsd xmm5, xmm4	addsd xmm5, xmm3	;# move ixM-izM to xmm2-xmm4  	movapd xmm3, [rsp + nb113nf_iyM]	movapd xmm4, [rsp + nb113nf_izM]	subpd  xmm3, xmm1	subpd  xmm4, xmm2	movapd xmm2, [rsp + nb113nf_ixM]	subpd  xmm2, xmm0		;# square it 	mulpd xmm2,xmm2	mulpd xmm3,xmm3	mulpd xmm4,xmm4	addpd xmm4, xmm3	addpd xmm4, xmm2		;# rsqM in xmm4, rsqH2 in xmm5, rsqH1 in xmm6, rsqO in xmm7 	;# start with rsqH1 - put seed in xmm2 	cvtsd2ss xmm2, xmm6		rsqrtss xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd  xmm3, xmm2	mulsd   xmm2, xmm2	movapd  xmm1, [rsp + nb113nf_three]	mulsd   xmm2, xmm6	;# rsq*lu*lu 	subsd   xmm1, xmm2	;# 30-rsq*lu*lu 	mulsd   xmm1, xmm3	;# lu*(3-rsq*lu*lu) 	mulsd   xmm1, [rsp + nb113nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulsd xmm1, xmm1	;# lu*lu 	mulsd xmm6, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb113nf_three]	subsd xmm1, xmm6	;# 3-rsq*lu*lu 	mulsd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulsd xmm1, [rsp + nb113nf_half] ;# rinv 	movapd xmm6, xmm1		;# rsqH2 - seed in xmm2 	cvtsd2ss xmm2, xmm5		rsqrtss xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd  xmm3, xmm2	mulsd   xmm2, xmm2	movapd  xmm1, [rsp + nb113nf_three]	mulsd   xmm2, xmm5	;# rsq*lu*lu 	subsd   xmm1, xmm2	;# 30-rsq*lu*lu 	mulsd   xmm1, xmm3	;# lu*(3-rsq*lu*lu) 	mulsd   xmm1, [rsp + nb113nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulsd xmm1, xmm1	;# lu*lu 	mulsd xmm5, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb113nf_three]	subsd xmm1, xmm5	;# 3-rsq*lu*lu 	mulsd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulsd xmm1, [rsp + nb113nf_half] ;# rinv 	movapd xmm5, xmm1		;# rsqM - seed in xmm2 	cvtsd2ss xmm2, xmm4	rsqrtss xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd  xmm3, xmm2	mulsd   xmm2, xmm2	movapd  xmm1, [rsp + nb113nf_three]	mulsd   xmm2, xmm4	;# rsq*lu*lu 	subsd   xmm1, xmm2	;# 30-rsq*lu*lu 	mulsd   xmm1, xmm3	;# lu*(3-rsq*lu*lu) 	mulsd   xmm1, [rsp + nb113nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulsd xmm1, xmm1	;# lu*lu 	mulsd xmm4, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb113nf_three]	subsd xmm1, xmm4	;# 3-rsq*lu*lu 	mulsd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulsd xmm1, [rsp + nb113nf_half] ;# rinv 	movapd xmm4, xmm1	;# Calculate coulomb potential	addsd  xmm6, xmm5 	;# rinvH1+rinvH2	mulsd  xmm4, [rsp + nb113nf_qqM]	mulsd  xmm6, [rsp + nb113nf_qqH]	addsd  xmm4, xmm6	addsd xmm4, [rsp + nb113nf_vctot]	movsd [rsp + nb113nf_vctot], xmm4	;# do O interactions directly. xmm7=rsq	cvtsd2ss xmm2, xmm7	movapd   xmm6, xmm7	rcpps    xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd   xmm1, [rsp + nb113nf_two]	movapd   xmm0, xmm1	mulsd   xmm7, xmm2	subsd   xmm1, xmm7	mulsd   xmm2, xmm1 ;# iter1 	mulsd   xmm6, xmm2	subsd   xmm0, xmm6	mulsd   xmm0, xmm2 ;# xmm0=rinvsq	movapd  xmm1, xmm0		mulsd   xmm1, xmm1 ;# rinv4	mulsd   xmm1, xmm0 ;#rinvsix	movapd  xmm2, xmm1	mulsd	xmm2, xmm2 ;# rinvtwelve	mulsd  xmm1, [rsp + nb113nf_c6]	mulsd  xmm2, [rsp + nb113nf_c12]	movapd xmm3, xmm2	subsd  xmm3, xmm1	;# Vvdw=Vvdw12-Vvdw6 			addsd  xmm3, [rsp + nb113nf_Vvdwtot]	movsd [rsp + nb113nf_Vvdwtot], xmm3.nb113nf_updateouterdata:	;# get n from stack	mov esi, [rsp + nb113nf_n]        ;# get group index for i particle         mov   rdx, [rbp + nb113nf_gid]      	;# base of gid[]        mov   edx, [rdx + rsi*4]		;# ggid=gid[n]	;# accumulate total potential energy and update it 	movapd xmm7, [rsp + nb113nf_vctot]	;# accumulate 	movhlps xmm6, xmm7	addsd  xmm7, xmm6	;# low xmm7 has the sum now         	;# add earlier value from mem 	mov   rax, [rbp + nb113nf_Vc]	addsd xmm7, [rax + rdx*8] 	;# move back to mem 	movsd [rax + rdx*8], xmm7 		;# accumulate total lj energy and update it 	movapd xmm7, [rsp + nb113nf_Vvdwtot]	;# accumulate 	movhlps xmm6, xmm7	addsd  xmm7, xmm6	;# low xmm7 has the sum now 	;# add earlier value from mem 	mov   rax, [rbp + nb113nf_Vvdw]	addsd xmm7, [rax + rdx*8] 	;# move back to mem 	movsd [rax + rdx*8], xmm7 	       ;# finish if last         mov ecx, [rsp + nb113nf_nn1]	;# esi already loaded with n	inc esi        sub ecx, esi        jz .nb113nf_outerend        ;# not last, iterate outer loop once more!          mov [rsp + nb113nf_n], esi        jmp .nb113nf_outer.nb113nf_outerend:        ;# check if more outer neighborlists remain        mov   ecx, [rsp + nb113nf_nri]	;# esi already loaded with n above        sub   ecx, esi        jz .nb113nf_end        ;# non-zero, do one more workunit        jmp   .nb113nf_threadloop.nb113nf_end:	mov eax, [rsp + nb113nf_nouter]	mov ebx, [rsp + nb113nf_ninner]	mov rcx, [rbp + nb113nf_outeriter]	mov rdx, [rbp + nb113nf_inneriter]	mov [rcx], eax	mov [rdx], ebx	add rsp, 472	emms        pop r15        pop r14        pop r13        pop r12	pop rbx	pop	rbp	ret

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?