nb_kernel213_x86_64_sse2.intel_syntax.s

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

S
2,195
字号
	shl ebx, 1		mov edi, [rsp + nb213nf_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 + nb213nf_c6], xmm4	movapd [rsp + nb213nf_c12], xmm6		mov rsi, [rbp + nb213nf_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 + nb213nf_ixO]	movapd xmm5, [rsp + nb213nf_iyO]	movapd xmm6, [rsp + nb213nf_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 + nb213nf_ixH1]	movapd xmm5, [rsp + nb213nf_iyH1]	movapd xmm6, [rsp + nb213nf_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 + nb213nf_ixH2]	movapd xmm4, [rsp + nb213nf_iyH2]	movapd xmm5, [rsp + nb213nf_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 + nb213nf_iyM]	movapd xmm4, [rsp + nb213nf_izM]	subpd  xmm3, xmm1	subpd  xmm4, xmm2	movapd xmm2, [rsp + nb213nf_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 	;# calculate krsq	movapd xmm0, [rsp + nb213nf_krf]	movapd xmm1, xmm0	movapd xmm2, xmm0	mulpd xmm0, xmm4  	mulpd xmm1, xmm5	mulpd xmm2, xmm6	movapd [rsp + nb213nf_krsqM], xmm0	movapd [rsp + nb213nf_krsqH2], xmm1	movapd [rsp + nb213nf_krsqH1], xmm2	;# 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 + nb213nf_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 + nb213nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulpd xmm1, xmm1	;# lu*lu 	mulpd xmm6, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb213nf_three]	subpd xmm1, xmm6	;# 3-rsq*lu*lu 	mulpd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulpd xmm1, [rsp + nb213nf_half] ;# rinv 	movapd  [rsp + nb213nf_rinvH1], xmm1		;# rsqH2 - seed in xmm2 	cvtpd2ps xmm2, xmm5		rsqrtps xmm2, xmm2	cvtps2pd xmm2, xmm2	movapd  xmm3, xmm2	mulpd   xmm2, xmm2	movapd  xmm1, [rsp + nb213nf_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 + nb213nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulpd xmm1, xmm1	;# lu*lu 	mulpd xmm5, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb213nf_three]	subpd xmm1, xmm5	;# 3-rsq*lu*lu 	mulpd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulpd xmm1, [rsp + nb213nf_half] ;# rinv 	movapd  [rsp + nb213nf_rinvH2], xmm1			;# rsqM - seed in xmm2 	cvtpd2ps xmm2, xmm4		rsqrtps xmm2, xmm2	cvtps2pd xmm2, xmm2	movapd  xmm3, xmm2	mulpd   xmm2, xmm2	movapd  xmm1, [rsp + nb213nf_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 + nb213nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulpd xmm1, xmm1	;# lu*lu 	mulpd xmm4, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb213nf_three]	subpd xmm1, xmm4	;# 3-rsq*lu*lu 	mulpd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulpd xmm1, [rsp + nb213nf_half] ;# rinv 	movapd  [rsp + nb213nf_rinvM], xmm1		;# do O interactions directly - rsqO is in xmm7	cvtpd2ps xmm2, xmm7	movapd   xmm6, xmm7	rcpps    xmm2, xmm2	cvtps2pd xmm2, xmm2	movapd   xmm1, [rsp + nb213nf_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 + nb213nf_c6]	mulpd  xmm2, [rsp + nb213nf_c12]	movapd xmm3, xmm2	subpd  xmm3, xmm1	;# Vvdw=Vvdw12-Vvdw6 			addpd  xmm3, [rsp + nb213nf_Vvdwtot]	movapd [rsp + nb213nf_Vvdwtot], xmm3	;# H1 interactions 	movapd  xmm6, [rsp + nb213nf_rinvH1]	addpd   xmm6, [rsp + nb213nf_krsqH1] 	subpd   xmm6, [rsp + nb213nf_crf]	mulpd   xmm6, [rsp + nb213nf_qqH] ;# vcoul 	addpd   xmm6, [rsp + nb213nf_vctot]	movapd [rsp + nb213nf_vctot], xmm6		;# H2 interactions 	movapd  xmm6, [rsp + nb213nf_rinvH2]	addpd   xmm6, [rsp + nb213nf_krsqH2] 	subpd   xmm6, [rsp + nb213nf_crf]	mulpd   xmm6, [rsp + nb213nf_qqH] ;# vcoul 	addpd   xmm6, [rsp + nb213nf_vctot]	movapd [rsp + nb213nf_vctot], xmm6	;# M interactions 	movapd  xmm6, [rsp + nb213nf_rinvM]	addpd   xmm6, [rsp + nb213nf_krsqM] 	subpd   xmm6, [rsp + nb213nf_crf]	mulpd   xmm6, [rsp + nb213nf_qqM] ;# vcoul 	addpd   xmm6, [rsp + nb213nf_vctot]	movapd [rsp + nb213nf_vctot], xmm6		;# should we do one more iteration? 	sub dword ptr [rsp + nb213nf_innerk],  2	jl   .nb213nf_checksingle	jmp  .nb213nf_unroll_loop.nb213nf_checksingle:		mov   edx, [rsp + nb213nf_innerk]	and   edx, 1	jnz  .nb213nf_dosingle	jmp  .nb213nf_updateouterdata.nb213nf_dosingle:	mov   rdx, [rsp + nb213nf_innerjjnr]     ;# pointer to jjnr[k] 	mov   eax, [rdx]		add qword ptr [rsp + nb213nf_innerjjnr],  4		mov rsi, [rbp + nb213nf_charge]    ;# base of charge[] 	xorpd xmm3, xmm3	movlpd xmm3, [rsi + rax*8]	movapd xmm4, xmm3	mulsd  xmm3, [rsp + nb213nf_iqM]	mulsd  xmm4, [rsp + nb213nf_iqH]	movd  mm0, eax		;# use mmx registers as temp storage 	movapd  [rsp + nb213nf_qqM], xmm3	movapd  [rsp + nb213nf_qqH], xmm4		mov rsi, [rbp + nb213nf_type]	mov eax, [rsi + rax*4]	mov rsi, [rbp + nb213nf_vdwparam]	shl eax, 1		mov edi, [rsp + nb213nf_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 + nb213nf_c6], xmm4	movapd [rsp + nb213nf_c12], xmm6		mov rsi, [rbp + nb213nf_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 + nb213nf_ixO]	movapd xmm5, [rsp + nb213nf_iyO]	movapd xmm6, [rsp + nb213nf_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 + nb213nf_ixH1]	movapd xmm5, [rsp + nb213nf_iyH1]	movapd xmm6, [rsp + nb213nf_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 + nb213nf_ixH2]	movapd xmm4, [rsp + nb213nf_iyH2]	movapd xmm5, [rsp + nb213nf_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 + nb213nf_iyM]	movapd xmm4, [rsp + nb213nf_izM]	subpd  xmm3, xmm1	subpd  xmm4, xmm2	movapd xmm2, [rsp + nb213nf_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 	;# calculate krsq	movsd xmm0, [rsp + nb213nf_krf]	movsd xmm1, xmm0	movsd xmm2, xmm0	mulsd xmm0, xmm4  	mulsd xmm1, xmm5	mulsd xmm2, xmm6	movsd [rsp + nb213nf_krsqM], xmm0	movsd [rsp + nb213nf_krsqH2], xmm1	movsd [rsp + nb213nf_krsqH1], xmm2	;# 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 + nb213nf_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 + nb213nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulsd xmm1, xmm1	;# lu*lu 	mulsd xmm6, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb213nf_three]	subsd xmm1, xmm6	;# 3-rsq*lu*lu 	mulsd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulsd xmm1, [rsp + nb213nf_half] ;# rinv 	movapd [rsp + nb213nf_rinvH1], xmm1		;# rsqH2 - seed in xmm2 	cvtsd2ss xmm2, xmm5		rsqrtss xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd  xmm3, xmm2	mulsd   xmm2, xmm2	movapd  xmm1, [rsp + nb213nf_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 + nb213nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulsd xmm1, xmm1	;# lu*lu 	mulsd xmm5, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb213nf_three]	subsd xmm1, xmm5	;# 3-rsq*lu*lu 	mulsd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulsd xmm1, [rsp + nb213nf_half] ;# rinv 	movapd [rsp + nb213nf_rinvH2], xmm1		;# rsqM - seed in xmm2 	cvtsd2ss xmm2, xmm4	rsqrtss xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd  xmm3, xmm2	mulsd   xmm2, xmm2	movapd  xmm1, [rsp + nb213nf_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 + nb213nf_half] ;# iter1 ( new lu) 	movapd xmm3, xmm1	mulsd xmm1, xmm1	;# lu*lu 	mulsd xmm4, xmm1	;# rsq*lu*lu 	movapd xmm1, [rsp + nb213nf_three]	subsd xmm1, xmm4	;# 3-rsq*lu*lu 	mulsd xmm1, xmm3	;# lu*(	3-rsq*lu*lu) 	mulsd xmm1, [rsp + nb213nf_half] ;# rinv 	movapd [rsp + nb213nf_rinvM], xmm1	;# do O interactions directly. xmm7=rsq	cvtsd2ss xmm2, xmm7	movapd   xmm6, xmm7	rcpps    xmm2, xmm2	cvtss2sd xmm2, xmm2	movapd   xmm1, [rsp + nb213nf_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 + nb213nf_c6]	mulsd  xmm2, [rsp + nb213nf_c12]	movapd xmm3, xmm2	subsd  xmm3, xmm1	;# Vvdw=Vvdw12-Vvdw6 			addsd  xmm3, [rsp + nb213nf_Vvdwtot]	movsd [rsp + nb213nf_Vvdwtot], xmm3	;# H1 interactions 	movsd  xmm6, [rsp + nb213nf_rinvH1]	addsd   xmm6, [rsp + nb213nf_krsqH1] 	subsd   xmm6, [rsp + nb213nf_crf]	mulsd   xmm6, [rsp + nb213nf_qqH] ;# vcoul 	addsd   xmm6, [rsp + nb213nf_vctot]	movsd [rsp + nb213nf_vctot], xmm6		;# H2 interactions 	movsd  xmm6, [rsp + nb213nf_rinvH2]	addsd   xmm6, [rsp + nb213nf_krsqH2] 	subsd   xmm6, [rsp + nb213nf_crf]	mulsd   xmm6, [rsp + nb213nf_qqH] ;# vcoul 	addsd   xmm6, [rsp + nb213nf_vctot]	movsd [rsp + nb213nf_vctot], xmm6	;# M interactions 	movsd  xmm6, [rsp + nb213nf_rinvM]	addsd   xmm6, [rsp + nb213nf_krsqM] 	subsd   xmm6, [rsp + nb213nf_crf]	mulsd   xmm6, [rsp + nb213nf_qqM] ;# vcoul 	addsd   xmm6, [rsp + nb213nf_vctot]	movsd [rsp + nb213nf_vctot], xmm6	.nb213nf_updateouterdata:	;# get n from stack	mov esi, [rsp + nb213nf_n]        ;# get group index for i particle         mov   rdx, [rbp + nb213nf_gid]      	;# base of gid[]        mov   edx, [rdx + rsi*4]		;# ggid=gid[n]	;# accumulate total potential energy and update it 	movapd xmm7, [rsp + nb213nf_vctot]	;# accumulate 	movhlps xmm6, xmm7	addsd  xmm7, xmm6	;# low xmm7 has the sum now         	;# add earlier value from mem 	mov   rax, [rbp + nb213nf_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 + nb213nf_Vvdwtot]	;# accumulate 	movhlps xmm6, xmm7	addsd  xmm7, xmm6	;# low xmm7 has the sum now 	;# add earlier value from mem 	mov   rax, [rbp + nb213nf_Vvdw]	addsd xmm7, [rax + rdx*8] 	;# move back to mem 	movsd [rax + rdx*8], xmm7 	       ;# finish if last         mov ecx, [rsp + nb213nf_nn1]	;# esi already loaded with n	inc esi        sub ecx, esi        jz .nb213nf_outerend        ;# not last, iterate outer loop once more!          mov [rsp + nb213nf_n], esi        jmp .nb213nf_outer.nb213nf_outerend:        ;# check if more outer neighborlists remain        mov   ecx, [rsp + nb213nf_nri]	;# esi already loaded with n above        sub   ecx, esi        jz .nb213nf_end        ;# non-zero, do one more workunit        jmp   .nb213nf_threadloop.nb213nf_end:	mov eax, [rsp + nb213nf_nouter]	mov ebx, [rsp + nb213nf_ninner]	mov rcx, [rbp + nb213nf_outeriter]	mov rdx, [rbp + nb213nf_inneriter]	mov [rcx], eax	mov [rdx], ebx	add rsp, 600	emms        pop r15        pop r14        pop r13        pop r12	pop rbx	pop	rbp	ret

⌨️ 快捷键说明

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