package fiat
import "math/bits"
type p256Uint1 uint64
type p256Int1 int64
type p256MontgomeryDomainFieldElement [4 ]uint64
type p256NonMontgomeryDomainFieldElement [4 ]uint64
func p256CmovznzU64 (out1 *uint64 , arg1 p256Uint1 , arg2 uint64 , arg3 uint64 ) {
x1 := (uint64 (arg1 ) * 0xffffffffffffffff )
x2 := ((x1 & arg3 ) | ((^x1 ) & arg2 ))
*out1 = x2
}
func p256Mul (out1 *p256MontgomeryDomainFieldElement , arg1 *p256MontgomeryDomainFieldElement , arg2 *p256MontgomeryDomainFieldElement ) {
x1 := arg1 [1 ]
x2 := arg1 [2 ]
x3 := arg1 [3 ]
x4 := arg1 [0 ]
var x5 uint64
var x6 uint64
x6 , x5 = bits .Mul64 (x4 , arg2 [3 ])
var x7 uint64
var x8 uint64
x8 , x7 = bits .Mul64 (x4 , arg2 [2 ])
var x9 uint64
var x10 uint64
x10 , x9 = bits .Mul64 (x4 , arg2 [1 ])
var x11 uint64
var x12 uint64
x12 , x11 = bits .Mul64 (x4 , arg2 [0 ])
var x13 uint64
var x14 uint64
x13 , x14 = bits .Add64 (x12 , x9 , uint64 (0x0 ))
var x15 uint64
var x16 uint64
x15 , x16 = bits .Add64 (x10 , x7 , uint64 (p256Uint1 (x14 )))
var x17 uint64
var x18 uint64
x17 , x18 = bits .Add64 (x8 , x5 , uint64 (p256Uint1 (x16 )))
x19 := (uint64 (p256Uint1 (x18 )) + x6 )
var x20 uint64
var x21 uint64
x21 , x20 = bits .Mul64 (x11 , 0xffffffff00000001 )
var x22 uint64
var x23 uint64
x23 , x22 = bits .Mul64 (x11 , 0xffffffff )
var x24 uint64
var x25 uint64
x25 , x24 = bits .Mul64 (x11 , 0xffffffffffffffff )
var x26 uint64
var x27 uint64
x26 , x27 = bits .Add64 (x25 , x22 , uint64 (0x0 ))
x28 := (uint64 (p256Uint1 (x27 )) + x23 )
var x30 uint64
_, x30 = bits .Add64 (x11 , x24 , uint64 (0x0 ))
var x31 uint64
var x32 uint64
x31 , x32 = bits .Add64 (x13 , x26 , uint64 (p256Uint1 (x30 )))
var x33 uint64
var x34 uint64
x33 , x34 = bits .Add64 (x15 , x28 , uint64 (p256Uint1 (x32 )))
var x35 uint64
var x36 uint64
x35 , x36 = bits .Add64 (x17 , x20 , uint64 (p256Uint1 (x34 )))
var x37 uint64
var x38 uint64
x37 , x38 = bits .Add64 (x19 , x21 , uint64 (p256Uint1 (x36 )))
var x39 uint64
var x40 uint64
x40 , x39 = bits .Mul64 (x1 , arg2 [3 ])
var x41 uint64
var x42 uint64
x42 , x41 = bits .Mul64 (x1 , arg2 [2 ])
var x43 uint64
var x44 uint64
x44 , x43 = bits .Mul64 (x1 , arg2 [1 ])
var x45 uint64
var x46 uint64
x46 , x45 = bits .Mul64 (x1 , arg2 [0 ])
var x47 uint64
var x48 uint64
x47 , x48 = bits .Add64 (x46 , x43 , uint64 (0x0 ))
var x49 uint64
var x50 uint64
x49 , x50 = bits .Add64 (x44 , x41 , uint64 (p256Uint1 (x48 )))
var x51 uint64
var x52 uint64
x51 , x52 = bits .Add64 (x42 , x39 , uint64 (p256Uint1 (x50 )))
x53 := (uint64 (p256Uint1 (x52 )) + x40 )
var x54 uint64
var x55 uint64
x54 , x55 = bits .Add64 (x31 , x45 , uint64 (0x0 ))
var x56 uint64
var x57 uint64
x56 , x57 = bits .Add64 (x33 , x47 , uint64 (p256Uint1 (x55 )))
var x58 uint64
var x59 uint64
x58 , x59 = bits .Add64 (x35 , x49 , uint64 (p256Uint1 (x57 )))
var x60 uint64
var x61 uint64
x60 , x61 = bits .Add64 (x37 , x51 , uint64 (p256Uint1 (x59 )))
var x62 uint64
var x63 uint64
x62 , x63 = bits .Add64 (uint64 (p256Uint1 (x38 )), x53 , uint64 (p256Uint1 (x61 )))
var x64 uint64
var x65 uint64
x65 , x64 = bits .Mul64 (x54 , 0xffffffff00000001 )
var x66 uint64
var x67 uint64
x67 , x66 = bits .Mul64 (x54 , 0xffffffff )
var x68 uint64
var x69 uint64
x69 , x68 = bits .Mul64 (x54 , 0xffffffffffffffff )
var x70 uint64
var x71 uint64
x70 , x71 = bits .Add64 (x69 , x66 , uint64 (0x0 ))
x72 := (uint64 (p256Uint1 (x71 )) + x67 )
var x74 uint64
_, x74 = bits .Add64 (x54 , x68 , uint64 (0x0 ))
var x75 uint64
var x76 uint64
x75 , x76 = bits .Add64 (x56 , x70 , uint64 (p256Uint1 (x74 )))
var x77 uint64
var x78 uint64
x77 , x78 = bits .Add64 (x58 , x72 , uint64 (p256Uint1 (x76 )))
var x79 uint64
var x80 uint64
x79 , x80 = bits .Add64 (x60 , x64 , uint64 (p256Uint1 (x78 )))
var x81 uint64
var x82 uint64
x81 , x82 = bits .Add64 (x62 , x65 , uint64 (p256Uint1 (x80 )))
x83 := (uint64 (p256Uint1 (x82 )) + uint64 (p256Uint1 (x63 )))
var x84 uint64
var x85 uint64
x85 , x84 = bits .Mul64 (x2 , arg2 [3 ])
var x86 uint64
var x87 uint64
x87 , x86 = bits .Mul64 (x2 , arg2 [2 ])
var x88 uint64
var x89 uint64
x89 , x88 = bits .Mul64 (x2 , arg2 [1 ])
var x90 uint64
var x91 uint64
x91 , x90 = bits .Mul64 (x2 , arg2 [0 ])
var x92 uint64
var x93 uint64
x92 , x93 = bits .Add64 (x91 , x88 , uint64 (0x0 ))
var x94 uint64
var x95 uint64
x94 , x95 = bits .Add64 (x89 , x86 , uint64 (p256Uint1 (x93 )))
var x96 uint64
var x97 uint64
x96 , x97 = bits .Add64 (x87 , x84 , uint64 (p256Uint1 (x95 )))
x98 := (uint64 (p256Uint1 (x97 )) + x85 )
var x99 uint64
var x100 uint64
x99 , x100 = bits .Add64 (x75 , x90 , uint64 (0x0 ))
var x101 uint64
var x102 uint64
x101 , x102 = bits .Add64 (x77 , x92 , uint64 (p256Uint1 (x100 )))
var x103 uint64
var x104 uint64
x103 , x104 = bits .Add64 (x79 , x94 , uint64 (p256Uint1 (x102 )))
var x105 uint64
var x106 uint64
x105 , x106 = bits .Add64 (x81 , x96 , uint64 (p256Uint1 (x104 )))
var x107 uint64
var x108 uint64
x107 , x108 = bits .Add64 (x83 , x98 , uint64 (p256Uint1 (x106 )))
var x109 uint64
var x110 uint64
x110 , x109 = bits .Mul64 (x99 , 0xffffffff00000001 )
var x111 uint64
var x112 uint64
x112 , x111 = bits .Mul64 (x99 , 0xffffffff )
var x113 uint64
var x114 uint64
x114 , x113 = bits .Mul64 (x99 , 0xffffffffffffffff )
var x115 uint64
var x116 uint64
x115 , x116 = bits .Add64 (x114 , x111 , uint64 (0x0 ))
x117 := (uint64 (p256Uint1 (x116 )) + x112 )
var x119 uint64
_, x119 = bits .Add64 (x99 , x113 , uint64 (0x0 ))
var x120 uint64
var x121 uint64
x120 , x121 = bits .Add64 (x101 , x115 , uint64 (p256Uint1 (x119 )))
var x122 uint64
var x123 uint64
x122 , x123 = bits .Add64 (x103 , x117 , uint64 (p256Uint1 (x121 )))
var x124 uint64
var x125 uint64
x124 , x125 = bits .Add64 (x105 , x109 , uint64 (p256Uint1 (x123 )))
var x126 uint64
var x127 uint64
x126 , x127 = bits .Add64 (x107 , x110 , uint64 (p256Uint1 (x125 )))
x128 := (uint64 (p256Uint1 (x127 )) + uint64 (p256Uint1 (x108 )))
var x129 uint64
var x130 uint64
x130 , x129 = bits .Mul64 (x3 , arg2 [3 ])
var x131 uint64
var x132 uint64
x132 , x131 = bits .Mul64 (x3 , arg2 [2 ])
var x133 uint64
var x134 uint64
x134 , x133 = bits .Mul64 (x3 , arg2 [1 ])
var x135 uint64
var x136 uint64
x136 , x135 = bits .Mul64 (x3 , arg2 [0 ])
var x137 uint64
var x138 uint64
x137 , x138 = bits .Add64 (x136 , x133 , uint64 (0x0 ))
var x139 uint64
var x140 uint64
x139 , x140 = bits .Add64 (x134 , x131 , uint64 (p256Uint1 (x138 )))
var x141 uint64
var x142 uint64
x141 , x142 = bits .Add64 (x132 , x129 , uint64 (p256Uint1 (x140 )))
x143 := (uint64 (p256Uint1 (x142 )) + x130 )
var x144 uint64
var x145 uint64
x144 , x145 = bits .Add64 (x120 , x135 , uint64 (0x0 ))
var x146 uint64
var x147 uint64
x146 , x147 = bits .Add64 (x122 , x137 , uint64 (p256Uint1 (x145 )))
var x148 uint64
var x149 uint64
x148 , x149 = bits .Add64 (x124 , x139 , uint64 (p256Uint1 (x147 )))
var x150 uint64
var x151 uint64
x150 , x151 = bits .Add64 (x126 , x141 , uint64 (p256Uint1 (x149 )))
var x152 uint64
var x153 uint64
x152 , x153 = bits .Add64 (x128 , x143 , uint64 (p256Uint1 (x151 )))
var x154 uint64
var x155 uint64
x155 , x154 = bits .Mul64 (x144 , 0xffffffff00000001 )
var x156 uint64
var x157 uint64
x157 , x156 = bits .Mul64 (x144 , 0xffffffff )
var x158 uint64
var x159 uint64
x159 , x158 = bits .Mul64 (x144 , 0xffffffffffffffff )
var x160 uint64
var x161 uint64
x160 , x161 = bits .Add64 (x159 , x156 , uint64 (0x0 ))
x162 := (uint64 (p256Uint1 (x161 )) + x157 )
var x164 uint64
_, x164 = bits .Add64 (x144 , x158 , uint64 (0x0 ))
var x165 uint64
var x166 uint64
x165 , x166 = bits .Add64 (x146 , x160 , uint64 (p256Uint1 (x164 )))
var x167 uint64
var x168 uint64
x167 , x168 = bits .Add64 (x148 , x162 , uint64 (p256Uint1 (x166 )))
var x169 uint64
var x170 uint64
x169 , x170 = bits .Add64 (x150 , x154 , uint64 (p256Uint1 (x168 )))
var x171 uint64
var x172 uint64
x171 , x172 = bits .Add64 (x152 , x155 , uint64 (p256Uint1 (x170 )))
x173 := (uint64 (p256Uint1 (x172 )) + uint64 (p256Uint1 (x153 )))
var x174 uint64
var x175 uint64
x174 , x175 = bits .Sub64 (x165 , 0xffffffffffffffff , uint64 (0x0 ))
var x176 uint64
var x177 uint64
x176 , x177 = bits .Sub64 (x167 , 0xffffffff , uint64 (p256Uint1 (x175 )))
var x178 uint64
var x179 uint64
x178 , x179 = bits .Sub64 (x169 , uint64 (0x0 ), uint64 (p256Uint1 (x177 )))
var x180 uint64
var x181 uint64
x180 , x181 = bits .Sub64 (x171 , 0xffffffff00000001 , uint64 (p256Uint1 (x179 )))
var x183 uint64
_, x183 = bits .Sub64 (x173 , uint64 (0x0 ), uint64 (p256Uint1 (x181 )))
var x184 uint64
p256CmovznzU64 (&x184 , p256Uint1 (x183 ), x174 , x165 )
var x185 uint64
p256CmovznzU64 (&x185 , p256Uint1 (x183 ), x176 , x167 )
var x186 uint64
p256CmovznzU64 (&x186 , p256Uint1 (x183 ), x178 , x169 )
var x187 uint64
p256CmovznzU64 (&x187 , p256Uint1 (x183 ), x180 , x171 )
out1 [0 ] = x184
out1 [1 ] = x185
out1 [2 ] = x186
out1 [3 ] = x187
}
func p256Square (out1 *p256MontgomeryDomainFieldElement , arg1 *p256MontgomeryDomainFieldElement ) {
x1 := arg1 [1 ]
x2 := arg1 [2 ]
x3 := arg1 [3 ]
x4 := arg1 [0 ]
var x5 uint64
var x6 uint64
x6 , x5 = bits .Mul64 (x4 , arg1 [3 ])
var x7 uint64
var x8 uint64
x8 , x7 = bits .Mul64 (x4 , arg1 [2 ])
var x9 uint64
var x10 uint64
x10 , x9 = bits .Mul64 (x4 , arg1 [1 ])
var x11 uint64
var x12 uint64
x12 , x11 = bits .Mul64 (x4 , arg1 [0 ])
var x13 uint64
var x14 uint64
x13 , x14 = bits .Add64 (x12 , x9 , uint64 (0x0 ))
var x15 uint64
var x16 uint64
x15 , x16 = bits .Add64 (x10 , x7 , uint64 (p256Uint1 (x14 )))
var x17 uint64
var x18 uint64
x17 , x18 = bits .Add64 (x8 , x5 , uint64 (p256Uint1 (x16 )))
x19 := (uint64 (p256Uint1 (x18 )) + x6 )
var x20 uint64
var x21 uint64
x21 , x20 = bits .Mul64 (x11 , 0xffffffff00000001 )
var x22 uint64
var x23 uint64
x23 , x22 = bits .Mul64 (x11 , 0xffffffff )
var x24 uint64
var x25 uint64
x25 , x24 = bits .Mul64 (x11 , 0xffffffffffffffff )
var x26 uint64
var x27 uint64
x26 , x27 = bits .Add64 (x25 , x22 , uint64 (0x0 ))
x28 := (uint64 (p256Uint1 (x27 )) + x23 )
var x30 uint64
_, x30 = bits .Add64 (x11 , x24 , uint64 (0x0 ))
var x31 uint64
var x32 uint64
x31 , x32 = bits .Add64 (x13 , x26 , uint64 (p256Uint1 (x30 )))
var x33 uint64
var x34 uint64
x33 , x34 = bits .Add64 (x15 , x28 , uint64 (p256Uint1 (x32 )))
var x35 uint64
var x36 uint64
x35 , x36 = bits .Add64 (x17 , x20 , uint64 (p256Uint1 (x34 )))
var x37 uint64
var x38 uint64
x37 , x38 = bits .Add64 (x19 , x21 , uint64 (p256Uint1 (x36 )))
var x39 uint64
var x40 uint64
x40 , x39 = bits .Mul64 (x1 , arg1 [3 ])
var x41 uint64
var x42 uint64
x42 , x41 = bits .Mul64 (x1 , arg1 [2 ])
var x43 uint64
var x44 uint64
x44 , x43 = bits .Mul64 (x1 , arg1 [1 ])
var x45 uint64
var x46 uint64
x46 , x45 = bits .Mul64 (x1 , arg1 [0 ])
var x47 uint64
var x48 uint64
x47 , x48 = bits .Add64 (x46 , x43 , uint64 (0x0 ))
var x49 uint64
var x50 uint64
x49 , x50 = bits .Add64 (x44 , x41 , uint64 (p256Uint1 (x48 )))
var x51 uint64
var x52 uint64
x51 , x52 = bits .Add64 (x42 , x39 , uint64 (p256Uint1 (x50 )))
x53 := (uint64 (p256Uint1 (x52 )) + x40 )
var x54 uint64
var x55 uint64
x54 , x55 = bits .Add64 (x31 , x45 , uint64 (0x0 ))
var x56 uint64
var x57 uint64
x56 , x57 = bits .Add64 (x33 , x47 , uint64 (p256Uint1 (x55 )))
var x58 uint64
var x59 uint64
x58 , x59 = bits .Add64 (x35 , x49 , uint64 (p256Uint1 (x57 )))
var x60 uint64
var x61 uint64
x60 , x61 = bits .Add64 (x37 , x51 , uint64 (p256Uint1 (x59 )))
var x62 uint64
var x63 uint64
x62 , x63 = bits .Add64 (uint64 (p256Uint1 (x38 )), x53 , uint64 (p256Uint1 (x61 )))
var x64 uint64
var x65 uint64
x65 , x64 = bits .Mul64 (x54 , 0xffffffff00000001 )
var x66 uint64
var x67 uint64
x67 , x66 = bits .Mul64 (x54 , 0xffffffff )
var x68 uint64
var x69 uint64
x69 , x68 = bits .Mul64 (x54 , 0xffffffffffffffff )
var x70 uint64
var x71 uint64
x70 , x71 = bits .Add64 (x69 , x66 , uint64 (0x0 ))
x72 := (uint64 (p256Uint1 (x71 )) + x67 )
var x74 uint64
_, x74 = bits .Add64 (x54 , x68 , uint64 (0x0 ))
var x75 uint64
var x76 uint64
x75 , x76 = bits .Add64 (x56 , x70 , uint64 (p256Uint1 (x74 )))
var x77 uint64
var x78 uint64
x77 , x78 = bits .Add64 (x58 , x72 , uint64 (p256Uint1 (x76 )))
var x79 uint64
var x80 uint64
x79 , x80 = bits .Add64 (x60 , x64 , uint64 (p256Uint1 (x78 )))
var x81 uint64
var x82 uint64
x81 , x82 = bits .Add64 (x62 , x65 , uint64 (p256Uint1 (x80 )))
x83 := (uint64 (p256Uint1 (x82 )) + uint64 (p256Uint1 (x63 )))
var x84 uint64
var x85 uint64
x85 , x84 = bits .Mul64 (x2 , arg1 [3 ])
var x86 uint64
var x87 uint64
x87 , x86 = bits .Mul64 (x2 , arg1 [2 ])
var x88 uint64
var x89 uint64
x89 , x88 = bits .Mul64 (x2 , arg1 [1 ])
var x90 uint64
var x91 uint64
x91 , x90 = bits .Mul64 (x2 , arg1 [0 ])
var x92 uint64
var x93 uint64
x92 , x93 = bits .Add64 (x91 , x88 , uint64 (0x0 ))
var x94 uint64
var x95 uint64
x94 , x95 = bits .Add64 (x89 , x86 , uint64 (p256Uint1 (x93 )))
var x96 uint64
var x97 uint64
x96 , x97 = bits .Add64 (x87 , x84 , uint64 (p256Uint1 (x95 )))
x98 := (uint64 (p256Uint1 (x97 )) + x85 )
var x99 uint64
var x100 uint64
x99 , x100 = bits .Add64 (x75 , x90 , uint64 (0x0 ))
var x101 uint64
var x102 uint64
x101 , x102 = bits .Add64 (x77 , x92 , uint64 (p256Uint1 (x100 )))
var x103 uint64
var x104 uint64
x103 , x104 = bits .Add64 (x79 , x94 , uint64 (p256Uint1 (x102 )))
var x105 uint64
var x106 uint64
x105 , x106 = bits .Add64 (x81 , x96 , uint64 (p256Uint1 (x104 )))
var x107 uint64
var x108 uint64
x107 , x108 = bits .Add64 (x83 , x98 , uint64 (p256Uint1 (x106 )))
var x109 uint64
var x110 uint64
x110 , x109 = bits .Mul64 (x99 , 0xffffffff00000001 )
var x111 uint64
var x112 uint64
x112 , x111 = bits .Mul64 (x99 , 0xffffffff )
var x113 uint64
var x114 uint64
x114 , x113 = bits .Mul64 (x99 , 0xffffffffffffffff )
var x115 uint64
var x116 uint64
x115 , x116 = bits .Add64 (x114 , x111 , uint64 (0x0 ))
x117 := (uint64 (p256Uint1 (x116 )) + x112 )
var x119 uint64
_, x119 = bits .Add64 (x99 , x113 , uint64 (0x0 ))
var x120 uint64
var x121 uint64
x120 , x121 = bits .Add64 (x101 , x115 , uint64 (p256Uint1 (x119 )))
var x122 uint64
var x123 uint64
x122 , x123 = bits .Add64 (x103 , x117 , uint64 (p256Uint1 (x121 )))
var x124 uint64
var x125 uint64
x124 , x125 = bits .Add64 (x105 , x109 , uint64 (p256Uint1 (x123 )))
var x126 uint64
var x127 uint64
x126 , x127 = bits .Add64 (x107 , x110 , uint64 (p256Uint1 (x125 )))
x128 := (uint64 (p256Uint1 (x127 )) + uint64 (p256Uint1 (x108 )))
var x129 uint64
var x130 uint64
x130 , x129 = bits .Mul64 (x3 , arg1 [3 ])
var x131 uint64
var x132 uint64
x132 , x131 = bits .Mul64 (x3 , arg1 [2 ])
var x133 uint64
var x134 uint64
x134 , x133 = bits .Mul64 (x3 , arg1 [1 ])
var x135 uint64
var x136 uint64
x136 , x135 = bits .Mul64 (x3 , arg1 [0 ])
var x137 uint64
var x138 uint64
x137 , x138 = bits .Add64 (x136 , x133 , uint64 (0x0 ))
var x139 uint64
var x140 uint64
x139 , x140 = bits .Add64 (x134 , x131 , uint64 (p256Uint1 (x138 )))
var x141 uint64
var x142 uint64
x141 , x142 = bits .Add64 (x132 , x129 , uint64 (p256Uint1 (x140 )))
x143 := (uint64 (p256Uint1 (x142 )) + x130 )
var x144 uint64
var x145 uint64
x144 , x145 = bits .Add64 (x120 , x135 , uint64 (0x0 ))
var x146 uint64
var x147 uint64
x146 , x147 = bits .Add64 (x122 , x137 , uint64 (p256Uint1 (x145 )))
var x148 uint64
var x149 uint64
x148 , x149 = bits .Add64 (x124 , x139 , uint64 (p256Uint1 (x147 )))
var x150 uint64
var x151 uint64
x150 , x151 = bits .Add64 (x126 , x141 , uint64 (p256Uint1 (x149 )))
var x152 uint64
var x153 uint64
x152 , x153 = bits .Add64 (x128 , x143 , uint64 (p256Uint1 (x151 )))
var x154 uint64
var x155 uint64
x155 , x154 = bits .Mul64 (x144 , 0xffffffff00000001 )
var x156 uint64
var x157 uint64
x157 , x156 = bits .Mul64 (x144 , 0xffffffff )
var x158 uint64
var x159 uint64
x159 , x158 = bits .Mul64 (x144 , 0xffffffffffffffff )
var x160 uint64
var x161 uint64
x160 , x161 = bits .Add64 (x159 , x156 , uint64 (0x0 ))
x162 := (uint64 (p256Uint1 (x161 )) + x157 )
var x164 uint64
_, x164 = bits .Add64 (x144 , x158 , uint64 (0x0 ))
var x165 uint64
var x166 uint64
x165 , x166 = bits .Add64 (x146 , x160 , uint64 (p256Uint1 (x164 )))
var x167 uint64
var x168 uint64
x167 , x168 = bits .Add64 (x148 , x162 , uint64 (p256Uint1 (x166 )))
var x169 uint64
var x170 uint64
x169 , x170 = bits .Add64 (x150 , x154 , uint64 (p256Uint1 (x168 )))
var x171 uint64
var x172 uint64
x171 , x172 = bits .Add64 (x152 , x155 , uint64 (p256Uint1 (x170 )))
x173 := (uint64 (p256Uint1 (x172 )) + uint64 (p256Uint1 (x153 )))
var x174 uint64
var x175 uint64
x174 , x175 = bits .Sub64 (x165 , 0xffffffffffffffff , uint64 (0x0 ))
var x176 uint64
var x177 uint64
x176 , x177 = bits .Sub64 (x167 , 0xffffffff , uint64 (p256Uint1 (x175 )))
var x178 uint64
var x179 uint64
x178 , x179 = bits .Sub64 (x169 , uint64 (0x0 ), uint64 (p256Uint1 (x177 )))
var x180 uint64
var x181 uint64
x180 , x181 = bits .Sub64 (x171 , 0xffffffff00000001 , uint64 (p256Uint1 (x179 )))
var x183 uint64
_, x183 = bits .Sub64 (x173 , uint64 (0x0 ), uint64 (p256Uint1 (x181 )))
var x184 uint64
p256CmovznzU64 (&x184 , p256Uint1 (x183 ), x174 , x165 )
var x185 uint64
p256CmovznzU64 (&x185 , p256Uint1 (x183 ), x176 , x167 )
var x186 uint64
p256CmovznzU64 (&x186 , p256Uint1 (x183 ), x178 , x169 )
var x187 uint64
p256CmovznzU64 (&x187 , p256Uint1 (x183 ), x180 , x171 )
out1 [0 ] = x184
out1 [1 ] = x185
out1 [2 ] = x186
out1 [3 ] = x187
}
func p256Add (out1 *p256MontgomeryDomainFieldElement , arg1 *p256MontgomeryDomainFieldElement , arg2 *p256MontgomeryDomainFieldElement ) {
var x1 uint64
var x2 uint64
x1 , x2 = bits .Add64 (arg1 [0 ], arg2 [0 ], uint64 (0x0 ))
var x3 uint64
var x4 uint64
x3 , x4 = bits .Add64 (arg1 [1 ], arg2 [1 ], uint64 (p256Uint1 (x2 )))
var x5 uint64
var x6 uint64
x5 , x6 = bits .Add64 (arg1 [2 ], arg2 [2 ], uint64 (p256Uint1 (x4 )))
var x7 uint64
var x8 uint64
x7 , x8 = bits .Add64 (arg1 [3 ], arg2 [3 ], uint64 (p256Uint1 (x6 )))
var x9 uint64
var x10 uint64
x9 , x10 = bits .Sub64 (x1 , 0xffffffffffffffff , uint64 (0x0 ))
var x11 uint64
var x12 uint64
x11 , x12 = bits .Sub64 (x3 , 0xffffffff , uint64 (p256Uint1 (x10 )))
var x13 uint64
var x14 uint64
x13 , x14 = bits .Sub64 (x5 , uint64 (0x0 ), uint64 (p256Uint1 (x12 )))
var x15 uint64
var x16 uint64
x15 , x16 = bits .Sub64 (x7 , 0xffffffff00000001 , uint64 (p256Uint1 (x14 )))
var x18 uint64
_, x18 = bits .Sub64 (uint64 (p256Uint1 (x8 )), uint64 (0x0 ), uint64 (p256Uint1 (x16 )))
var x19 uint64
p256CmovznzU64 (&x19 , p256Uint1 (x18 ), x9 , x1 )
var x20 uint64
p256CmovznzU64 (&x20 , p256Uint1 (x18 ), x11 , x3 )
var x21 uint64
p256CmovznzU64 (&x21 , p256Uint1 (x18 ), x13 , x5 )
var x22 uint64
p256CmovznzU64 (&x22 , p256Uint1 (x18 ), x15 , x7 )
out1 [0 ] = x19
out1 [1 ] = x20
out1 [2 ] = x21
out1 [3 ] = x22
}
func p256Sub (out1 *p256MontgomeryDomainFieldElement , arg1 *p256MontgomeryDomainFieldElement , arg2 *p256MontgomeryDomainFieldElement ) {
var x1 uint64
var x2 uint64
x1 , x2 = bits .Sub64 (arg1 [0 ], arg2 [0 ], uint64 (0x0 ))
var x3 uint64
var x4 uint64
x3 , x4 = bits .Sub64 (arg1 [1 ], arg2 [1 ], uint64 (p256Uint1 (x2 )))
var x5 uint64
var x6 uint64
x5 , x6 = bits .Sub64 (arg1 [2 ], arg2 [2 ], uint64 (p256Uint1 (x4 )))
var x7 uint64
var x8 uint64
x7 , x8 = bits .Sub64 (arg1 [3 ], arg2 [3 ], uint64 (p256Uint1 (x6 )))
var x9 uint64
p256CmovznzU64 (&x9 , p256Uint1 (x8 ), uint64 (0x0 ), 0xffffffffffffffff )
var x10 uint64
var x11 uint64
x10 , x11 = bits .Add64 (x1 , x9 , uint64 (0x0 ))
var x12 uint64
var x13 uint64
x12 , x13 = bits .Add64 (x3 , (x9 & 0xffffffff ), uint64 (p256Uint1 (x11 )))
var x14 uint64
var x15 uint64
x14 , x15 = bits .Add64 (x5 , uint64 (0x0 ), uint64 (p256Uint1 (x13 )))
var x16 uint64
x16 , _ = bits .Add64 (x7 , (x9 & 0xffffffff00000001 ), uint64 (p256Uint1 (x15 )))
out1 [0 ] = x10
out1 [1 ] = x12
out1 [2 ] = x14
out1 [3 ] = x16
}
func p256SetOne (out1 *p256MontgomeryDomainFieldElement ) {
out1 [0 ] = uint64 (0x1 )
out1 [1 ] = 0xffffffff00000000
out1 [2 ] = 0xffffffffffffffff
out1 [3 ] = 0xfffffffe
}
func p256FromMontgomery (out1 *p256NonMontgomeryDomainFieldElement , arg1 *p256MontgomeryDomainFieldElement ) {
x1 := arg1 [0 ]
var x2 uint64
var x3 uint64
x3 , x2 = bits .Mul64 (x1 , 0xffffffff00000001 )
var x4 uint64
var x5 uint64
x5 , x4 = bits .Mul64 (x1 , 0xffffffff )
var x6 uint64
var x7 uint64
x7 , x6 = bits .Mul64 (x1 , 0xffffffffffffffff )
var x8 uint64
var x9 uint64
x8 , x9 = bits .Add64 (x7 , x4 , uint64 (0x0 ))
var x11 uint64
_, x11 = bits .Add64 (x1 , x6 , uint64 (0x0 ))
var x12 uint64
var x13 uint64
x12 , x13 = bits .Add64 (uint64 (0x0 ), x8 , uint64 (p256Uint1 (x11 )))
var x14 uint64
var x15 uint64
x14 , x15 = bits .Add64 (x12 , arg1 [1 ], uint64 (0x0 ))
var x16 uint64
var x17 uint64
x17 , x16 = bits .Mul64 (x14 , 0xffffffff00000001 )
var x18 uint64
var x19 uint64
x19 , x18 = bits .Mul64 (x14 , 0xffffffff )
var x20 uint64
var x21 uint64
x21 , x20 = bits .Mul64 (x14 , 0xffffffffffffffff )
var x22 uint64
var x23 uint64
x22 , x23 = bits .Add64 (x21 , x18 , uint64 (0x0 ))
var x25 uint64
_, x25 = bits .Add64 (x14 , x20 , uint64 (0x0 ))
var x26 uint64
var x27 uint64
x26 , x27 = bits .Add64 ((uint64 (p256Uint1 (x15 )) + (uint64 (p256Uint1 (x13 )) + (uint64 (p256Uint1 (x9 )) + x5 ))), x22 , uint64 (p256Uint1 (x25 )))
var x28 uint64
var x29 uint64
x28 , x29 = bits .Add64 (x2 , (uint64 (p256Uint1 (x23 )) + x19 ), uint64 (p256Uint1 (x27 )))
var x30 uint64
var x31 uint64
x30 , x31 = bits .Add64 (x3 , x16 , uint64 (p256Uint1 (x29 )))
var x32 uint64
var x33 uint64
x32 , x33 = bits .Add64 (x26 , arg1 [2 ], uint64 (0x0 ))
var x34 uint64
var x35 uint64
x34 , x35 = bits .Add64 (x28 , uint64 (0x0 ), uint64 (p256Uint1 (x33 )))
var x36 uint64
var x37 uint64
x36 , x37 = bits .Add64 (x30 , uint64 (0x0 ), uint64 (p256Uint1 (x35 )))
var x38 uint64
var x39 uint64
x39 , x38 = bits .Mul64 (x32 , 0xffffffff00000001 )
var x40 uint64
var x41 uint64
x41 , x40 = bits .Mul64 (x32 , 0xffffffff )
var x42 uint64
var x43 uint64
x43 , x42 = bits .Mul64 (x32 , 0xffffffffffffffff )
var x44 uint64
var x45 uint64
x44 , x45 = bits .Add64 (x43 , x40 , uint64 (0x0 ))
var x47 uint64
_, x47 = bits .Add64 (x32 , x42 , uint64 (0x0 ))
var x48 uint64
var x49 uint64
x48 , x49 = bits .Add64 (x34 , x44 , uint64 (p256Uint1 (x47 )))
var x50 uint64
var x51 uint64
x50 , x51 = bits .Add64 (x36 , (uint64 (p256Uint1 (x45 )) + x41 ), uint64 (p256Uint1 (x49 )))
var x52 uint64
var x53 uint64
x52 , x53 = bits .Add64 ((uint64 (p256Uint1 (x37 )) + (uint64 (p256Uint1 (x31 )) + x17 )), x38 , uint64 (p256Uint1 (x51 )))
var x54 uint64
var x55 uint64
x54 , x55 = bits .Add64 (x48 , arg1 [3 ], uint64 (0x0 ))
var x56 uint64
var x57 uint64
x56 , x57 = bits .Add64 (x50 , uint64 (0x0 ), uint64 (p256Uint1 (x55 )))
var x58 uint64
var x59 uint64
x58 , x59 = bits .Add64 (x52 , uint64 (0x0 ), uint64 (p256Uint1 (x57 )))
var x60 uint64
var x61 uint64
x61 , x60 = bits .Mul64 (x54 , 0xffffffff00000001 )
var x62 uint64
var x63 uint64
x63 , x62 = bits .Mul64 (x54 , 0xffffffff )
var x64 uint64
var x65 uint64
x65 , x64 = bits .Mul64 (x54 , 0xffffffffffffffff )
var x66 uint64
var x67 uint64
x66 , x67 = bits .Add64 (x65 , x62 , uint64 (0x0 ))
var x69 uint64
_, x69 = bits .Add64 (x54 , x64 , uint64 (0x0 ))
var x70 uint64
var x71 uint64
x70 , x71 = bits .Add64 (x56 , x66 , uint64 (p256Uint1 (x69 )))
var x72 uint64
var x73 uint64
x72 , x73 = bits .Add64 (x58 , (uint64 (p256Uint1 (x67 )) + x63 ), uint64 (p256Uint1 (x71 )))
var x74 uint64
var x75 uint64
x74 , x75 = bits .Add64 ((uint64 (p256Uint1 (x59 )) + (uint64 (p256Uint1 (x53 )) + x39 )), x60 , uint64 (p256Uint1 (x73 )))
x76 := (uint64 (p256Uint1 (x75 )) + x61 )
var x77 uint64
var x78 uint64
x77 , x78 = bits .Sub64 (x70 , 0xffffffffffffffff , uint64 (0x0 ))
var x79 uint64
var x80 uint64
x79 , x80 = bits .Sub64 (x72 , 0xffffffff , uint64 (p256Uint1 (x78 )))
var x81 uint64
var x82 uint64
x81 , x82 = bits .Sub64 (x74 , uint64 (0x0 ), uint64 (p256Uint1 (x80 )))
var x83 uint64
var x84 uint64
x83 , x84 = bits .Sub64 (x76 , 0xffffffff00000001 , uint64 (p256Uint1 (x82 )))
var x86 uint64
_, x86 = bits .Sub64 (uint64 (0x0 ), uint64 (0x0 ), uint64 (p256Uint1 (x84 )))
var x87 uint64
p256CmovznzU64 (&x87 , p256Uint1 (x86 ), x77 , x70 )
var x88 uint64
p256CmovznzU64 (&x88 , p256Uint1 (x86 ), x79 , x72 )
var x89 uint64
p256CmovznzU64 (&x89 , p256Uint1 (x86 ), x81 , x74 )
var x90 uint64
p256CmovznzU64 (&x90 , p256Uint1 (x86 ), x83 , x76 )
out1 [0 ] = x87
out1 [1 ] = x88
out1 [2 ] = x89
out1 [3 ] = x90
}
func p256ToMontgomery (out1 *p256MontgomeryDomainFieldElement , arg1 *p256NonMontgomeryDomainFieldElement ) {
x1 := arg1 [1 ]
x2 := arg1 [2 ]
x3 := arg1 [3 ]
x4 := arg1 [0 ]
var x5 uint64
var x6 uint64
x6 , x5 = bits .Mul64 (x4 , 0x4fffffffd )
var x7 uint64
var x8 uint64
x8 , x7 = bits .Mul64 (x4 , 0xfffffffffffffffe )
var x9 uint64
var x10 uint64
x10 , x9 = bits .Mul64 (x4 , 0xfffffffbffffffff )
var x11 uint64
var x12 uint64
x12 , x11 = bits .Mul64 (x4 , 0x3 )
var x13 uint64
var x14 uint64
x13 , x14 = bits .Add64 (x12 , x9 , uint64 (0x0 ))
var x15 uint64
var x16 uint64
x15 , x16 = bits .Add64 (x10 , x7 , uint64 (p256Uint1 (x14 )))
var x17 uint64
var x18 uint64
x17 , x18 = bits .Add64 (x8 , x5 , uint64 (p256Uint1 (x16 )))
var x19 uint64
var x20 uint64
x20 , x19 = bits .Mul64 (x11 , 0xffffffff00000001 )
var x21 uint64
var x22 uint64
x22 , x21 = bits .Mul64 (x11 , 0xffffffff )
var x23 uint64
var x24 uint64
x24 , x23 = bits .Mul64 (x11 , 0xffffffffffffffff )
var x25 uint64
var x26 uint64
x25 , x26 = bits .Add64 (x24 , x21 , uint64 (0x0 ))
var x28 uint64
_, x28 = bits .Add64 (x11 , x23 , uint64 (0x0 ))
var x29 uint64
var x30 uint64
x29 , x30 = bits .Add64 (x13 , x25 , uint64 (p256Uint1 (x28 )))
var x31 uint64
var x32 uint64
x31 , x32 = bits .Add64 (x15 , (uint64 (p256Uint1 (x26 )) + x22 ), uint64 (p256Uint1 (x30 )))
var x33 uint64
var x34 uint64
x33 , x34 = bits .Add64 (x17 , x19 , uint64 (p256Uint1 (x32 )))
var x35 uint64
var x36 uint64
x35 , x36 = bits .Add64 ((uint64 (p256Uint1 (x18 )) + x6 ), x20 , uint64 (p256Uint1 (x34 )))
var x37 uint64
var x38 uint64
x38 , x37 = bits .Mul64 (x1 , 0x4fffffffd )
var x39 uint64
var x40 uint64
x40 , x39 = bits .Mul64 (x1 , 0xfffffffffffffffe )
var x41 uint64
var x42 uint64
x42 , x41 = bits .Mul64 (x1 , 0xfffffffbffffffff )
var x43 uint64
var x44 uint64
x44 , x43 = bits .Mul64 (x1 , 0x3 )
var x45 uint64
var x46 uint64
x45 , x46 = bits .Add64 (x44 , x41 , uint64 (0x0 ))
var x47 uint64
var x48 uint64
x47 , x48 = bits .Add64 (x42 , x39 , uint64 (p256Uint1 (x46 )))
var x49 uint64
var x50 uint64
x49 , x50 = bits .Add64 (x40 , x37 , uint64 (p256Uint1 (x48 )))
var x51 uint64
var x52 uint64
x51 , x52 = bits .Add64 (x29 , x43 , uint64 (0x0 ))
var x53 uint64
var x54 uint64
x53 , x54 = bits .Add64 (x31 , x45 , uint64 (p256Uint1 (x52 )))
var x55 uint64
var x56 uint64
x55 , x56 = bits .Add64 (x33 , x47 , uint64 (p256Uint1 (x54 )))
var x57 uint64
var x58 uint64
x57 , x58 = bits .Add64 (x35 , x49 , uint64 (p256Uint1 (x56 )))
var x59 uint64
var x60 uint64
x60 , x59 = bits .Mul64 (x51 , 0xffffffff00000001 )
var x61 uint64
var x62 uint64
x62 , x61 = bits .Mul64 (x51 , 0xffffffff )
var x63 uint64
var x64 uint64
x64 , x63 = bits .Mul64 (x51 , 0xffffffffffffffff )
var x65 uint64
var x66 uint64
x65 , x66 = bits .Add64 (x64 , x61 , uint64 (0x0 ))
var x68 uint64
_, x68 = bits .Add64 (x51 , x63 , uint64 (0x0 ))
var x69 uint64
var x70 uint64
x69 , x70 = bits .Add64 (x53 , x65 , uint64 (p256Uint1 (x68 )))
var x71 uint64
var x72 uint64
x71 , x72 = bits .Add64 (x55 , (uint64 (p256Uint1 (x66 )) + x62 ), uint64 (p256Uint1 (x70 )))
var x73 uint64
var x74 uint64
x73 , x74 = bits .Add64 (x57 , x59 , uint64 (p256Uint1 (x72 )))
var x75 uint64
var x76 uint64
x75 , x76 = bits .Add64 (((uint64 (p256Uint1 (x58 )) + uint64 (p256Uint1 (x36 ))) + (uint64 (p256Uint1 (x50 )) + x38 )), x60 , uint64 (p256Uint1 (x74 )))
var x77 uint64
var x78 uint64
x78 , x77 = bits .Mul64 (x2 , 0x4fffffffd )
var x79 uint64
var x80 uint64
x80 , x79 = bits .Mul64 (x2 , 0xfffffffffffffffe )
var x81 uint64
var x82 uint64
x82 , x81 = bits .Mul64 (x2 , 0xfffffffbffffffff )
var x83 uint64
var x84 uint64
x84 , x83 = bits .Mul64 (x2 , 0x3 )
var x85 uint64
var x86 uint64
x85 , x86 = bits .Add64 (x84 , x81 , uint64 (0x0 ))
var x87 uint64
var x88 uint64
x87 , x88 = bits .Add64 (x82 , x79 , uint64 (p256Uint1 (x86 )))
var x89 uint64
var x90 uint64
x89 , x90 = bits .Add64 (x80 , x77 , uint64 (p256Uint1 (x88 )))
var x91 uint64
var x92 uint64
x91 , x92 = bits .Add64 (x69 , x83 , uint64 (0x0 ))
var x93 uint64
var x94 uint64
x93 , x94 = bits .Add64 (x71 , x85 , uint64 (p256Uint1 (x92 )))
var x95 uint64
var x96 uint64
x95 , x96 = bits .Add64 (x73 , x87 , uint64 (p256Uint1 (x94 )))
var x97 uint64
var x98 uint64
x97 , x98 = bits .Add64 (x75 , x89 , uint64 (p256Uint1 (x96 )))
var x99 uint64
var x100 uint64
x100 , x99 = bits .Mul64 (x91 , 0xffffffff00000001 )
var x101 uint64
var x102 uint64
x102 , x101 = bits .Mul64 (x91 , 0xffffffff )
var x103 uint64
var x104 uint64
x104 , x103 = bits .Mul64 (x91 , 0xffffffffffffffff )
var x105 uint64
var x106 uint64
x105 , x106 = bits .Add64 (x104 , x101 , uint64 (0x0 ))
var x108 uint64
_, x108 = bits .Add64 (x91 , x103 , uint64 (0x0 ))
var x109 uint64
var x110 uint64
x109 , x110 = bits .Add64 (x93 , x105 , uint64 (p256Uint1 (x108 )))
var x111 uint64
var x112 uint64
x111 , x112 = bits .Add64 (x95 , (uint64 (p256Uint1 (x106 )) + x102 ), uint64 (p256Uint1 (x110 )))
var x113 uint64
var x114 uint64
x113 , x114 = bits .Add64 (x97 , x99 , uint64 (p256Uint1 (x112 )))
var x115 uint64
var x116 uint64
x115 , x116 = bits .Add64 (((uint64 (p256Uint1 (x98 )) + uint64 (p256Uint1 (x76 ))) + (uint64 (p256Uint1 (x90 )) + x78 )), x100 , uint64 (p256Uint1 (x114 )))
var x117 uint64
var x118 uint64
x118 , x117 = bits .Mul64 (x3 , 0x4fffffffd )
var x119 uint64
var x120 uint64
x120 , x119 = bits .Mul64 (x3 , 0xfffffffffffffffe )
var x121 uint64
var x122 uint64
x122 , x121 = bits .Mul64 (x3 , 0xfffffffbffffffff )
var x123 uint64
var x124 uint64
x124 , x123 = bits .Mul64 (x3 , 0x3 )
var x125 uint64
var x126 uint64
x125 , x126 = bits .Add64 (x124 , x121 , uint64 (0x0 ))
var x127 uint64
var x128 uint64
x127 , x128 = bits .Add64 (x122 , x119 , uint64 (p256Uint1 (x126 )))
var x129 uint64
var x130 uint64
x129 , x130 = bits .Add64 (x120 , x117 , uint64 (p256Uint1 (x128 )))
var x131 uint64
var x132 uint64
x131 , x132 = bits .Add64 (x109 , x123 , uint64 (0x0 ))
var x133 uint64
var x134 uint64
x133 , x134 = bits .Add64 (x111 , x125 , uint64 (p256Uint1 (x132 )))
var x135 uint64
var x136 uint64
x135 , x136 = bits .Add64 (x113 , x127 , uint64 (p256Uint1 (x134 )))
var x137 uint64
var x138 uint64
x137 , x138 = bits .Add64 (x115 , x129 , uint64 (p256Uint1 (x136 )))
var x139 uint64
var x140 uint64
x140 , x139 = bits .Mul64 (x131 , 0xffffffff00000001 )
var x141 uint64
var x142 uint64
x142 , x141 = bits .Mul64 (x131 , 0xffffffff )
var x143 uint64
var x144 uint64
x144 , x143 = bits .Mul64 (x131 , 0xffffffffffffffff )
var x145 uint64
var x146 uint64
x145 , x146 = bits .Add64 (x144 , x141 , uint64 (0x0 ))
var x148 uint64
_, x148 = bits .Add64 (x131 , x143 , uint64 (0x0 ))
var x149 uint64
var x150 uint64
x149 , x150 = bits .Add64 (x133 , x145 , uint64 (p256Uint1 (x148 )))
var x151 uint64
var x152 uint64
x151 , x152 = bits .Add64 (x135 , (uint64 (p256Uint1 (x146 )) + x142 ), uint64 (p256Uint1 (x150 )))
var x153 uint64
var x154 uint64
x153 , x154 = bits .Add64 (x137 , x139 , uint64 (p256Uint1 (x152 )))
var x155 uint64
var x156 uint64
x155 , x156 = bits .Add64 (((uint64 (p256Uint1 (x138 )) + uint64 (p256Uint1 (x116 ))) + (uint64 (p256Uint1 (x130 )) + x118 )), x140 , uint64 (p256Uint1 (x154 )))
var x157 uint64
var x158 uint64
x157 , x158 = bits .Sub64 (x149 , 0xffffffffffffffff , uint64 (0x0 ))
var x159 uint64
var x160 uint64
x159 , x160 = bits .Sub64 (x151 , 0xffffffff , uint64 (p256Uint1 (x158 )))
var x161 uint64
var x162 uint64
x161 , x162 = bits .Sub64 (x153 , uint64 (0x0 ), uint64 (p256Uint1 (x160 )))
var x163 uint64
var x164 uint64
x163 , x164 = bits .Sub64 (x155 , 0xffffffff00000001 , uint64 (p256Uint1 (x162 )))
var x166 uint64
_, x166 = bits .Sub64 (uint64 (p256Uint1 (x156 )), uint64 (0x0 ), uint64 (p256Uint1 (x164 )))
var x167 uint64
p256CmovznzU64 (&x167 , p256Uint1 (x166 ), x157 , x149 )
var x168 uint64
p256CmovznzU64 (&x168 , p256Uint1 (x166 ), x159 , x151 )
var x169 uint64
p256CmovznzU64 (&x169 , p256Uint1 (x166 ), x161 , x153 )
var x170 uint64
p256CmovznzU64 (&x170 , p256Uint1 (x166 ), x163 , x155 )
out1 [0 ] = x167
out1 [1 ] = x168
out1 [2 ] = x169
out1 [3 ] = x170
}
func p256Selectznz (out1 *[4 ]uint64 , arg1 p256Uint1 , arg2 *[4 ]uint64 , arg3 *[4 ]uint64 ) {
var x1 uint64
p256CmovznzU64 (&x1 , arg1 , arg2 [0 ], arg3 [0 ])
var x2 uint64
p256CmovznzU64 (&x2 , arg1 , arg2 [1 ], arg3 [1 ])
var x3 uint64
p256CmovznzU64 (&x3 , arg1 , arg2 [2 ], arg3 [2 ])
var x4 uint64
p256CmovznzU64 (&x4 , arg1 , arg2 [3 ], arg3 [3 ])
out1 [0 ] = x1
out1 [1 ] = x2
out1 [2 ] = x3
out1 [3 ] = x4
}
func p256ToBytes (out1 *[32 ]uint8 , arg1 *[4 ]uint64 ) {
x1 := arg1 [3 ]
x2 := arg1 [2 ]
x3 := arg1 [1 ]
x4 := arg1 [0 ]
x5 := (uint8 (x4 ) & 0xff )
x6 := (x4 >> 8 )
x7 := (uint8 (x6 ) & 0xff )
x8 := (x6 >> 8 )
x9 := (uint8 (x8 ) & 0xff )
x10 := (x8 >> 8 )
x11 := (uint8 (x10 ) & 0xff )
x12 := (x10 >> 8 )
x13 := (uint8 (x12 ) & 0xff )
x14 := (x12 >> 8 )
x15 := (uint8 (x14 ) & 0xff )
x16 := (x14 >> 8 )
x17 := (uint8 (x16 ) & 0xff )
x18 := uint8 ((x16 >> 8 ))
x19 := (uint8 (x3 ) & 0xff )
x20 := (x3 >> 8 )
x21 := (uint8 (x20 ) & 0xff )
x22 := (x20 >> 8 )
x23 := (uint8 (x22 ) & 0xff )
x24 := (x22 >> 8 )
x25 := (uint8 (x24 ) & 0xff )
x26 := (x24 >> 8 )
x27 := (uint8 (x26 ) & 0xff )
x28 := (x26 >> 8 )
x29 := (uint8 (x28 ) & 0xff )
x30 := (x28 >> 8 )
x31 := (uint8 (x30 ) & 0xff )
x32 := uint8 ((x30 >> 8 ))
x33 := (uint8 (x2 ) & 0xff )
x34 := (x2 >> 8 )
x35 := (uint8 (x34 ) & 0xff )
x36 := (x34 >> 8 )
x37 := (uint8 (x36 ) & 0xff )
x38 := (x36 >> 8 )
x39 := (uint8 (x38 ) & 0xff )
x40 := (x38 >> 8 )
x41 := (uint8 (x40 ) & 0xff )
x42 := (x40 >> 8 )
x43 := (uint8 (x42 ) & 0xff )
x44 := (x42 >> 8 )
x45 := (uint8 (x44 ) & 0xff )
x46 := uint8 ((x44 >> 8 ))
x47 := (uint8 (x1 ) & 0xff )
x48 := (x1 >> 8 )
x49 := (uint8 (x48 ) & 0xff )
x50 := (x48 >> 8 )
x51 := (uint8 (x50 ) & 0xff )
x52 := (x50 >> 8 )
x53 := (uint8 (x52 ) & 0xff )
x54 := (x52 >> 8 )
x55 := (uint8 (x54 ) & 0xff )
x56 := (x54 >> 8 )
x57 := (uint8 (x56 ) & 0xff )
x58 := (x56 >> 8 )
x59 := (uint8 (x58 ) & 0xff )
x60 := uint8 ((x58 >> 8 ))
out1 [0 ] = x5
out1 [1 ] = x7
out1 [2 ] = x9
out1 [3 ] = x11
out1 [4 ] = x13
out1 [5 ] = x15
out1 [6 ] = x17
out1 [7 ] = x18
out1 [8 ] = x19
out1 [9 ] = x21
out1 [10 ] = x23
out1 [11 ] = x25
out1 [12 ] = x27
out1 [13 ] = x29
out1 [14 ] = x31
out1 [15 ] = x32
out1 [16 ] = x33
out1 [17 ] = x35
out1 [18 ] = x37
out1 [19 ] = x39
out1 [20 ] = x41
out1 [21 ] = x43
out1 [22 ] = x45
out1 [23 ] = x46
out1 [24 ] = x47
out1 [25 ] = x49
out1 [26 ] = x51
out1 [27 ] = x53
out1 [28 ] = x55
out1 [29 ] = x57
out1 [30 ] = x59
out1 [31 ] = x60
}
func p256FromBytes (out1 *[4 ]uint64 , arg1 *[32 ]uint8 ) {
x1 := (uint64 (arg1 [31 ]) << 56 )
x2 := (uint64 (arg1 [30 ]) << 48 )
x3 := (uint64 (arg1 [29 ]) << 40 )
x4 := (uint64 (arg1 [28 ]) << 32 )
x5 := (uint64 (arg1 [27 ]) << 24 )
x6 := (uint64 (arg1 [26 ]) << 16 )
x7 := (uint64 (arg1 [25 ]) << 8 )
x8 := arg1 [24 ]
x9 := (uint64 (arg1 [23 ]) << 56 )
x10 := (uint64 (arg1 [22 ]) << 48 )
x11 := (uint64 (arg1 [21 ]) << 40 )
x12 := (uint64 (arg1 [20 ]) << 32 )
x13 := (uint64 (arg1 [19 ]) << 24 )
x14 := (uint64 (arg1 [18 ]) << 16 )
x15 := (uint64 (arg1 [17 ]) << 8 )
x16 := arg1 [16 ]
x17 := (uint64 (arg1 [15 ]) << 56 )
x18 := (uint64 (arg1 [14 ]) << 48 )
x19 := (uint64 (arg1 [13 ]) << 40 )
x20 := (uint64 (arg1 [12 ]) << 32 )
x21 := (uint64 (arg1 [11 ]) << 24 )
x22 := (uint64 (arg1 [10 ]) << 16 )
x23 := (uint64 (arg1 [9 ]) << 8 )
x24 := arg1 [8 ]
x25 := (uint64 (arg1 [7 ]) << 56 )
x26 := (uint64 (arg1 [6 ]) << 48 )
x27 := (uint64 (arg1 [5 ]) << 40 )
x28 := (uint64 (arg1 [4 ]) << 32 )
x29 := (uint64 (arg1 [3 ]) << 24 )
x30 := (uint64 (arg1 [2 ]) << 16 )
x31 := (uint64 (arg1 [1 ]) << 8 )
x32 := arg1 [0 ]
x33 := (x31 + uint64 (x32 ))
x34 := (x30 + x33 )
x35 := (x29 + x34 )
x36 := (x28 + x35 )
x37 := (x27 + x36 )
x38 := (x26 + x37 )
x39 := (x25 + x38 )
x40 := (x23 + uint64 (x24 ))
x41 := (x22 + x40 )
x42 := (x21 + x41 )
x43 := (x20 + x42 )
x44 := (x19 + x43 )
x45 := (x18 + x44 )
x46 := (x17 + x45 )
x47 := (x15 + uint64 (x16 ))
x48 := (x14 + x47 )
x49 := (x13 + x48 )
x50 := (x12 + x49 )
x51 := (x11 + x50 )
x52 := (x10 + x51 )
x53 := (x9 + x52 )
x54 := (x7 + uint64 (x8 ))
x55 := (x6 + x54 )
x56 := (x5 + x55 )
x57 := (x4 + x56 )
x58 := (x3 + x57 )
x59 := (x2 + x58 )
x60 := (x1 + x59 )
out1 [0 ] = x39
out1 [1 ] = x46
out1 [2 ] = x53
out1 [3 ] = x60
}
The pages are generated with Golds v0.6.7 . (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu .
PR and bug reports are welcome and can be submitted to the issue list .
Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds .