mirror of
https://github.com/logos-storage/plonky2.git
synced 2026-01-07 16:23:12 +00:00
dont panic
This commit is contained in:
parent
26d99a9b15
commit
dd58b9b5d8
@ -1,8 +1,8 @@
|
|||||||
/// def bn254_pairing(pairs: List((Curve, TwistedCurve))) -> Fp12:
|
/// def bn254_pairing(pairs: List((Curve, TwistedCurve))) -> Fp12:
|
||||||
///
|
///
|
||||||
/// for P, Q in pairs:
|
/// for P, Q in pairs:
|
||||||
/// assert(P.is_valid)
|
/// if not (P.is_valid and Q.is_valid):
|
||||||
/// assert(Q.is_valid)
|
/// return @U256_MAX
|
||||||
///
|
///
|
||||||
/// out = 1
|
/// out = 1
|
||||||
/// for P, Q in pairs:
|
/// for P, Q in pairs:
|
||||||
@ -35,17 +35,28 @@ bn254_input_check:
|
|||||||
// stack: P_j, inp_j, j, k, inp
|
// stack: P_j, inp_j, j, k, inp
|
||||||
%bn_check
|
%bn_check
|
||||||
// stack: valid?, inp_j, j, k, inp
|
// stack: valid?, inp_j, j, k, inp
|
||||||
%assert_nonzero
|
ISZERO
|
||||||
|
%jumpi(bn_pairing_invalid_input)
|
||||||
// stack: inp_j, j, k, inp
|
// stack: inp_j, j, k, inp
|
||||||
|
DUP1
|
||||||
|
// stack: inp_j , inp_j, j, k, inp
|
||||||
%add_const(2)
|
%add_const(2)
|
||||||
|
// stack: inp_j', inp_j, j, k, inp
|
||||||
%load_fp254_4
|
%load_fp254_4
|
||||||
// stack: Q_j, j, k, inp
|
// stack: Q_j, inp_j, j, k, inp
|
||||||
%bn_check_twisted
|
%bn_check_twisted
|
||||||
// stack: valid?, j, k, inp
|
// stack: valid?, inp_j, j, k, inp
|
||||||
%assert_nonzero
|
ISZERO
|
||||||
// stack: j, k, inp
|
%jumpi(bn_pairing_invalid_input)
|
||||||
|
// stack: inp_j, j, k, inp
|
||||||
|
POP
|
||||||
%jump(bn254_input_check)
|
%jump(bn254_input_check)
|
||||||
|
|
||||||
|
bn_pairing_invalid_input:
|
||||||
|
// stack: inp_j, j, k, inp, out, retdest
|
||||||
|
%stack (inp_j, j, k, inp, out, retdest) -> (retdest, @U256_MAX)
|
||||||
|
JUMP
|
||||||
|
|
||||||
bn254_pairing_start:
|
bn254_pairing_start:
|
||||||
// stack: 0, k, inp, out, retdest
|
// stack: 0, k, inp, out, retdest
|
||||||
%stack (j, k, inp, out) -> (out, 1, k, inp, out)
|
%stack (j, k, inp, out) -> (out, 1, k, inp, out)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user