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.

60 lines
1.6 KiB

  1. // Copyright 2020 ConsenSys Software Inc.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. // Code generated by consensys/gnark-crypto DO NOT EDIT
  15. package ff
  16. import (
  17. "math/bits"
  18. )
  19. // madd0 hi = a*b + c (discards lo bits)
  20. func madd0(a, b, c uint64) (hi uint64) {
  21. var carry, lo uint64
  22. hi, lo = bits.Mul64(a, b)
  23. _, carry = bits.Add64(lo, c, 0)
  24. hi, _ = bits.Add64(hi, 0, carry)
  25. return
  26. }
  27. // madd1 hi, lo = a*b + c
  28. func madd1(a, b, c uint64) (hi uint64, lo uint64) {
  29. var carry uint64
  30. hi, lo = bits.Mul64(a, b)
  31. lo, carry = bits.Add64(lo, c, 0)
  32. hi, _ = bits.Add64(hi, 0, carry)
  33. return
  34. }
  35. // madd2 hi, lo = a*b + c + d
  36. func madd2(a, b, c, d uint64) (hi uint64, lo uint64) {
  37. var carry uint64
  38. hi, lo = bits.Mul64(a, b)
  39. c, carry = bits.Add64(c, d, 0)
  40. hi, _ = bits.Add64(hi, 0, carry)
  41. lo, carry = bits.Add64(lo, c, 0)
  42. hi, _ = bits.Add64(hi, 0, carry)
  43. return
  44. }
  45. func madd3(a, b, c, d, e uint64) (hi uint64, lo uint64) {
  46. var carry uint64
  47. hi, lo = bits.Mul64(a, b)
  48. c, carry = bits.Add64(c, d, 0)
  49. hi, _ = bits.Add64(hi, 0, carry)
  50. lo, carry = bits.Add64(lo, c, 0)
  51. hi, _ = bits.Add64(hi, e, carry)
  52. return
  53. }