You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							191 lines
						
					
					
						
							2.8 KiB
						
					
					
				
			
		
		
	
	
							191 lines
						
					
					
						
							2.8 KiB
						
					
					
				| // Copyright 2012 The Go Authors. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| // This code was translated into a form compatible with 6a from the public
 | |
| // domain sources in SUPERCOP: http://bench.cr.yp.to/supercop.html
 | |
| 
 | |
| // +build amd64,!gccgo,!appengine
 | |
| 
 | |
| // func mul(dest, a, b *[5]uint64)
 | |
| TEXT ·mul(SB),0,$128-24
 | |
| 	MOVQ dest+0(FP), DI
 | |
| 	MOVQ a+8(FP), SI
 | |
| 	MOVQ b+16(FP), DX
 | |
| 
 | |
| 	MOVQ SP,R11
 | |
| 	MOVQ $31,CX
 | |
| 	NOTQ CX
 | |
| 	ANDQ CX,SP
 | |
| 	ADDQ $32,SP
 | |
| 
 | |
| 	MOVQ R11,0(SP)
 | |
| 	MOVQ R12,8(SP)
 | |
| 	MOVQ R13,16(SP)
 | |
| 	MOVQ R14,24(SP)
 | |
| 	MOVQ R15,32(SP)
 | |
| 	MOVQ BX,40(SP)
 | |
| 	MOVQ BP,48(SP)
 | |
| 	MOVQ DI,56(SP)
 | |
| 	MOVQ DX,CX
 | |
| 	MOVQ 24(SI),DX
 | |
| 	IMUL3Q $19,DX,AX
 | |
| 	MOVQ AX,64(SP)
 | |
| 	MULQ 16(CX)
 | |
| 	MOVQ AX,R8
 | |
| 	MOVQ DX,R9
 | |
| 	MOVQ 32(SI),DX
 | |
| 	IMUL3Q $19,DX,AX
 | |
| 	MOVQ AX,72(SP)
 | |
| 	MULQ 8(CX)
 | |
| 	ADDQ AX,R8
 | |
| 	ADCQ DX,R9
 | |
| 	MOVQ 0(SI),AX
 | |
| 	MULQ 0(CX)
 | |
| 	ADDQ AX,R8
 | |
| 	ADCQ DX,R9
 | |
| 	MOVQ 0(SI),AX
 | |
| 	MULQ 8(CX)
 | |
| 	MOVQ AX,R10
 | |
| 	MOVQ DX,R11
 | |
| 	MOVQ 0(SI),AX
 | |
| 	MULQ 16(CX)
 | |
| 	MOVQ AX,R12
 | |
| 	MOVQ DX,R13
 | |
| 	MOVQ 0(SI),AX
 | |
| 	MULQ 24(CX)
 | |
| 	MOVQ AX,R14
 | |
| 	MOVQ DX,R15
 | |
| 	MOVQ 0(SI),AX
 | |
| 	MULQ 32(CX)
 | |
| 	MOVQ AX,BX
 | |
| 	MOVQ DX,BP
 | |
| 	MOVQ 8(SI),AX
 | |
| 	MULQ 0(CX)
 | |
| 	ADDQ AX,R10
 | |
| 	ADCQ DX,R11
 | |
| 	MOVQ 8(SI),AX
 | |
| 	MULQ 8(CX)
 | |
| 	ADDQ AX,R12
 | |
| 	ADCQ DX,R13
 | |
| 	MOVQ 8(SI),AX
 | |
| 	MULQ 16(CX)
 | |
| 	ADDQ AX,R14
 | |
| 	ADCQ DX,R15
 | |
| 	MOVQ 8(SI),AX
 | |
| 	MULQ 24(CX)
 | |
| 	ADDQ AX,BX
 | |
| 	ADCQ DX,BP
 | |
| 	MOVQ 8(SI),DX
 | |
| 	IMUL3Q $19,DX,AX
 | |
| 	MULQ 32(CX)
 | |
| 	ADDQ AX,R8
 | |
| 	ADCQ DX,R9
 | |
| 	MOVQ 16(SI),AX
 | |
| 	MULQ 0(CX)
 | |
| 	ADDQ AX,R12
 | |
| 	ADCQ DX,R13
 | |
| 	MOVQ 16(SI),AX
 | |
| 	MULQ 8(CX)
 | |
| 	ADDQ AX,R14
 | |
| 	ADCQ DX,R15
 | |
| 	MOVQ 16(SI),AX
 | |
| 	MULQ 16(CX)
 | |
| 	ADDQ AX,BX
 | |
| 	ADCQ DX,BP
 | |
