2022-01-30 23:27:37 +00:00
|
|
|
|
// Code generated by command: go run fe_amd64_asm.go -out ../fe_amd64.s -stubs ../fe_amd64.go -pkg field. DO NOT EDIT.
|
|
|
|
|
|
2024-08-27 17:04:05 +00:00
|
|
|
|
//go:build amd64 && gc && !purego
|
2022-01-30 23:27:37 +00:00
|
|
|
|
// +build amd64,gc,!purego
|
|
|
|
|
|
|
|
|
|
#include "textflag.h"
|
|
|
|
|
|
|
|
|
|
// func feMul(out *Element, a *Element, b *Element)
|
|
|
|
|
TEXT ·feMul(SB), NOSPLIT, $0-24
|
|
|
|
|
MOVQ a+8(FP), CX
|
|
|
|
|
MOVQ b+16(FP), BX
|
|
|
|
|
|
|
|
|
|
// r0 = a0×b0
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
MULQ (BX)
|
|
|
|
|
MOVQ AX, DI
|
|
|
|
|
MOVQ DX, SI
|
|
|
|
|
|
|
|
|
|
// r0 += 19×a1×b4
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 32(BX)
|
|
|
|
|
ADDQ AX, DI
|
|
|
|
|
ADCQ DX, SI
|
|
|
|
|
|
|
|
|
|
// r0 += 19×a2×b3
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 24(BX)
|
|
|
|
|
ADDQ AX, DI
|
|
|
|
|
ADCQ DX, SI
|
|
|
|
|
|
|
|
|
|
// r0 += 19×a3×b2
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 16(BX)
|
|
|
|
|
ADDQ AX, DI
|
|
|
|
|
ADCQ DX, SI
|
|
|
|
|
|
|
|
|
|
// r0 += 19×a4×b1
|
|
|
|
|
MOVQ 32(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 8(BX)
|
|
|
|
|
ADDQ AX, DI
|
|
|
|
|
ADCQ DX, SI
|
|
|
|
|
|
|
|
|
|
// r1 = a0×b1
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
MULQ 8(BX)
|
|
|
|
|
MOVQ AX, R9
|
|
|
|
|
MOVQ DX, R8
|
|
|
|
|
|
|
|
|
|
// r1 += a1×b0
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
MULQ (BX)
|
|
|
|
|
ADDQ AX, R9
|
|
|
|
|
ADCQ DX, R8
|
|
|
|
|
|
|
|
|
|
// r1 += 19×a2×b4
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 32(BX)
|
|
|
|
|
ADDQ AX, R9
|
|
|
|
|
ADCQ DX, R8
|
|
|
|
|
|
|
|
|
|
// r1 += 19×a3×b3
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 24(BX)
|
|
|
|
|
ADDQ AX, R9
|
|
|
|
|
ADCQ DX, R8
|
|
|
|
|
|
|
|
|
|
// r1 += 19×a4×b2
|
|
|
|
|
MOVQ 32(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 16(BX)
|
|
|
|
|
ADDQ AX, R9
|
|
|
|
|
ADCQ DX, R8
|
|
|
|
|
|
|
|
|
|
// r2 = a0×b2
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
MULQ 16(BX)
|
|
|
|
|
MOVQ AX, R11
|
|
|
|
|
MOVQ DX, R10
|
|
|
|
|
|
|
|
|
|
// r2 += a1×b1
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
MULQ 8(BX)
|
|
|
|
|
ADDQ AX, R11
|
|
|
|
|
ADCQ DX, R10
|
|
|
|
|
|
|
|
|
|
// r2 += a2×b0
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
MULQ (BX)
|
|
|
|
|
ADDQ AX, R11
|
|
|
|
|
ADCQ DX, R10
|
|
|
|
|
|
|
|
|
|
// r2 += 19×a3×b4
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 32(BX)
|
|
|
|
|
ADDQ AX, R11
|
|
|
|
|
ADCQ DX, R10
|
|
|
|
|
|
|
|
|
|
// r2 += 19×a4×b3
|
|
|
|
|
MOVQ 32(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 24(BX)
|
|
|
|
|
ADDQ AX, R11
|
|
|
|
|
ADCQ DX, R10
|
|
|
|
|
|
|
|
|
|
// r3 = a0×b3
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
MULQ 24(BX)
|
|
|
|
|
MOVQ AX, R13
|
|
|
|
|
MOVQ DX, R12
|
|
|
|
|
|
|
|
|
|
// r3 += a1×b2
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
MULQ 16(BX)
|
|
|
|
|
ADDQ AX, R13
|
|
|
|
|
ADCQ DX, R12
|
|
|
|
|
|
|
|
|
|
// r3 += a2×b1
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
MULQ 8(BX)
|
|
|
|
|
ADDQ AX, R13
|
|
|
|
|
ADCQ DX, R12
|
|
|
|
|
|
|
|
|
|
// r3 += a3×b0
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
MULQ (BX)
|
|
|
|
|
ADDQ AX, R13
|
|
|
|
|
ADCQ DX, R12
|
|
|
|
|
|
|
|
|
|
// r3 += 19×a4×b4
|
|
|
|
|
MOVQ 32(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 32(BX)
|
|
|
|
|
ADDQ AX, R13
|
|
|
|
|
ADCQ DX, R12
|
|
|
|
|
|
|
|
|
|
// r4 = a0×b4
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
MULQ 32(BX)
|
|
|
|
|
MOVQ AX, R15
|
|
|
|
|
MOVQ DX, R14
|
|
|
|
|
|
|
|
|
|
// r4 += a1×b3
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
MULQ 24(BX)
|
|
|
|
|
ADDQ AX, R15
|
|
|
|
|
ADCQ DX, R14
|
|
|
|
|
|
|
|
|
|
// r4 += a2×b2
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
MULQ 16(BX)
|
|
|
|
|
ADDQ AX, R15
|
|
|
|
|
ADCQ DX, R14
|
|
|
|
|
|
|
|
|
|
// r4 += a3×b1
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
MULQ 8(BX)
|
|
|
|
|
ADDQ AX, R15
|
|
|
|
|
ADCQ DX, R14
|
|
|
|
|
|
|
|
|
|
// r4 += a4×b0
|
|
|
|
|
MOVQ 32(CX), AX
|
|
|
|
|
MULQ (BX)
|
|
|
|
|
ADDQ AX, R15
|
|
|
|
|
ADCQ DX, R14
|
|
|
|
|
|
|
|
|
|
// First reduction chain
|
|
|
|
|
MOVQ $0x0007ffffffffffff, AX
|
|
|
|
|
SHLQ $0x0d, DI, SI
|
|
|
|
|
SHLQ $0x0d, R9, R8
|
|
|
|
|
SHLQ $0x0d, R11, R10
|
|
|
|
|
SHLQ $0x0d, R13, R12
|
|
|
|
|
SHLQ $0x0d, R15, R14
|
|
|
|
|
ANDQ AX, DI
|
|
|
|
|
IMUL3Q $0x13, R14, R14
|
|
|
|
|
ADDQ R14, DI
|
|
|
|
|
ANDQ AX, R9
|
|
|
|
|
ADDQ SI, R9
|
|
|
|
|
ANDQ AX, R11
|
|
|
|
|
ADDQ R8, R11
|
|
|
|
|
ANDQ AX, R13
|
|
|
|
|
ADDQ R10, R13
|
|
|
|
|
ANDQ AX, R15
|
|
|
|
|
ADDQ R12, R15
|
|
|
|
|
|
|
|
|
|
// Second reduction chain (carryPropagate)
|
|
|
|
|
MOVQ DI, SI
|
|
|
|
|
SHRQ $0x33, SI
|
|
|
|
|
MOVQ R9, R8
|
|
|
|
|
SHRQ $0x33, R8
|
|
|
|
|
MOVQ R11, R10
|
|
|
|
|
SHRQ $0x33, R10
|
|
|
|
|
MOVQ R13, R12
|
|
|
|
|
SHRQ $0x33, R12
|
|
|
|
|
MOVQ R15, R14
|
|
|
|
|
SHRQ $0x33, R14
|
|
|
|
|
ANDQ AX, DI
|
|
|
|
|
IMUL3Q $0x13, R14, R14
|
|
|
|
|
ADDQ R14, DI
|
|
|
|
|
ANDQ AX, R9
|
|
|
|
|
ADDQ SI, R9
|
|
|
|
|
ANDQ AX, R11
|
|
|
|
|
ADDQ R8, R11
|
|
|
|
|
ANDQ AX, R13
|
|
|
|
|
ADDQ R10, R13
|
|
|
|
|
ANDQ AX, R15
|
|
|
|
|
ADDQ R12, R15
|
|
|
|
|
|
|
|
|
|
// Store output
|
|
|
|
|
MOVQ out+0(FP), AX
|
|
|
|
|
MOVQ DI, (AX)
|
|
|
|
|
MOVQ R9, 8(AX)
|
|
|
|
|
MOVQ R11, 16(AX)
|
|
|
|
|
MOVQ R13, 24(AX)
|
|
|
|
|
MOVQ R15, 32(AX)
|
|
|
|
|
RET
|
|
|
|
|
|
|
|
|
|
// func feSquare(out *Element, a *Element)
|
|
|
|
|
TEXT ·feSquare(SB), NOSPLIT, $0-16
|
|
|
|
|
MOVQ a+8(FP), CX
|
|
|
|
|
|
|
|
|
|
// r0 = l0×l0
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
MULQ (CX)
|
|
|
|
|
MOVQ AX, SI
|
|
|
|
|
MOVQ DX, BX
|
|
|
|
|
|
|
|
|
|
// r0 += 38×l1×l4
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
IMUL3Q $0x26, AX, AX
|
|
|
|
|
MULQ 32(CX)
|
|
|
|
|
ADDQ AX, SI
|
|
|
|
|
ADCQ DX, BX
|
|
|
|
|
|
|
|
|
|
// r0 += 38×l2×l3
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
IMUL3Q $0x26, AX, AX
|
|
|
|
|
MULQ 24(CX)
|
|
|
|
|
ADDQ AX, SI
|
|
|
|
|
ADCQ DX, BX
|
|
|
|
|
|
|
|
|
|
// r1 = 2×l0×l1
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
SHLQ $0x01, AX
|
|
|
|
|
MULQ 8(CX)
|
|
|
|
|
MOVQ AX, R8
|
|
|
|
|
MOVQ DX, DI
|
|
|
|
|
|
|
|
|
|
// r1 += 38×l2×l4
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
IMUL3Q $0x26, AX, AX
|
|
|
|
|
MULQ 32(CX)
|
|
|
|
|
ADDQ AX, R8
|
|
|
|
|
ADCQ DX, DI
|
|
|
|
|
|
|
|
|
|
// r1 += 19×l3×l3
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 24(CX)
|
|
|
|
|
ADDQ AX, R8
|
|
|
|
|
ADCQ DX, DI
|
|
|
|
|
|
|
|
|
|
// r2 = 2×l0×l2
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
SHLQ $0x01, AX
|
|
|
|
|
MULQ 16(CX)
|
|
|
|
|
MOVQ AX, R10
|
|
|
|
|
MOVQ DX, R9
|
|
|
|
|
|
|
|
|
|
// r2 += l1×l1
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
MULQ 8(CX)
|
|
|
|
|
ADDQ AX, R10
|
|
|
|
|
ADCQ DX, R9
|
|
|
|
|
|
|
|
|
|
// r2 += 38×l3×l4
|
|
|
|
|
MOVQ 24(CX), AX
|
|
|
|
|
IMUL3Q $0x26, AX, AX
|
|
|
|
|
MULQ 32(CX)
|
|
|
|
|
ADDQ AX, R10
|
|
|
|
|
ADCQ DX, R9
|
|
|
|
|
|
|
|
|
|
// r3 = 2×l0×l3
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
SHLQ $0x01, AX
|
|
|
|
|
MULQ 24(CX)
|
|
|
|
|
MOVQ AX, R12
|
|
|
|
|
MOVQ DX, R11
|
|
|
|
|
|
|
|
|
|
// r3 += 2×l1×l2
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
IMUL3Q $0x02, AX, AX
|
|
|
|
|
MULQ 16(CX)
|
|
|
|
|
ADDQ AX, R12
|
|
|
|
|
ADCQ DX, R11
|
|
|
|
|
|
|
|
|
|
// r3 += 19×l4×l4
|
|
|
|
|
MOVQ 32(CX), AX
|
|
|
|
|
IMUL3Q $0x13, AX, AX
|
|
|
|
|
MULQ 32(CX)
|
|
|
|
|
ADDQ AX, R12
|
|
|
|
|
ADCQ DX, R11
|
|
|
|
|
|
|
|
|
|
// r4 = 2×l0×l4
|
|
|
|
|
MOVQ (CX), AX
|
|
|
|
|
SHLQ $0x01, AX
|
|
|
|
|
MULQ 32(CX)
|
|
|
|
|
MOVQ AX, R14
|
|
|
|
|
MOVQ DX, R13
|
|
|
|
|
|
|
|
|
|
// r4 += 2×l1×l3
|
|
|
|
|
MOVQ 8(CX), AX
|
|
|
|
|
IMUL3Q $0x02, AX, AX
|
|
|
|
|
MULQ 24(CX)
|
|
|
|
|
ADDQ AX, R14
|
|
|
|
|
ADCQ DX, R13
|
|
|
|
|
|
|
|
|
|
// r4 += l2×l2
|
|
|
|
|
MOVQ 16(CX), AX
|
|
|
|
|
MULQ 16(CX)
|
|
|
|
|
ADDQ AX, R14
|
|
|
|
|
ADCQ DX, R13
|
|
|
|
|
|
|
|
|
|
// First reduction chain
|
|
|
|
|
MOVQ $0x0007ffffffffffff, AX
|
|
|
|
|
SHLQ $0x0d, SI, BX
|
|
|
|
|
SHLQ $0x0d, R8, DI
|
|
|
|
|
SHLQ $0x0d, R10, R9
|
|
|
|
|
SHLQ $0x0d, R12, R11
|
|
|
|
|
SHLQ $0x0d, R14, R13
|
|
|
|
|
ANDQ AX, SI
|
|
|
|
|
IMUL3Q $0x13, R13, R13
|
|
|
|
|
ADDQ R13, SI
|
|
|
|
|
ANDQ AX, R8
|
|
|
|
|
ADDQ BX, R8
|
|
|
|
|
ANDQ AX, R10
|
|
|
|
|
ADDQ DI, R10
|
|
|
|
|
ANDQ AX, R12
|
|
|
|
|
ADDQ R9, R12
|
|
|
|
|
ANDQ AX, R14
|
|
|
|
|
ADDQ R11, R14
|
|
|
|
|
|
|
|
|
|
// Second reduction chain (carryPropagate)
|
|
|
|
|
MOVQ SI, BX
|
|
|
|
|
SHRQ $0x33, BX
|
|
|
|
|
MOVQ R8, DI
|
|
|
|
|
SHRQ $0x33, DI
|
|
|
|
|
MOVQ R10, R9
|
|
|
|
|
SHRQ $0x33, R9
|
|
|
|
|
MOVQ R12, R11
|
|
|
|
|
SHRQ $0x33, R11
|
|
|
|
|
MOVQ R14, R13
|
|
|
|
|
SHRQ $0x33, R13
|
|
|
|
|
ANDQ AX, SI
|
|
|
|
|
IMUL3Q $0x13, R13, R13
|
|
|
|
|
ADDQ R13, SI
|
|
|
|
|
ANDQ AX, R8
|
|
|
|
|
ADDQ BX, R8
|
|
|
|
|
ANDQ AX, R10
|
|
|
|
|
ADDQ DI, R10
|
|
|
|
|
ANDQ AX, R12
|
|
|
|
|
ADDQ R9, R12
|
|
|
|
|
ANDQ AX, R14
|
|
|
|
|
ADDQ R11, R14
|
|
|
|
|
|
|
|
|
|
// Store output
|
|
|
|
|
MOVQ out+0(FP), AX
|
|
|
|
|
MOVQ SI, (AX)
|
|
|
|
|
MOVQ R8, 8(AX)
|
|
|
|
|
MOVQ R10, 16(AX)
|
|
|
|
|
MOVQ R12, 24(AX)
|
|
|
|
|
MOVQ R14, 32(AX)
|
|
|
|
|
RET
|