common/math: copy result in Exp (#29233)

common/math: does not change base parameter
pull/29238/head
Aaron Chen 9 months ago committed by GitHub
parent 99bbbc0277
commit 4bd55a064c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 7
      common/math/big.go

@ -224,7 +224,7 @@ func ReadBits(bigint *big.Int, buf []byte) {
} }
} }
// U256 encodes as a 256 bit two's complement number. This operation is destructive. // U256 encodes x as a 256 bit two's complement number. This operation is destructive.
func U256(x *big.Int) *big.Int { func U256(x *big.Int) *big.Int {
return x.And(x, tt256m1) return x.And(x, tt256m1)
} }
@ -255,14 +255,15 @@ func S256(x *big.Int) *big.Int {
// //
// Courtesy @karalabe and @chfast // Courtesy @karalabe and @chfast
func Exp(base, exponent *big.Int) *big.Int { func Exp(base, exponent *big.Int) *big.Int {
copyBase := new(big.Int).Set(base)
result := big.NewInt(1) result := big.NewInt(1)
for _, word := range exponent.Bits() { for _, word := range exponent.Bits() {
for i := 0; i < wordBits; i++ { for i := 0; i < wordBits; i++ {
if word&1 == 1 { if word&1 == 1 {
U256(result.Mul(result, base)) U256(result.Mul(result, copyBase))
} }
U256(base.Mul(base, base)) U256(copyBase.Mul(copyBase, copyBase))
word >>= 1 word >>= 1
} }
} }

Loading…
Cancel
Save