| 	MOVQ 16(SI),DX
 | |
| 	IMUL3Q $19,DX,AX
 | |
| 	MULQ 24(CX)
 | |
| 	ADDQ AX,R8
 | |
| 	ADCQ DX,R9
 | |
| 	MOVQ 16(SI),DX
 | |
| 	IMUL3Q $19,DX,AX
 | |
| 	MULQ 32(CX)
 | |
| 	ADDQ AX,R10
 | |
| 	ADCQ DX,R11
 | |
| 	MOVQ 24(SI),AX
 | |
| 	MULQ 0(CX)
 | |
| 	ADDQ AX,R14
 | |
| 	ADCQ DX,R15
 | |
| 	MOVQ 24(SI),AX
 | |
| 	MULQ 8(CX)
 | |
| 	ADDQ AX,BX
 | |
| 	ADCQ DX,BP
 | |
| 	MOVQ 64(SP),AX
 | |
| 	MULQ 24(CX)
 | |
| 	ADDQ AX,R10
 | |
| 	ADCQ DX,R11
 | |
| 	MOVQ 64(SP),AX
 | |
| 	MULQ 32(CX)
 | |
| 	ADDQ AX,R12
 | |
| 	ADCQ DX,R13
 | |
| 	MOVQ 32(SI),AX
 | |
| 	MULQ 0(CX)
 | |
| 	ADDQ AX,BX
 | |
| 	ADCQ DX,BP
 | |
| 	MOVQ 72(SP),AX
 | |
| 	MULQ 16(CX)
 | |
| 	ADDQ AX,R10
 | |
| 	ADCQ DX,R11
 | |
| 	MOVQ 72(SP),AX
 | |
| 	MULQ 24(CX)
 | |
| 	ADDQ AX,R12
 | |
| 	ADCQ DX,R13
 | |
| 	MOVQ 72(SP),AX
 | |
| 	MULQ 32(CX)
 | |
| 	ADDQ AX,R14
 | |
| 	ADCQ DX,R15
 | |
| 	MOVQ ·REDMASK51(SB),SI
 | |
| 	SHLQ $13,R9:R8
 | |
| 	ANDQ SI,R8
 | |
| 	SHLQ $13,R11:R10
 | |
| 	ANDQ SI,R10
 | |
| 	ADDQ R9,R10
 | |
| 	SHLQ $13,R13:R12
 | |
| 	ANDQ SI,R12
 | |
| 	ADDQ R11,R12
 | |
| 	SHLQ $13,R15:R14
 | |
| 	ANDQ SI,R14
 | |
| 	ADDQ R13,R14
 | |
| 	SHLQ $13,BP:BX
 | |
| 	ANDQ SI,BX
 | |
| 	ADDQ R15,BX
 | |
| 	IMUL3Q $19,BP,DX
 | |
| 	ADDQ DX,R8
 | |
| 	MOVQ R8,DX
 | |
| 	SHRQ $51,DX
 | |
| 	ADDQ R10,DX
 | |
| 	MOVQ DX,CX
 | |
| 	SHRQ $51,DX
 | |
| 	ANDQ SI,R8
 | |
| 	ADDQ R12,DX
 | |
| 	MOVQ DX,R9
 | |
| 	SHRQ $51,DX
 | |
| 	ANDQ SI,CX
 | |
| 	ADDQ R14,DX
 | |
| 	MOVQ DX,AX
 | |
| 	SHRQ $51,DX
 | |
| 	ANDQ SI,R9
 | |
| 	ADDQ BX,DX
 | |
| 	MOVQ DX,R10
 | |
| 	SHRQ $51,DX
 | |
| 	ANDQ SI,AX
 | |
| 	IMUL3Q $19,DX,DX
 | |
| 	ADDQ DX,R8
 | |
| 	ANDQ SI,R10
 | |
| 	MOVQ R8,0(DI)
 | |
| 	MOVQ CX,8(DI)
 | |
| 	MOVQ R9,16(DI)
 | |
| 	MOVQ AX,24(DI)
 | |
| 	MOVQ R10,32(DI)
 | |
| 	MOVQ 0(SP),R11
 | |
| 	MOVQ 8(SP),R12
 | |
| 	MOVQ 16(SP),R13
 | |
| 	MOVQ 24(SP),R14
 | |
| 	MOVQ 32(SP),R15
 | |
| 	MOVQ 40(SP),BX
 | |
| 	MOVQ 48(SP),BP
 | |
| 	MOVQ R11,SP
 | |
| 	MOVQ DI,AX
 | |
| 	MOVQ SI,DX
 | |
| 	RET
 | |
| 
 |