Files
p256k1/field_amd64.go
mleku 14dc85cdc3 Add BMI2/AVX2 field assembly and SIMD comparison benchmarks
- Port field operations assembler from libsecp256k1 (field_amd64.s,
    field_amd64_bmi2.s) with MULX/ADCX/ADOX instructions
  - Add AVX2 scalar and affine point operations in avx/ package
  - Implement CPU feature detection (cpufeatures.go) for AVX2/BMI2
  - Add libsecp256k1.so via purego for native C library comparison
  - Create comprehensive SIMD benchmark suite comparing btcec, P256K1
    pure Go, P256K1 ASM, and libsecp256k1
  - Add BENCHMARK_SIMD.md documenting performance across implementations
  - Remove BtcecSigner, consolidate on P256K1Signer as primary impl
  - Add field operation tests and benchmarks (field_asm_test.go,
    field_bench_test.go)
  - Update GLV endomorphism with wNAF scalar multiplication
  - Add scalar assembly (scalar_amd64.s) for optimized operations
  - Clean up dependencies and update benchmark reports
2025-11-29 08:11:13 +00:00

42 lines
1.2 KiB
Go

//go:build amd64
package p256k1
// fieldMulAsm multiplies two field elements using x86-64 assembly.
// This is a direct port of bitcoin-core secp256k1_fe_mul_inner.
// r, a, b are 5x52-bit limb representations.
//
//go:noescape
func fieldMulAsm(r, a, b *FieldElement)
// fieldSqrAsm squares a field element using x86-64 assembly.
// This is a direct port of bitcoin-core secp256k1_fe_sqr_inner.
// Squaring is optimized compared to multiplication.
//
//go:noescape
func fieldSqrAsm(r, a *FieldElement)
// fieldMulAsmBMI2 multiplies two field elements using BMI2+ADX instructions.
// Uses MULX for flag-free multiplication enabling parallel carry chains.
// r, a, b are 5x52-bit limb representations.
//
//go:noescape
func fieldMulAsmBMI2(r, a, b *FieldElement)
// fieldSqrAsmBMI2 squares a field element using BMI2+ADX instructions.
// Uses MULX for flag-free multiplication.
//
//go:noescape
func fieldSqrAsmBMI2(r, a *FieldElement)
// hasFieldAsm returns true if field assembly is available.
// On amd64, this is always true.
func hasFieldAsm() bool {
return true
}
// hasFieldAsmBMI2 returns true if BMI2+ADX optimized field assembly is available.
func hasFieldAsmBMI2() bool {
return HasBMI2()
}