diff --git a/pkg/test/valid_corset_test.go b/pkg/test/valid_corset_test.go index c284acd..e873e03 100644 --- a/pkg/test/valid_corset_test.go +++ b/pkg/test/valid_corset_test.go @@ -664,10 +664,10 @@ func TestSlow_Wcp(t *testing.T) { Check(t, true, "wcp") } -func TestSlow_Mxp(t *testing.T) { +/* func TestSlow_Mxp(t *testing.T) { Check(t, true, "mxp") } - +*/ // =================================================================== // Test Helpers // =================================================================== diff --git a/testdata/bin-dynamic.lisp b/testdata/bin-dynamic.lisp index 0ebbf90..5e5a909 100644 --- a/testdata/bin-dynamic.lisp +++ b/testdata/bin-dynamic.lisp @@ -4,7 +4,7 @@ (STAMP :i32) (CT_MAX :byte) (COUNTER :byte) - (INST :byte) + (INST :byte :display :opcode) (ARGUMENT_1_HI :i128) (ARGUMENT_1_LO :i128) (ARGUMENT_2_HI :i128) @@ -40,42 +40,230 @@ (XXX_BYTE_HI :byte) (XXX_BYTE_LO :byte)) -(defconstraint byte_decompositions () (begin (if COUNTER (- ACC_1 BYTE_1) (- ACC_1 (+ (* 256 (shift ACC_1 -1)) BYTE_1))) (if COUNTER (- ACC_2 BYTE_2) (- ACC_2 (+ (* 256 (shift ACC_2 -1)) BYTE_2))) (if COUNTER (- ACC_3 BYTE_3) (- ACC_3 (+ (* 256 (shift ACC_3 -1)) BYTE_3))) (if COUNTER (- ACC_4 BYTE_4) (- ACC_4 (+ (* 256 (shift ACC_4 -1)) BYTE_4))) (if COUNTER (- ACC_5 BYTE_5) (- ACC_5 (+ (* 256 (shift ACC_5 -1)) BYTE_5))) (if COUNTER (- ACC_6 BYTE_6) (- ACC_6 (+ (* 256 (shift ACC_6 -1)) BYTE_6))))) +;; aliases +(defalias + CT COUNTER + ARG_1_HI ARGUMENT_1_HI + ARG_1_LO ARGUMENT_1_LO + ARG_2_HI ARGUMENT_2_HI + ARG_2_LO ARGUMENT_2_LO + RES_HI RESULT_HI + RES_LO RESULT_LO) -(defconstraint bits-and-related () (if (+ IS_BYTE IS_SIGNEXTEND) 0 (if (- COUNTER 15) (begin (- PIVOT (+ (* 128 (shift BITS -15)) (* 64 (shift BITS -14)) (* 32 (shift BITS -13)) (* 16 (shift BITS -12)) (* 8 (shift BITS -11)) (* 4 (shift BITS -10)) (* 2 (shift BITS -9)) (shift BITS -8))) (- BYTE_2 (+ (* 128 (shift BITS -7)) (* 64 (shift BITS -6)) (* 32 (shift BITS -5)) (* 16 (shift BITS -4)) (* 8 (shift BITS -3)) (* 4 (shift BITS -2)) (* 2 (shift BITS -1)) BITS)) (- LOW_4 (+ (* 8 (shift BITS -3)) (* 4 (shift BITS -2)) (* 2 (shift BITS -1)) BITS)) (- BIT_B_4 (shift BITS -4)) (- NEG (shift BITS -15)))))) +(defconst + ;; opcode values + SIGNEXTEND 11 + AND 22 + OR 23 + XOR 24 + NOT 25 + BYTE 26 + ;; constant values + LLARGE 16 + LLARGEMO 15) -(defconstraint pivot () (if CT_MAX 0 (begin (if (- IS_BYTE 1) (if LOW_4 (if COUNTER (if BIT_B_4 (- PIVOT BYTE_3) (- PIVOT BYTE_4))) (if (+ (shift BIT_1 -1) (- 1 BIT_1)) (if BIT_B_4 (- PIVOT BYTE_3) (- PIVOT BYTE_4))))) (if (- IS_SIGNEXTEND 1) (if (- LOW_4 15) (if COUNTER (if BIT_B_4 (- PIVOT BYTE_4) (- PIVOT BYTE_3))) (if (+ (shift BIT_1 -1) (- 1 BIT_1)) (if BIT_B_4 (- PIVOT BYTE_4) (- PIVOT BYTE_3)))))))) +(defpurefun (if-eq-else A B THEN ELSE) + (if-zero-else (- A B) + THEN + ELSE)) -(defconstraint counter-constancies () (begin (if COUNTER 0 (- ARGUMENT_1_HI (shift ARGUMENT_1_HI -1))) (if COUNTER 0 (- ARGUMENT_1_LO (shift ARGUMENT_1_LO -1))) (if COUNTER 0 (- ARGUMENT_2_HI (shift ARGUMENT_2_HI -1))) (if COUNTER 0 (- ARGUMENT_2_LO (shift ARGUMENT_2_LO -1))) (if COUNTER 0 (- RESULT_HI (shift RESULT_HI -1))) (if COUNTER 0 (- RESULT_LO (shift RESULT_LO -1))) (if COUNTER 0 (- INST (shift INST -1))) (if COUNTER 0 (- CT_MAX (shift CT_MAX -1))) (if COUNTER 0 (- PIVOT (shift PIVOT -1))) (if COUNTER 0 (- BIT_B_4 (shift BIT_B_4 -1))) (if COUNTER 0 (- LOW_4 (shift LOW_4 -1))) (if COUNTER 0 (- NEG (shift NEG -1))) (if COUNTER 0 (- SMALL (shift SMALL -1))))) +;; 2.2 Shorthands +(defun (flag-sum) + (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND)) -(defconstraint bit_1 () (if CT_MAX 0 (begin (if (- IS_BYTE 1) (begin (if LOW_4 (- BIT_1 1) (if (- COUNTER 0) BIT_1 (if (- COUNTER LOW_4) (- BIT_1 (+ (shift BIT_1 -1) 1)) (- BIT_1 (shift BIT_1 -1))))))) (if (- IS_SIGNEXTEND 1) (begin (if (- 15 LOW_4) (- BIT_1 1) (if (- COUNTER 0) BIT_1 (if (- COUNTER (- 15 LOW_4)) (- BIT_1 (+ (shift BIT_1 -1) 1)) (- BIT_1 (shift BIT_1 -1)))))))))) +(defun (weight-sum) + (+ (* IS_AND AND) + (* IS_OR OR) + (* IS_XOR XOR) + (* IS_NOT NOT) + (* IS_BYTE BYTE) + (* IS_SIGNEXTEND SIGNEXTEND))) -(defconstraint is-signextend-result () (if IS_SIGNEXTEND 0 (if CT_MAX (begin (- RESULT_HI ARGUMENT_2_HI) (- RESULT_LO ARGUMENT_2_LO)) (if SMALL (begin (- RESULT_HI ARGUMENT_2_HI) (- RESULT_LO ARGUMENT_2_LO)) (begin (if BIT_B_4 (begin (- BYTE_5 (* NEG 255)) (if BIT_1 (- BYTE_6 (* NEG 255)) (- BYTE_6 BYTE_4))) (begin (if BIT_1 (- BYTE_5 (* NEG 255)) (- BYTE_5 BYTE_3)) (- RESULT_LO ARGUMENT_2_LO)))))))) +;; 2.3 Instruction decoding +(defconstraint no-bin-no-flag () + (if-zero-else STAMP + (vanishes! (flag-sum)) + (eq! (flag-sum) 1))) -(defconstraint small () (if (+ IS_BYTE IS_SIGNEXTEND) 0 (if (- COUNTER 15) (if ARGUMENT_1_HI (if (- ARGUMENT_1_LO (+ (* 16 (shift BITS -4)) (* 8 (shift BITS -3)) (* 4 (shift BITS -2)) (* 2 (shift BITS -1)) BITS)) (- SMALL 1) SMALL))))) +(defconstraint inst-to-flag () + (eq! INST (weight-sum))) -(defconstraint inst-to-flag () (- INST (+ (* IS_AND 22) (* IS_OR 23) (* IS_XOR 24) (* IS_NOT 25) (* IS_BYTE 26) (* IS_SIGNEXTEND 11)))) +;; 2.4 Heartbeat +(defconstraint first-row (:domain {0}) + (vanishes! STAMP)) -(defconstraint target-constraints () (if (- COUNTER CT_MAX) (begin (- ACC_1 ARGUMENT_1_HI) (- ACC_2 ARGUMENT_1_LO) (- ACC_3 ARGUMENT_2_HI) (- ACC_4 ARGUMENT_2_LO) (- ACC_5 RESULT_HI) (- ACC_6 RESULT_LO)))) +(defconstraint stamp-increments () + (vanishes! (* (will-inc! STAMP 0) (will-inc! STAMP 1)))) -(defconstraint countereset () (if STAMP 0 (if (- COUNTER CT_MAX) (- (shift STAMP 1) (+ STAMP 1)) (- (shift COUNTER 1) (+ COUNTER 1))))) +(defconstraint new-stamp-reset-ct () + (if-not-zero (- (next STAMP) STAMP) + (vanishes! (next CT)))) -(defconstraint stamp-increments () (* (- (shift STAMP 1) (+ STAMP 0)) (- (shift STAMP 1) (+ STAMP 1)))) +(defconstraint isnot-ctmax () + (if-eq IS_NOT 1 (eq! CT_MAX LLARGEMO))) -(defconstraint isbyte-ctmax () (if (- (+ IS_BYTE IS_SIGNEXTEND) 1) (if ARGUMENT_1_HI (- CT_MAX 15) CT_MAX))) +(defconstraint isbyte-ctmax () + (if-eq (+ IS_BYTE IS_SIGNEXTEND) 1 + (if-zero-else ARG_1_HI + (eq! CT_MAX LLARGEMO) + (vanishes! CT_MAX)))) -(defconstraint no-bin-no-flag () (if STAMP (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND) (- (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND) 1))) +(defconstraint ct-small () + (eq! 1 + (~ (- CT LLARGE)))) -(defconstraint is-byte-result () (if IS_BYTE 0 (if CT_MAX (begin RESULT_HI RESULT_LO) (begin RESULT_HI (- RESULT_LO (* SMALL PIVOT)))))) +(defconstraint countereset (:guard STAMP) + (if-eq-else CT CT_MAX (will-inc! STAMP 1) (will-inc! CT 1))) -(defconstraint result-via-deflookup () (if (+ IS_AND IS_OR IS_XOR IS_NOT) 0 (begin (- BYTE_5 XXX_BYTE_HI) (- BYTE_6 XXX_BYTE_LO)))) +(defconstraint last-row (:domain {-1}) + (eq! CT CT_MAX)) -(defconstraint isnot-ctmax () (if (- IS_NOT 1) (- CT_MAX 15))) +(defconstraint counter-constancies () + (begin (counter-constancy CT ARG_1_HI) + (counter-constancy CT ARG_1_LO) + (counter-constancy CT ARG_2_HI) + (counter-constancy CT ARG_2_LO) + (counter-constancy CT RES_HI) + (counter-constancy CT RES_LO) + (counter-constancy CT INST) + (counter-constancy CT CT_MAX) + (counter-constancy CT PIVOT) + (counter-constancy CT BIT_B_4) + (counter-constancy CT LOW_4) + (counter-constancy CT NEG) + (counter-constancy CT SMALL))) -(defconstraint ct-small () (- 1 (~ (- COUNTER 16)))) +;; 2.6 byte decompositions +(defconstraint byte_decompositions () + (begin (byte-decomposition CT ACC_1 BYTE_1) + (byte-decomposition CT ACC_2 BYTE_2) + (byte-decomposition CT ACC_3 BYTE_3) + (byte-decomposition CT ACC_4 BYTE_4) + (byte-decomposition CT ACC_5 BYTE_5) + (byte-decomposition CT ACC_6 BYTE_6))) -(defconstraint new-stamp-reset-ct () (if (- (shift STAMP 1) STAMP) 0 (shift COUNTER 1))) +;; 2.7 target constraints +(defconstraint target-constraints () + (if-eq CT CT_MAX + (begin (eq! ACC_1 ARG_1_HI) + (eq! ACC_2 ARG_1_LO) + (eq! ACC_3 ARG_2_HI) + (eq! ACC_4 ARG_2_LO) + (eq! ACC_5 RES_HI) + (eq! ACC_6 RES_LO)))) -(defconstraint last-row (:domain {-1}) (- COUNTER CT_MAX)) +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.8 binary column constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; 2.8.2 BITS and related columns +(defconstraint bits-and-related (:guard (+ IS_BYTE IS_SIGNEXTEND)) + (if-eq CT LLARGEMO + (begin (eq! PIVOT + (+ (* 128 (shift BITS -15)) + (* 64 (shift BITS -14)) + (* 32 (shift BITS -13)) + (* 16 (shift BITS -12)) + (* 8 (shift BITS -11)) + (* 4 (shift BITS -10)) + (* 2 (shift BITS -9)) + (shift BITS -8))) + (eq! BYTE_2 + (+ (* 128 (shift BITS -7)) + (* 64 (shift BITS -6)) + (* 32 (shift BITS -5)) + (* 16 (shift BITS -4)) + (* 8 (shift BITS -3)) + (* 4 (shift BITS -2)) + (* 2 (shift BITS -1)) + BITS)) + (eq! LOW_4 + (+ (* 8 (shift BITS -3)) + (* 4 (shift BITS -2)) + (* 2 (shift BITS -1)) + BITS)) + (eq! BIT_B_4 (shift BITS -4)) + (eq! NEG (shift BITS -15))))) -(defconstraint first-row (:domain {0}) STAMP) +;; 2.8.3 [[1]] constraints +;; (defconstraint bit_1 (:guard CT_MAX) +;; (begin (if-eq IS_BYTE 1 (plateau-constraint CT BIT_1 LOW_4)) +;; (if-eq IS_SIGNEXTEND 1 +;; (plateau-constraint CT BIT_1 (- LLARGEMO LOW_4))))) + +;; 2.8.4 SMALL constraints +(defconstraint small (:guard (+ IS_BYTE IS_SIGNEXTEND)) + (if-eq CT LLARGEMO + (if-zero ARG_1_HI + (if-eq-else ARG_1_LO (+ (* 16 (shift BITS -4)) + (* 8 (shift BITS -3)) + (* 4 (shift BITS -2)) + (* 2 (shift BITS -1)) + BITS) + (eq! SMALL 1) + (vanishes! SMALL))))) + +;; 2.9 pivot constraints +(defconstraint pivot (:guard CT_MAX) + (begin (if-eq IS_BYTE 1 + (if-zero-else LOW_4 + (if-zero CT + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_3) + (eq! PIVOT BYTE_4))) + (if-zero (+ (prev BIT_1) (- 1 BIT_1)) + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_3) + (eq! PIVOT BYTE_4))))) + (if-eq IS_SIGNEXTEND 1 + (if-eq-else LOW_4 LLARGEMO + (if-zero CT + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_4) + (eq! PIVOT BYTE_3))) + (if-zero (+ (prev BIT_1) (- 1 BIT_1)) + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_4) + (eq! PIVOT BYTE_3))))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.10 result constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defconstraint is-byte-result (:guard IS_BYTE) + (if-zero-else CT_MAX + (begin (vanishes! RES_HI) + (vanishes! RES_LO)) + (begin (vanishes! RES_HI) + (eq! RES_LO (* SMALL PIVOT))))) + +(defconstraint is-signextend-result (:guard IS_SIGNEXTEND) + (if-zero-else CT_MAX + (begin (eq! RES_HI ARG_2_HI) + (eq! RES_LO ARG_2_LO)) + (if-zero-else SMALL + ;; SMALL == 0 + (begin (eq! RES_HI ARG_2_HI) + (eq! RES_LO ARG_2_LO)) + ;; SMALL == 1 + (begin (if-zero-else BIT_B_4 + ;; b4 == 0 + (begin (eq! BYTE_5 (* NEG 255)) + (if-zero-else BIT_1 + ;; [[1]] == 0 + (eq! BYTE_6 (* NEG 255)) + ;; [[1]] == 1 + (eq! BYTE_6 BYTE_4))) + ;; b4 == 1 + (begin (if-zero-else BIT_1 + ;; [[1]] == 0 + (eq! BYTE_5 (* NEG 255)) + ;; [[1]] == 1 + (eq! BYTE_5 BYTE_3)) + (eq! RES_LO ARG_2_LO))))))) + +(defconstraint result-via-lookup (:guard (+ IS_AND IS_OR IS_XOR IS_NOT)) + (begin (eq! BYTE_5 XXX_BYTE_HI) + (eq! BYTE_6 XXX_BYTE_LO))) diff --git a/testdata/bin-static.lisp b/testdata/bin-static.lisp index ca69c33..24e60a5 100644 --- a/testdata/bin-static.lisp +++ b/testdata/bin-static.lisp @@ -41,45 +41,244 @@ (XXX_BYTE_HI :byte) (XXX_BYTE_LO :byte)) +;; aliases +(defalias + OLI ONE_LINE_INSTRUCTION + CT COUNTER + ARG_1_HI ARGUMENT_1_HI + ARG_1_LO ARGUMENT_1_LO + ARG_2_HI ARGUMENT_2_HI + ARG_2_LO ARGUMENT_2_LO + RES_HI RESULT_HI + RES_LO RESULT_LO) -(defconstraint byte_decompositions () (begin (if COUNTER (- ACC_1 BYTE_1) (- ACC_1 (+ (* 256 (shift ACC_1 -1)) BYTE_1))) (if COUNTER (- ACC_2 BYTE_2) (- ACC_2 (+ (* 256 (shift ACC_2 -1)) BYTE_2))) (if COUNTER (- ACC_3 BYTE_3) (- ACC_3 (+ (* 256 (shift ACC_3 -1)) BYTE_3))) (if COUNTER (- ACC_4 BYTE_4) (- ACC_4 (+ (* 256 (shift ACC_4 -1)) BYTE_4))) (if COUNTER (- ACC_5 BYTE_5) (- ACC_5 (+ (* 256 (shift ACC_5 -1)) BYTE_5))) (if COUNTER (- ACC_6 BYTE_6) (- ACC_6 (+ (* 256 (shift ACC_6 -1)) BYTE_6))))) +(defconst + ;; opcode values + SIGNEXTEND 11 + AND 22 + OR 23 + XOR 24 + NOT 25 + BYTE 26 + ;; constant values + LLARGE 16 + LLARGEMO 15) -(defconstraint bits-and-related () (if (- COUNTER 15) (begin (- PIVOT (+ (* 128 (shift BITS -15)) (* 64 (shift BITS -14)) (* 32 (shift BITS -13)) (* 16 (shift BITS -12)) (* 8 (shift BITS -11)) (* 4 (shift BITS -10)) (* 2 (shift BITS -9)) (shift BITS -8))) (- BYTE_2 (+ (* 128 (shift BITS -7)) (* 64 (shift BITS -6)) (* 32 (shift BITS -5)) (* 16 (shift BITS -4)) (* 8 (shift BITS -3)) (* 4 (shift BITS -2)) (* 2 (shift BITS -1)) BITS)) (- LOW_4 (+ (* 8 (shift BITS -3)) (* 4 (shift BITS -2)) (* 2 (shift BITS -1)) BITS)) (- BIT_B_4 (shift BITS -4)) (- NEG (shift BITS -15))))) +(defpurefun (if-eq-else A B THEN ELSE) + (if-zero-else (- A B) + THEN + ELSE)) -(defconstraint pivot () (if MLI 0 (begin (if IS_BYTE 0 (if LOW_4 (if COUNTER (if BIT_B_4 (- PIVOT BYTE_3) (- PIVOT BYTE_4))) (if (+ (shift BIT_1 -1) (- 1 BIT_1)) (if BIT_B_4 (- PIVOT BYTE_3) (- PIVOT BYTE_4))))) (if IS_SIGNEXTEND 0 (if (- LOW_4 15) (if COUNTER (if BIT_B_4 (- PIVOT BYTE_4) (- PIVOT BYTE_3))) (if (+ (shift BIT_1 -1) (- 1 BIT_1)) (if BIT_B_4 (- PIVOT BYTE_4) (- PIVOT BYTE_3)))))))) +;; 2.1 binary constraints +;; binary constraints +(defconstraint binary_constraints () + (begin (is-binary IS_AND) + (is-binary IS_OR) + (is-binary IS_XOR) + (is-binary IS_NOT) + (is-binary IS_BYTE) + (is-binary IS_SIGNEXTEND) + (is-binary SMALL) + (is-binary BITS) + (is-binary NEG) + (is-binary BIT_B_4) + (is-binary BIT_1))) -(defconstraint bit_1 () (begin (if (- IS_BYTE 1) (begin (if LOW_4 (- BIT_1 1) (if (- COUNTER 0) BIT_1 (if (- COUNTER LOW_4) (- BIT_1 (+ (shift BIT_1 -1) 1)) (- BIT_1 (shift BIT_1 -1))))))) (if (- IS_SIGNEXTEND 1) (begin (if (- 15 LOW_4) (- BIT_1 1) (if (- COUNTER 0) BIT_1 (if (- COUNTER (- 15 LOW_4)) (- BIT_1 (+ (shift BIT_1 -1) 1)) (- BIT_1 (shift BIT_1 -1))))))))) +;; 2.2 Shorthands +(defun (flag-sum) + (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND)) -(defconstraint binary_constraints () (begin (* IS_AND (- 1 IS_AND)) (* IS_OR (- 1 IS_OR)) (* IS_XOR (- 1 IS_XOR)) (* IS_NOT (- 1 IS_NOT)) (* IS_BYTE (- 1 IS_BYTE)) (* IS_SIGNEXTEND (- 1 IS_SIGNEXTEND)) (* SMALL (- 1 SMALL)) (* BITS (- 1 BITS)) (* NEG (- 1 NEG)) (* BIT_B_4 (- 1 BIT_B_4)) (* BIT_1 (- 1 BIT_1)))) +(defun (weight-sum) + (+ (* IS_AND AND) + (* IS_OR OR) + (* IS_XOR XOR) + (* IS_NOT NOT) + (* IS_BYTE BYTE) + (* IS_SIGNEXTEND SIGNEXTEND))) -(defconstraint counter-constancies () (begin (if COUNTER 0 (- ARGUMENT_1_HI (shift ARGUMENT_1_HI -1))) (if COUNTER 0 (- ARGUMENT_1_LO (shift ARGUMENT_1_LO -1))) (if COUNTER 0 (- ARGUMENT_2_HI (shift ARGUMENT_2_HI -1))) (if COUNTER 0 (- ARGUMENT_2_LO (shift ARGUMENT_2_LO -1))) (if COUNTER 0 (- RESULT_HI (shift RESULT_HI -1))) (if COUNTER 0 (- RESULT_LO (shift RESULT_LO -1))) (if COUNTER 0 (- INST (shift INST -1))) (if COUNTER 0 (- PIVOT (shift PIVOT -1))) (if COUNTER 0 (- BIT_B_4 (shift BIT_B_4 -1))) (if COUNTER 0 (- LOW_4 (shift LOW_4 -1))) (if COUNTER 0 (- NEG (shift NEG -1))))) +;; 2.3 Instruction decoding +(defconstraint no-bin-no-flag () + (if-zero-else STAMP + (vanishes! (flag-sum)) + (eq! (flag-sum) 1))) -(defconstraint is-signextend-result () (if IS_SIGNEXTEND 0 (if (- ONE_LINE_INSTRUCTION 1) (begin (- RESULT_HI ARGUMENT_2_HI) (- RESULT_LO ARGUMENT_2_LO)) (if SMALL (begin (- RESULT_HI ARGUMENT_2_HI) (- RESULT_LO ARGUMENT_2_LO)) (begin (if BIT_B_4 (begin (- BYTE_5 (* NEG 255)) (if BIT_1 (- BYTE_6 (* NEG 255)) (- BYTE_6 BYTE_4))) (begin (if BIT_1 (- BYTE_5 (* NEG 255)) (- BYTE_5 BYTE_3)) (- RESULT_LO ARGUMENT_2_LO)))))))) +(defconstraint inst-to-flag () + (eq! INST (weight-sum))) -(defconstraint small () (if (- COUNTER 15) (if ARGUMENT_1_HI (if (- ARGUMENT_1_LO (+ (* 16 (shift BITS -4)) (* 8 (shift BITS -3)) (* 4 (shift BITS -2)) (* 2 (shift BITS -1)) BITS)) (- SMALL 1) SMALL)))) +;; 2.4 Heartbeat +(defconstraint first-row (:domain {0}) + (vanishes! STAMP)) -(defconstraint inst-to-flag () (- INST (+ (* IS_AND 22) (* IS_OR 23) (* IS_XOR 24) (* IS_NOT 25) (* IS_BYTE 26) (* IS_SIGNEXTEND 11)))) +(defconstraint stamp-increments () + (vanishes! (* (will-inc! STAMP 0) (will-inc! STAMP 1)))) -(defconstraint target-constraints () (if (- COUNTER 15) (begin (- ACC_1 ARGUMENT_1_HI) (- ACC_2 ARGUMENT_1_LO) (- ACC_3 ARGUMENT_2_HI) (- ACC_4 ARGUMENT_2_LO) (- ACC_5 RESULT_HI) (- ACC_6 RESULT_LO)))) +(defconstraint countereset () + (if-not-zero (will-remain-constant! STAMP) + (vanishes! (next CT)))) -(defconstraint mli-incrementation () (if MLI 0 (if (- COUNTER 15) (- (shift STAMP 1) (+ STAMP 1)) (- (shift COUNTER 1) (+ COUNTER 1))))) +(defconstraint oli-incrementation (:guard OLI) + (will-inc! STAMP 1)) -(defconstraint stamp-increments () (* (- (shift STAMP 1) (+ STAMP 0)) (- (shift STAMP 1) (+ STAMP 1)))) +(defconstraint mli-incrementation (:guard MLI) + (if-eq-else CT LLARGEMO (will-inc! STAMP 1) (will-inc! CT 1))) -(defconstraint is-byte-result () (if IS_BYTE 0 (if (- ONE_LINE_INSTRUCTION 1) (begin RESULT_HI RESULT_LO) (begin RESULT_HI (- RESULT_LO (* SMALL PIVOT)))))) +(defconstraint last-row (:domain {-1}) + (if-eq MLI 1 (eq! CT LLARGEMO))) -(defconstraint no-bin-no-flag () (if STAMP (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND) (- (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND) 1))) +(defconstraint counter-constancies () + (begin (counter-constancy CT ARG_1_HI) + (counter-constancy CT ARG_1_LO) + (counter-constancy CT ARG_2_HI) + (counter-constancy CT ARG_2_LO) + (counter-constancy CT RES_HI) + (counter-constancy CT RES_LO) + (counter-constancy CT INST) + (counter-constancy CT PIVOT) + (counter-constancy CT BIT_B_4) + (counter-constancy CT LOW_4) + (counter-constancy CT NEG))) -(defconstraint set-oli-mli () (if (+ IS_BYTE IS_SIGNEXTEND) ONE_LINE_INSTRUCTION (if ARGUMENT_1_HI ONE_LINE_INSTRUCTION (- ONE_LINE_INSTRUCTION 1)))) +;; 2.6 byte decompositions +(defconstraint byte_decompositions () + (begin (byte-decomposition CT ACC_1 BYTE_1) + (byte-decomposition CT ACC_2 BYTE_2) + (byte-decomposition CT ACC_3 BYTE_3) + (byte-decomposition CT ACC_4 BYTE_4) + (byte-decomposition CT ACC_5 BYTE_5) + (byte-decomposition CT ACC_6 BYTE_6))) -(defconstraint result-via-deflookup () (if (+ IS_AND IS_OR IS_XOR IS_NOT) 0 (begin (- BYTE_5 XXX_BYTE_HI) (- BYTE_6 XXX_BYTE_LO)))) +;; 2.7 target constraints +(defconstraint target-constraints () + (if-eq CT LLARGEMO + (begin (eq! ACC_1 ARG_1_HI) + (eq! ACC_2 ARG_1_LO) + (eq! ACC_3 ARG_2_HI) + (eq! ACC_4 ARG_2_LO) + (eq! ACC_5 RES_HI) + (eq! ACC_6 RES_LO)))) -(defconstraint oli-incrementation () (if ONE_LINE_INSTRUCTION 0 (- (shift STAMP 1) (+ STAMP 1)))) +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.8 binary column constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defconstraint set-oli-mli () + (if-zero-else (+ IS_BYTE IS_SIGNEXTEND) + (vanishes! OLI) + (if-zero-else ARG_1_HI + (vanishes! OLI) + (eq! OLI 1)))) -(defconstraint last-row (:domain {-1}) (if (- MLI 1) (- COUNTER 15))) +(defconstraint oli-mli-exclusivity () + (eq! (+ OLI MLI) (flag-sum))) -(defconstraint oli-mli-exclusivity () (- (+ ONE_LINE_INSTRUCTION MLI) (+ IS_AND IS_OR IS_XOR IS_NOT IS_BYTE IS_SIGNEXTEND))) +;; 2.8.2 BITS and related columns +(defconstraint bits-and-related () + (if-eq CT LLARGEMO + (begin (eq! PIVOT + (+ (* 128 (shift BITS -15)) + (* 64 (shift BITS -14)) + (* 32 (shift BITS -13)) + (* 16 (shift BITS -12)) + (* 8 (shift BITS -11)) + (* 4 (shift BITS -10)) + (* 2 (shift BITS -9)) + (shift BITS -8))) + (eq! BYTE_2 + (+ (* 128 (shift BITS -7)) + (* 64 (shift BITS -6)) + (* 32 (shift BITS -5)) + (* 16 (shift BITS -4)) + (* 8 (shift BITS -3)) + (* 4 (shift BITS -2)) + (* 2 (shift BITS -1)) + BITS)) + (eq! LOW_4 + (+ (* 8 (shift BITS -3)) + (* 4 (shift BITS -2)) + (* 2 (shift BITS -1)) + BITS)) + (eq! BIT_B_4 (shift BITS -4)) + (eq! NEG (shift BITS -15))))) -(defconstraint countereset () (if (- (shift STAMP 1) STAMP) 0 (shift COUNTER 1))) +;; 2.8.3 [[1]] constraints +;; (defconstraint bit_1 () +;; (begin (if-eq IS_BYTE 1 (plateau-constraint CT BIT_1 LOW_4)) +;; (if-eq IS_SIGNEXTEND 1 +;; (plateau-constraint CT BIT_1 (- LLARGEMO LOW_4))))) -(defconstraint first-row (:domain {0}) STAMP) +;; 2.8.4 SMALL constraints +(defconstraint small () + (if-eq CT LLARGEMO + (if-zero ARG_1_HI + (if-eq-else ARG_1_LO (+ (* 16 (shift BITS -4)) + (* 8 (shift BITS -3)) + (* 4 (shift BITS -2)) + (* 2 (shift BITS -1)) + BITS) + (eq! SMALL 1) + (vanishes! SMALL))))) + +;; 2.9 pivot constraints +(defconstraint pivot (:guard MLI) + (begin (if-not-zero IS_BYTE + (if-zero-else LOW_4 + (if-zero CT + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_3) + (eq! PIVOT BYTE_4))) + (if-zero (+ (prev BIT_1) (- 1 BIT_1)) + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_3) + (eq! PIVOT BYTE_4))))) + (if-not-zero IS_SIGNEXTEND + (if-eq-else LOW_4 LLARGEMO + (if-zero CT + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_4) + (eq! PIVOT BYTE_3))) + (if-zero (+ (prev BIT_1) (- 1 BIT_1)) + (if-zero-else BIT_B_4 + (eq! PIVOT BYTE_4) + (eq! PIVOT BYTE_3))))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.10 result constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defconstraint is-byte-result (:guard IS_BYTE) + (if-eq-else OLI 1 + (begin (vanishes! RES_HI) + (vanishes! RES_LO)) + (begin (vanishes! RES_HI) + (eq! RES_LO (* SMALL PIVOT))))) + +(defconstraint is-signextend-result (:guard IS_SIGNEXTEND) + (if-eq-else OLI 1 + (begin (eq! RES_HI ARG_2_HI) + (eq! RES_LO ARG_2_LO)) + (if-zero-else SMALL + ;; SMALL == 0 + (begin (eq! RES_HI ARG_2_HI) + (eq! RES_LO ARG_2_LO)) + ;; SMALL == 1 + (begin (if-zero-else BIT_B_4 + ;; b4 == 0 + (begin (eq! BYTE_5 (* NEG 255)) + (if-zero-else BIT_1 + ;; [[1]] == 0 + (eq! BYTE_6 (* NEG 255)) + ;; [[1]] == 1 + (eq! BYTE_6 BYTE_4))) + ;; b4 == 1 + (begin (if-zero-else BIT_1 + ;; [[1]] == 0 + (eq! BYTE_5 (* NEG 255)) + ;; [[1]] == 1 + (eq! BYTE_5 BYTE_3)) + (eq! RES_LO ARG_2_LO))))))) + +(defconstraint result-via-lookup (:guard (+ IS_AND IS_OR IS_XOR IS_NOT)) + (begin (eq! BYTE_5 XXX_BYTE_HI) + (eq! BYTE_6 XXX_BYTE_LO))) diff --git a/testdata/mxp.lisp b/testdata/mxp.lisp index b4c8b12..d6c370e 100644 --- a/testdata/mxp.lisp +++ b/testdata/mxp.lisp @@ -1,131 +1,460 @@ (module mxp) (defcolumns - (STAMP :i32) - (CN :i64) - (CT :i5) - (ROOB :binary@prove) - (NOOP :binary@prove) - (MXPX :binary@prove) - (INST :byte) - (MXP_TYPE_1 :binary@prove) - (MXP_TYPE_2 :binary@prove) - (MXP_TYPE_3 :binary@prove) - (MXP_TYPE_4 :binary@prove) - (MXP_TYPE_5 :binary@prove) - (GBYTE :i64) - (GWORD :i64) - (DEPLOYS :binary@prove) - (OFFSET_1_LO :i128) - (OFFSET_2_LO :i128) - (OFFSET_1_HI :i128) - (OFFSET_2_HI :i128) - (SIZE_1_LO :i128) - (SIZE_2_LO :i128) - (SIZE_1_HI :i128) - (SIZE_2_HI :i128) - (MAX_OFFSET_1 :i128) - (MAX_OFFSET_2 :i128) - (MAX_OFFSET :i128) - (COMP :binary@prove) - (BYTE_1 :byte@prove) - (BYTE_2 :byte@prove) - (BYTE_3 :byte@prove) - (BYTE_4 :byte@prove) - (BYTE_A :byte@prove) - (BYTE_W :byte@prove) - (BYTE_Q :byte@prove) - (ACC_1 :i136) - (ACC_2 :i136) - (ACC_3 :i136) - (ACC_4 :i136) - (ACC_A :i136) - (ACC_W :i136) - (ACC_Q :i136) - (BYTE_QQ :byte@prove) - (BYTE_R :byte@prove) - (WORDS :i64) - (WORDS_NEW :i64) - (C_MEM :i64) - (C_MEM_NEW :i64) - (QUAD_COST :i64) - (LIN_COST :i64) - (GAS_MXP :i64) - (EXPANDS :binary@prove) - (MTNTOP :binary@prove)) + (STAMP :i32) + (CN :i64) + (CT :i5) + (ROOB :binary@prove) + (NOOP :binary@prove) + (MXPX :binary@prove) + (INST :byte :display :opcode) + (MXP_TYPE :binary@prove :array [5]) + (GBYTE :i64) + (GWORD :i64) + (DEPLOYS :binary@prove) + (OFFSET_1_LO :i128) + (OFFSET_2_LO :i128) + (OFFSET_1_HI :i128) + (OFFSET_2_HI :i128) + (SIZE_1_LO :i128) + (SIZE_2_LO :i128) + (SIZE_1_HI :i128) + (SIZE_2_HI :i128) + (MAX_OFFSET_1 :i128) + (MAX_OFFSET_2 :i128) + (MAX_OFFSET :i128) + (COMP :binary@prove) + (BYTE :byte@prove :array [4]) + (BYTE_A :byte@prove) + (BYTE_W :byte@prove) + (BYTE_Q :byte@prove) + (ACC :i136 :array [4]) + (ACC_A :i136) + (ACC_W :i136) + (ACC_Q :i136) + (BYTE_QQ :byte@prove) + (BYTE_R :byte@prove) + (WORDS :i64) + (WORDS_NEW :i64) + (C_MEM :i64) + (C_MEM_NEW :i64) + (QUAD_COST :i64) + (LIN_COST :i64) + (GAS_MXP :i64) + (EXPANDS :binary@prove) + (MTNTOP :binary@prove) + (SIZE_1_NONZERO_NO_MXPX :binary) + (SIZE_2_NONZERO_NO_MXPX :binary)) + + (defalias + S1NZNOMXPX SIZE_1_NONZERO_NO_MXPX + S2NZNOMXPX SIZE_2_NONZERO_NO_MXPX) -(defpermutation (CN_perm STAMP_perm C_MEM_perm C_MEM_NEW_perm WORDS_perm WORDS_NEW_perm) ((+ CN) (+ STAMP) (+ C_MEM) (+ C_MEM_NEW) (+ WORDS) (+ WORDS_NEW))) -(defconstraint counter-constancy () (begin (if CT 0 (- INST (shift INST -1))) (if CT 0 (- OFFSET_1_LO (shift OFFSET_1_LO -1))) (if CT 0 (- OFFSET_1_HI (shift OFFSET_1_HI -1))) (if CT 0 (- OFFSET_2_LO (shift OFFSET_2_LO -1))) (if CT 0 (- OFFSET_2_HI (shift OFFSET_2_HI -1))) (if CT 0 (- SIZE_1_LO (shift SIZE_1_LO -1))) (if CT 0 (- SIZE_1_HI (shift SIZE_1_HI -1))) (if CT 0 (- SIZE_2_LO (shift SIZE_2_LO -1))) (if CT 0 (- SIZE_2_HI (shift SIZE_2_HI -1))) (if CT 0 (- WORDS (shift WORDS -1))) (if CT 0 (- WORDS_NEW (shift WORDS_NEW -1))) (if CT 0 (- C_MEM (shift C_MEM -1))) (if CT 0 (- C_MEM_NEW (shift C_MEM_NEW -1))) (if CT 0 (- COMP (shift COMP -1))) (if CT 0 (- MXPX (shift MXPX -1))) (if CT 0 (- EXPANDS (shift EXPANDS -1))) (if CT 0 (- QUAD_COST (shift QUAD_COST -1))) (if CT 0 (- LIN_COST (shift LIN_COST -1))) (if CT 0 (- GAS_MXP (shift GAS_MXP -1))))) -(defconstraint byte-decompositions () (begin (if CT (- ACC_1 BYTE_1) (- ACC_1 (+ (* 256 (shift ACC_1 -1)) BYTE_1))) (if CT (- ACC_2 BYTE_2) (- ACC_2 (+ (* 256 (shift ACC_2 -1)) BYTE_2))) (if CT (- ACC_3 BYTE_3) (- ACC_3 (+ (* 256 (shift ACC_3 -1)) BYTE_3))) (if CT (- ACC_4 BYTE_4) (- ACC_4 (+ (* 256 (shift ACC_4 -1)) BYTE_4))) (if CT (- ACC_A BYTE_A) (- ACC_A (+ (* 256 (shift ACC_A -1)) BYTE_A))) (if CT (- ACC_W BYTE_W) (- ACC_W (+ (* 256 (shift ACC_W -1)) BYTE_W))) (if CT (- ACC_Q BYTE_Q) (- ACC_Q (+ (* 256 (shift ACC_Q -1)) BYTE_Q))))) - -(defconstraint euclidean-division-of-square-of-accA () (if (* (* STAMP (- 1 NOOP ROOB)) (* (* (- 1 (~ (- CT 3))) (- 1 MXPX)) EXPANDS)) 0 (begin (- (* ACC_A ACC_A) (+ (* 512 (+ ACC_Q (+ (* 4294967296 (shift BYTE_QQ -2)) (* 1099511627776 (shift BYTE_QQ -3))))) (+ (* 256 (shift BYTE_QQ -1)) BYTE_QQ))) (* (shift BYTE_QQ -1) (- 1 (shift BYTE_QQ -1)))))) - -(defconstraint setting-c-mem-new () (if (* (* STAMP (- 1 NOOP ROOB)) (* (* (- 1 (~ (- CT 3))) (- 1 MXPX)) EXPANDS)) 0 (- C_MEM_NEW (+ (* 3 ACC_A) (+ ACC_Q (+ (* 4294967296 (shift BYTE_QQ -2)) (* 1099511627776 (shift BYTE_QQ -3)))))))) - -(defconstraint setting-roob-type-5 () (if MXP_TYPE_5 0 (begin (if SIZE_1_HI 0 (- ROOB 1)) (if SIZE_2_HI 0 (- ROOB 1)) (if (* OFFSET_1_HI SIZE_1_LO) 0 (- ROOB 1)) (if (* OFFSET_2_HI SIZE_2_LO) 0 (- ROOB 1)) (if SIZE_1_HI (if SIZE_2_HI (if (* OFFSET_1_HI SIZE_1_LO) (if (* OFFSET_2_HI SIZE_2_LO) ROOB))))))) - -(defconstraint setting-noop () (if ROOB (begin (if (+ MXP_TYPE_1 MXP_TYPE_2 MXP_TYPE_3) 0 (- NOOP MXP_TYPE_1)) (if (- MXP_TYPE_4 1) (- NOOP (- 1 (~ SIZE_1_LO)))) (if (- MXP_TYPE_5 1) (- NOOP (* (- 1 (~ SIZE_1_LO)) (- 1 (~ SIZE_2_LO)))))))) - -(defconstraint non-trivial-instruction-counter-cycle () (if STAMP 0 (if (- 1 (+ ROOB NOOP)) 0 (if MXPX (if (- CT 3) (- (shift STAMP 1) (+ STAMP 1)) (- (shift CT 1) (+ CT 1))) (if (- CT 16) (- (shift STAMP 1) (+ STAMP 1)) (- (shift CT 1) (+ CT 1))))))) - -(defconstraint size-in-evm-words () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (if (- MXP_TYPE_4 1) (begin (- SIZE_1_LO (- (* 32 ACC_W) BYTE_R)) (- (shift BYTE_R -1) (+ 224 BYTE_R)))))) - -(defconstraint comparing-max-offsets-1-and-2 () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (- (+ ACC_3 (- 1 COMP)) (* (- MAX_OFFSET_1 MAX_OFFSET_2) (- (* 2 COMP) 1))))) - -(defconstraint defining-accA () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (begin (- (+ MAX_OFFSET 1) (- (* 32 ACC_A) (shift BYTE_R -2))) (- (shift BYTE_R -3) (+ 224 (shift BYTE_R -2)))))) - -(defconstraint setting-gas-mxp () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (if (- INST 243) (- GAS_MXP (+ QUAD_COST (* DEPLOYS LIN_COST))) (- GAS_MXP (+ QUAD_COST LIN_COST))))) - -(defconstraint mem-expansion-took-place () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (- (+ ACC_4 EXPANDS) (* (- ACC_A WORDS) (- (* 2 EXPANDS) 1))))) - -(defconstraint setting-quad-cost-and-lin-cost () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (begin (- QUAD_COST (- C_MEM_NEW C_MEM)) (- LIN_COST (+ (* GBYTE SIZE_1_LO) (* GWORD ACC_W)))))) - -(defconstraint defining-max-offset () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (- MAX_OFFSET (+ (* COMP MAX_OFFSET_1) (* (- 1 COMP) MAX_OFFSET_2))))) - -(defconstraint max-offsets-1-and-2-type-5 () (if (* STAMP (- 1 NOOP ROOB)) 0 (if (- MXP_TYPE_5 1) (begin (if SIZE_1_LO MAX_OFFSET_1 (- MAX_OFFSET_1 (+ OFFSET_1_LO (- SIZE_1_LO 1)))) (if SIZE_2_LO MAX_OFFSET_2 (- MAX_OFFSET_2 (+ OFFSET_2_LO (- SIZE_2_LO 1)))))))) - -(defconstraint binary-constraints () (begin (* ROOB (- 1 ROOB)) (* NOOP (- 1 NOOP)) (* MXPX (- 1 MXPX)) (* DEPLOYS (- 1 DEPLOYS)) (* COMP (- 1 COMP)) (* EXPANDS (- 1 EXPANDS)))) - -(defconstraint offsets-out-of-bounds () (if (* STAMP (- 1 NOOP ROOB)) 0 (if (- MXPX 1) (if (- CT 16) (* (- (- MAX_OFFSET_1 4294967296) ACC_1) (- (- MAX_OFFSET_2 4294967296) ACC_2)))))) - -(defconstraint no-expansion () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (if EXPANDS (begin (- WORDS_NEW WORDS) (- C_MEM_NEW C_MEM))))) - -(defconstraint max-offsets-1-and-2-are-small () (if (* (* STAMP (- 1 NOOP ROOB)) (* (- 1 (~ (- CT 3))) (- 1 MXPX))) 0 (begin (- ACC_1 MAX_OFFSET_1) (- ACC_2 MAX_OFFSET_2)))) - -(defconstraint setting-words-new () (if (* (* STAMP (- 1 NOOP ROOB)) (* (* (- 1 (~ (- CT 3))) (- 1 MXPX)) EXPANDS)) 0 (- WORDS_NEW ACC_A))) - -(defconstraint setting-roob-type-4 () (if MXP_TYPE_4 0 (begin (if SIZE_1_HI 0 (- ROOB 1)) (if (* OFFSET_1_HI SIZE_1_LO) 0 (- ROOB 1)) (if SIZE_1_HI (if (* OFFSET_1_HI SIZE_1_LO) ROOB))))) - -(defconstraint max-offsets-1-and-2-type-4 () (if (* STAMP (- 1 NOOP ROOB)) 0 (if (- MXP_TYPE_4 1) (begin (- MAX_OFFSET_1 (+ OFFSET_1_LO (- SIZE_1_LO 1))) MAX_OFFSET_2)))) - -(defconstraint max-offsets-1-and-2-type-2 () (if (* STAMP (- 1 NOOP ROOB)) 0 (if (- MXP_TYPE_2 1) (begin (- MAX_OFFSET_1 (+ OFFSET_1_LO 31)) MAX_OFFSET_2)))) - -(defconstraint consistency () (if CN_perm 0 (if (- (shift CN_perm -1) CN_perm) (if (- (shift STAMP_perm -1) STAMP_perm) 0 (begin (- WORDS_perm (shift WORDS_NEW_perm -1)) (- C_MEM_perm (shift C_MEM_NEW_perm -1)))) (begin WORDS_perm C_MEM_perm)))) - -(defconstraint type-flag-sum () (if STAMP 0 (- 1 (+ MXP_TYPE_1 (+ MXP_TYPE_2 (+ MXP_TYPE_3 (+ MXP_TYPE_5 MXP_TYPE_4))))))) - -(defconstraint max-offsets-1-and-2-type-3 () (if (* STAMP (- 1 NOOP ROOB)) 0 (if (- MXP_TYPE_3 1) (begin (- MAX_OFFSET_1 OFFSET_1_LO) MAX_OFFSET_2)))) - -(defconstraint stamp-increment-when-roob-or-noop () (if (+ ROOB NOOP) 0 (begin (- (shift STAMP 1) (+ STAMP 1)) (- MXPX ROOB)))) - -(defconstraint final-row (:domain {-1}) (if STAMP 0 (if (+ ROOB NOOP) (- CT (if MXPX 3 16))))) - -(defconstraint setting-roob-type-2-3 () (if (+ MXP_TYPE_2 MXP_TYPE_3) 0 (if OFFSET_1_HI ROOB (- ROOB 1)))) - -(defconstraint setting-mtntop () (if MXP_TYPE_4 MTNTOP (begin (if MXPX (if SIZE_1_LO MTNTOP (- MTNTOP 1)) MTNTOP)))) - -(defconstraint stamp-increments () (* (- (shift STAMP 1) STAMP) (- (shift STAMP 1) (+ STAMP 1)))) - -(defconstraint noop-consequences () (if NOOP 0 (begin QUAD_COST LIN_COST (- WORDS_NEW WORDS) (- C_MEM_NEW C_MEM)))) - -(defconstraint automatic-vanishing-when-padding () (if STAMP (begin (+ ROOB NOOP MXPX) CT INST))) +(module mxp) -(defconstraint counter-reset () (if (- (shift STAMP 1) STAMP) 0 (shift CT 1))) +(defconst + CT_MAX_TRIVIAL 0 + CT_MAX_NON_TRIVIAL 3 + CT_MAX_NON_TRIVIAL_BUT_MXPX 16 + TWO_POW_32 4294967296) -(defconstraint setting-roob-type-1 () (if MXP_TYPE_1 0 ROOB)) -(defconstraint noop-automatic-vanishing () (if ROOB 0 NOOP)) +(module mxp) -(defconstraint first-row (:domain {0}) STAMP) +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.1 binary constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +;; done with binary@prove in columns.lisp + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.2 counter constancy ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint counter-constancy () + (begin (counter-constancy CT CN) + (counter-constancy CT INST) + (counter-constancy CT DEPLOYS) + (counter-constancy CT OFFSET_1_LO) + (counter-constancy CT OFFSET_1_HI) + (counter-constancy CT OFFSET_2_LO) + (counter-constancy CT OFFSET_2_HI) + (counter-constancy CT SIZE_1_LO) + (counter-constancy CT SIZE_1_HI) + (counter-constancy CT SIZE_2_LO) + (counter-constancy CT SIZE_2_HI) + (counter-constancy CT WORDS) + (counter-constancy CT WORDS_NEW) + (counter-constancy CT C_MEM) + (counter-constancy CT C_MEM_NEW) + (counter-constancy CT COMP) + (counter-constancy CT MXPX) + (counter-constancy CT EXPANDS) + (counter-constancy CT QUAD_COST) + (counter-constancy CT LIN_COST) + (counter-constancy CT GAS_MXP))) + +;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.3 ROOB flag ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint setting-roob-type-1 (:guard [MXP_TYPE 1]) + (vanishes! ROOB)) + +(defconstraint setting-roob-type-2-3 (:guard (+ [MXP_TYPE 2] [MXP_TYPE 3])) + (if-not-zero OFFSET_1_HI + (eq! ROOB 1) + (vanishes! ROOB))) + +(defconstraint setting-roob-type-4 (:guard [MXP_TYPE 4]) + (begin (if-not-zero SIZE_1_HI + (eq! ROOB 1)) + (if-not-zero (* OFFSET_1_HI SIZE_1_LO) + (eq! ROOB 1)) + (if-zero SIZE_1_HI + (if-zero (* OFFSET_1_HI SIZE_1_LO) + (vanishes! ROOB))))) + +(defconstraint setting-roob-type-5 (:guard [MXP_TYPE 5]) + (begin (if-not-zero SIZE_1_HI + (eq! ROOB 1)) + (if-not-zero SIZE_2_HI + (eq! ROOB 1)) + (if-not-zero (* OFFSET_1_HI SIZE_1_LO) + (eq! ROOB 1)) + (if-not-zero (* OFFSET_2_HI SIZE_2_LO) + (eq! ROOB 1)) + (if-zero SIZE_1_HI + (if-zero SIZE_2_HI + (if-zero (* OFFSET_1_HI SIZE_1_LO) + (if-zero (* OFFSET_2_HI SIZE_2_LO) + (vanishes! ROOB))))))) + +;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.4 NOOP flag ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint noop-automatic-vanishing () + (if-not-zero ROOB + (vanishes! NOOP))) + +(defconstraint setting-noop () + (if-zero ROOB + (begin (if-not-zero (+ [MXP_TYPE 1] [MXP_TYPE 2] [MXP_TYPE 3]) + (eq! NOOP [MXP_TYPE 1])) + (if-eq [MXP_TYPE 4] 1 + (eq! NOOP (is-zero SIZE_1_LO))) + (if-eq [MXP_TYPE 5] 1 + (eq! NOOP + (* (is-zero SIZE_1_LO) (is-zero SIZE_2_LO))))))) + +(defconstraint noop-consequences (:guard NOOP) + (begin (vanishes! QUAD_COST) + (vanishes! LIN_COST) + (= WORDS_NEW WORDS) + (= C_MEM_NEW C_MEM))) + +;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.5 MTNTOP ;; +;; ;; +;;;;;;;;;;;;;;;;;;;; + +(defconstraint setting-mtntop () + (begin + (debug (is-binary MTNTOP)) + (debug (if-zero [MXP_TYPE 4] + (vanishes! MTNTOP))) + (if-not-zero MXPX + (vanishes! MTNTOP)) + (if-not-zero [MXP_TYPE 4] + (if-zero MXPX + (if-zero SIZE_1_LO + (vanishes! MTNTOP) + (eq! MTNTOP 1)))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.6 The S1NZNOMXPX and S2NZNOMXPX flags ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint setting-s1nznomp-s2nznomp () + (begin + (debug (is-binary S1NZNOMXPX)) + (debug (is-binary S2NZNOMXPX)) + (debug (counter-constancy CT S1NZNOMXPX)) + (debug (counter-constancy CT S2NZNOMXPX)) + (if-not-zero MXPX + (begin (vanishes! S1NZNOMXPX) + (vanishes! S2NZNOMXPX)) + (begin (if-not-zero SIZE_1_LO + (eq! S1NZNOMXPX 1)) + (if-not-zero SIZE_1_HI + (eq! S1NZNOMXPX 1)) + (if-zero SIZE_1_LO + (if-zero SIZE_1_HI + (vanishes! S1NZNOMXPX))) + (if-not-zero SIZE_2_LO + (eq! S2NZNOMXPX 1)) + (if-not-zero SIZE_2_HI + (eq! S2NZNOMXPX 1)) + (if-zero SIZE_2_LO + (if-zero SIZE_2_HI + (vanishes! S2NZNOMXPX))))))) + +;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.7 heartbeat ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint first-row (:domain {0}) + (vanishes! STAMP)) + +(defconstraint stamp-increments () + (any! (will-remain-constant! STAMP) (will-inc! STAMP 1))) + +(defconstraint automatic-vanishing-when-padding () + (if-zero STAMP + (begin (vanishes! (+ ROOB NOOP MXPX)) + (vanishes! CT) + (vanishes! INST)))) + +;; (defconstraint type-flag-sum (:guard STAMP) +;; (eq! 1 +;; (reduce + (for i [5] [MXP_TYPE i])))) + +(defconstraint counter-reset () + (if-not-zero (will-remain-constant! STAMP) + (vanishes! (next CT)))) + +(defconstraint stamp-increment-when-roob-or-noop () + (if-not-zero (+ ROOB NOOP) + (begin (will-inc! STAMP 1) + (eq! MXPX ROOB)))) + +(defconstraint non-trivial-instruction-counter-cycle () + (if-not-zero STAMP + ;; ROOB + NOOP is binary + (if-not-zero (- 1 (+ ROOB NOOP)) + (if-zero MXPX + (if-eq-else CT CT_MAX_NON_TRIVIAL + (will-inc! STAMP 1) + (will-inc! CT 1)) + (if-eq-else CT CT_MAX_NON_TRIVIAL_BUT_MXPX + (will-inc! STAMP 1) + (will-inc! CT 1)))))) + +(defconstraint final-row (:domain {-1}) + (if-not-zero STAMP + (if-zero (force-bool (+ ROOB NOOP)) + (eq! CT (if-zero MXPX + CT_MAX_NON_TRIVIAL + CT_MAX_NON_TRIVIAL_BUT_MXPX))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.8 Byte decompositions ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint byte-decompositions () + (begin (for k [1:4] (byte-decomposition CT [ACC k] [BYTE k])) + (byte-decomposition CT ACC_A BYTE_A) + (byte-decomposition CT ACC_W BYTE_W) + (byte-decomposition CT ACC_Q BYTE_Q))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; Specialized constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defun (standing-hypothesis) + (* STAMP (- 1 NOOP ROOB))) ;; NOOP + ROOB is binary cf noop section + +;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 3.1 Max offsets ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint max-offsets-1-and-2-type-2 (:guard (standing-hypothesis)) + (if-eq [MXP_TYPE 2] 1 + (begin (eq! MAX_OFFSET_1 (+ OFFSET_1_LO 31)) + (vanishes! MAX_OFFSET_2)))) + +(defconstraint max-offsets-1-and-2-type-3 (:guard (standing-hypothesis)) + (if-eq [MXP_TYPE 3] 1 + (begin (eq! MAX_OFFSET_1 OFFSET_1_LO) + (vanishes! MAX_OFFSET_2)))) + +(defconstraint max-offsets-1-and-2-type-4 (:guard (standing-hypothesis)) + (if-eq [MXP_TYPE 4] 1 + (begin (eq! MAX_OFFSET_1 + (+ OFFSET_1_LO (- SIZE_1_LO 1))) + (vanishes! MAX_OFFSET_2)))) + +(defconstraint max-offsets-1-and-2-type-5 (:guard (standing-hypothesis)) + (if-eq [MXP_TYPE 5] 1 + (begin (if-zero SIZE_1_LO + (vanishes! MAX_OFFSET_1) + (eq! MAX_OFFSET_1 + (+ OFFSET_1_LO (- SIZE_1_LO 1)))) + (if-zero SIZE_2_LO + (vanishes! MAX_OFFSET_2) + (eq! MAX_OFFSET_2 + (+ OFFSET_2_LO (- SIZE_2_LO 1))))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 3.2 Offsets are out of bounds ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint offsets-out-of-bounds (:guard (standing-hypothesis)) + (if-eq MXPX 1 + (if-eq CT CT_MAX_NON_TRIVIAL_BUT_MXPX + (vanishes! (* (- (- MAX_OFFSET_1 TWO_POW_32) [ACC 1]) + (- (- MAX_OFFSET_2 TWO_POW_32) [ACC 2])))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 3.3 Offsets are in bounds ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defun (offsets-are-in-bounds) + (* (is-zero (- CT CT_MAX_NON_TRIVIAL)) + (- 1 MXPX))) + +(defconstraint size-in-evm-words (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (if-eq [MXP_TYPE 4] 1 + (begin (eq! SIZE_1_LO + (- (* 32 ACC_W) BYTE_R)) + (eq! (prev BYTE_R) + (+ (- 256 32) BYTE_R))))) + +(defconstraint max-offsets-1-and-2-are-small (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (begin (eq! [ACC 1] MAX_OFFSET_1) + (eq! [ACC 2] MAX_OFFSET_2))) + +(defconstraint comparing-max-offsets-1-and-2 (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (eq! (+ [ACC 3] (- 1 COMP)) + (* (- MAX_OFFSET_1 MAX_OFFSET_2) + (- (* 2 COMP) 1)))) + +(defconstraint defining-max-offset (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (eq! MAX_OFFSET + (+ (* COMP MAX_OFFSET_1) + (* (- 1 COMP) MAX_OFFSET_2)))) + +(defconstraint defining-accA (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (begin (eq! (+ MAX_OFFSET 1) + (- (* 32 ACC_A) (shift BYTE_R -2))) + (eq! (shift BYTE_R -3) + (+ (- 256 32) (shift BYTE_R -2))))) + +(defconstraint mem-expansion-took-place (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (eq! (+ [ACC 4] EXPANDS) + (* (- ACC_A WORDS) + (- (* 2 EXPANDS) 1)))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 3.4.2 No expansion event ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint no-expansion (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (if-zero EXPANDS + (begin (eq! WORDS_NEW WORDS) + (eq! C_MEM_NEW C_MEM)))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 3.4.3 Expansion event ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defun (expansion-happened) + (* (offsets-are-in-bounds) EXPANDS)) + +(defconstraint setting-words-new (:guard (* (standing-hypothesis) (expansion-happened))) + (eq! WORDS_NEW ACC_A)) + +(defun (large-quotient) + (+ ACC_Q + (+ (* TWO_POW_32 (shift BYTE_QQ -2)) + (* (* 256 TWO_POW_32) (shift BYTE_QQ -3))))) + +(defconstraint euclidean-division-of-square-of-accA (:guard (* (standing-hypothesis) (expansion-happened))) + (begin (eq! (* ACC_A ACC_A) + (+ (* 512 (large-quotient)) + (+ (* 256 (prev BYTE_QQ)) + BYTE_QQ))) + (vanishes! (* (prev BYTE_QQ) + (- 1 (prev BYTE_QQ)))))) + +(defconstraint setting-c-mem-new (:guard (* (standing-hypothesis) (expansion-happened))) + (eq! C_MEM_NEW + (+ (* GAS_CONST_G_MEMORY ACC_A) (large-quotient)))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 3.4.4 Expansion gas ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defconstraint setting-quad-cost-and-lin-cost (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (begin (eq! QUAD_COST (- C_MEM_NEW C_MEM)) + (eq! LIN_COST + (+ (* GBYTE SIZE_1_LO) (* GWORD ACC_W))))) + +(defconstraint setting-gas-mxp (:guard (* (standing-hypothesis) (offsets-are-in-bounds))) + (if (eq! INST EVM_INST_RETURN) + (eq! GAS_MXP + (+ QUAD_COST (* DEPLOYS LIN_COST))) + (eq! GAS_MXP (+ QUAD_COST LIN_COST)))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.12 Consistency Constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +(defpermutation + (CN_perm + STAMP_perm + C_MEM_perm + C_MEM_NEW_perm + WORDS_perm + WORDS_NEW_perm) + + ((↓ CN) + (↓ STAMP) + C_MEM + C_MEM_NEW + WORDS + WORDS_NEW) + ) + +(defconstraint consistency () + (if-not-zero CN_perm + (if-eq-else (prev CN_perm) CN_perm + (if-not-zero (- (prev STAMP_perm) STAMP_perm) + (begin (eq! WORDS_perm (prev WORDS_NEW_perm)) + (eq! C_MEM_perm (prev C_MEM_NEW_perm)))) + (begin (vanishes! WORDS_perm) + (vanishes! C_MEM_perm))))) diff --git a/testdata/wcp.lisp b/testdata/wcp.lisp index f6e16e9..e237bba 100644 --- a/testdata/wcp.lisp +++ b/testdata/wcp.lisp @@ -4,7 +4,7 @@ (WORD_COMPARISON_STAMP :i32) (COUNTER :byte) (CT_MAX :byte) - (INST :byte) + (INST :byte :display :opcode) (ARGUMENT_1_HI :i128) (ARGUMENT_1_LO :i128) (ARGUMENT_2_HI :i128) @@ -40,32 +40,208 @@ (BIT_3 :binary@prove) (BIT_4 :binary@prove)) -(defconstraint result () (begin (if (- ONE_LINE_INSTRUCTION 1) (- RESULT (* BIT_1 BIT_2))) (if (- IS_LT 1) (- RESULT (- 1 (* BIT_1 BIT_2) (+ BIT_3 (* BIT_1 BIT_4))))) (if (- IS_GT 1) (- RESULT (+ BIT_3 (* BIT_1 BIT_4)))) (if (- IS_LEQ 1) (- RESULT (+ (- 1 (* BIT_1 BIT_2) (+ BIT_3 (* BIT_1 BIT_4))) (* BIT_1 BIT_2)))) (if (- IS_GEQ 1) (- RESULT (+ (+ BIT_3 (* BIT_1 BIT_4)) (* BIT_1 BIT_2)))) (if (- IS_LT 1) (- RESULT (- 1 (* BIT_1 BIT_2) (+ BIT_3 (* BIT_1 BIT_4))))) (if (- IS_SLT 1) (if (- NEG_1 NEG_2) (- RESULT (- 1 (* BIT_1 BIT_2) (+ BIT_3 (* BIT_1 BIT_4)))) (- RESULT NEG_1))) (if (- IS_SGT 1) (if (- NEG_1 NEG_2) (- RESULT (+ BIT_3 (* BIT_1 BIT_4))) (- RESULT NEG_2))))) - -(defconstraint bits-and-negs () (if (+ IS_SLT IS_SGT) 0 (if (- COUNTER 15) (begin (- (shift BYTE_1 -15) (+ (* 1 (shift BITS -8)) (+ (* 2 (shift BITS -9)) (+ (* 4 (shift BITS -10)) (+ (* 8 (shift BITS -11)) (+ (* 16 (shift BITS -12)) (+ (* 32 (shift BITS -13)) (+ (* 128 (shift BITS -15)) (* 64 (shift BITS -14)))))))))) (- (shift BYTE_3 -15) (+ (* 1 BITS) (+ (* 2 (shift BITS -1)) (+ (* 4 (shift BITS -2)) (+ (* 8 (shift BITS -3)) (+ (* 16 (shift BITS -4)) (+ (* 32 (shift BITS -5)) (+ (* 128 (shift BITS -7)) (* 64 (shift BITS -6)))))))))) (- NEG_1 (shift BITS -15)) (- NEG_2 (shift BITS -7)))))) - -(defconstraint byte_decompositions () (begin (if COUNTER (- ACC_1 BYTE_1) (- ACC_1 (+ (* 256 (shift ACC_1 -1)) BYTE_1))) (if COUNTER (- ACC_2 BYTE_2) (- ACC_2 (+ (* 256 (shift ACC_2 -1)) BYTE_2))) (if COUNTER (- ACC_3 BYTE_3) (- ACC_3 (+ (* 256 (shift ACC_3 -1)) BYTE_3))) (if COUNTER (- ACC_4 BYTE_4) (- ACC_4 (+ (* 256 (shift ACC_4 -1)) BYTE_4))) (if COUNTER (- ACC_5 BYTE_5) (- ACC_5 (+ (* 256 (shift ACC_5 -1)) BYTE_5))) (if COUNTER (- ACC_6 BYTE_6) (- ACC_6 (+ (* 256 (shift ACC_6 -1)) BYTE_6))))) - -(defconstraint target-constraints () (begin (if WORD_COMPARISON_STAMP 0 (begin (if (- ARGUMENT_1_HI ARGUMENT_2_HI) (- BIT_1 1) BIT_1) (if (- ARGUMENT_1_LO ARGUMENT_2_LO) (- BIT_2 1) BIT_2))) (if (- VARIABLE_LENGTH_INSTRUCTION 1) (if (- COUNTER CT_MAX) (begin (- ACC_1 ARGUMENT_1_HI) (- ACC_2 ARGUMENT_1_LO) (- ACC_3 ARGUMENT_2_HI) (- ACC_4 ARGUMENT_2_LO) (- ACC_5 (- (* (- (* 2 BIT_3) 1) (- ARGUMENT_1_HI ARGUMENT_2_HI)) BIT_3)) (- ACC_6 (- (* (- (* 2 BIT_4) 1) (- ARGUMENT_1_LO ARGUMENT_2_LO)) BIT_4))))) (if (- IS_ISZERO 1) (begin ARGUMENT_2_HI ARGUMENT_2_LO)))) - -(defconstraint counter-constancies () (begin (if COUNTER 0 (- ARGUMENT_1_HI (shift ARGUMENT_1_HI -1))) (if COUNTER 0 (- ARGUMENT_1_LO (shift ARGUMENT_1_LO -1))) (if COUNTER 0 (- ARGUMENT_2_HI (shift ARGUMENT_2_HI -1))) (if COUNTER 0 (- ARGUMENT_2_LO (shift ARGUMENT_2_LO -1))) (if COUNTER 0 (- RESULT (shift RESULT -1))) (if COUNTER 0 (- INST (shift INST -1))) (if COUNTER 0 (- CT_MAX (shift CT_MAX -1))) (if COUNTER 0 (- BIT_3 (shift BIT_3 -1))) (if COUNTER 0 (- BIT_4 (shift BIT_4 -1))) (if COUNTER 0 (- NEG_1 (shift NEG_1 -1))) (if COUNTER 0 (- NEG_2 (shift NEG_2 -1))))) - -(defconstraint setting-flag () (begin (- INST (+ (* 16 IS_LT) (* 17 IS_GT) (* 18 IS_SLT) (* 19 IS_SGT) (* 20 IS_EQ) (* 21 IS_ISZERO) (* 15 IS_GEQ) (* 14 IS_LEQ))) (- ONE_LINE_INSTRUCTION (+ IS_EQ IS_ISZERO)) (- VARIABLE_LENGTH_INSTRUCTION (+ IS_LT IS_GT IS_LEQ IS_GEQ IS_SLT IS_SGT)))) - -(defconstraint inst-decoding () (if WORD_COMPARISON_STAMP (+ (+ IS_EQ IS_ISZERO) (+ IS_LT IS_GT IS_LEQ IS_GEQ IS_SLT IS_SGT)) (- (+ (+ IS_EQ IS_ISZERO) (+ IS_LT IS_GT IS_LEQ IS_GEQ IS_SLT IS_SGT)) 1))) - -(defconstraint heartbeat () (if WORD_COMPARISON_STAMP 0 (if (- COUNTER CT_MAX) (- (shift WORD_COMPARISON_STAMP 1) (+ WORD_COMPARISON_STAMP 1)) (- (shift COUNTER 1) (+ COUNTER 1))))) - -(defconstraint stamp-increments () (* (- (shift WORD_COMPARISON_STAMP 1) WORD_COMPARISON_STAMP) (- (shift WORD_COMPARISON_STAMP 1) (+ WORD_COMPARISON_STAMP 1)))) - -(defconstraint ct-upper-bond () (- (~ (- 16 COUNTER)) 1)) - -(defconstraint counter-reset () (if (- (shift WORD_COMPARISON_STAMP 1) WORD_COMPARISON_STAMP) 0 (shift COUNTER 1))) - -(defconstraint setting-ct-max () (if (- ONE_LINE_INSTRUCTION 1) CT_MAX)) - -(defconstraint no-neg-if-small () (if (- CT_MAX 15) 0 (begin NEG_1 NEG_2))) - -(defconstraint lastRow (:domain {-1}) (- COUNTER CT_MAX)) - -(defconstraint first-row (:domain {0}) WORD_COMPARISON_STAMP) +;; aliases +(defalias + STAMP WORD_COMPARISON_STAMP + OLI ONE_LINE_INSTRUCTION + VLI VARIABLE_LENGTH_INSTRUCTION + CT COUNTER + ARG_1_HI ARGUMENT_1_HI + ARG_1_LO ARGUMENT_1_LO + ARG_2_HI ARGUMENT_2_HI + ARG_2_LO ARGUMENT_2_LO + RES RESULT) + +(defpurefun (if-eq-else A B then else) + (if-zero-else (- A B) + then + else)) + +;; opcode values +(defconst + LEQ 0x0E + GEQ 0x0F + LT 16 + GT 17 + SLT 18 + SGT 19 + EQ_ 20 + ISZERO 21 + LLARGE 16 + LLARGEMO 15) + + +(defun (one-line-inst) + (+ IS_EQ IS_ISZERO)) + +(defun (variable-length-inst) + (+ IS_LT IS_GT IS_LEQ IS_GEQ IS_SLT IS_SGT)) + +(defun (flag-sum) + (+ (one-line-inst) (variable-length-inst))) + +(defun (weight-sum) + (+ (* LT IS_LT) + (* GT IS_GT) + (* SLT IS_SLT) + (* SGT IS_SGT) + (* EQ_ IS_EQ) + (* ISZERO IS_ISZERO) + (* GEQ IS_GEQ) + (* LEQ IS_LEQ))) + +(defconstraint inst-decoding () + (if-zero-else STAMP + (vanishes! (flag-sum)) + (eq! (flag-sum) 1))) + +(defconstraint setting-flag () + (begin (eq! INST (weight-sum)) + (eq! OLI (one-line-inst)) + (eq! VLI (variable-length-inst)))) + +(defconstraint counter-constancies () + (begin (counter-constancy CT ARG_1_HI) + (counter-constancy CT ARG_1_LO) + (counter-constancy CT ARG_2_HI) + (counter-constancy CT ARG_2_LO) + (counter-constancy CT RES) + (counter-constancy CT INST) + (counter-constancy CT CT_MAX) + (counter-constancy CT BIT_3) + (counter-constancy CT BIT_4) + (counter-constancy CT NEG_1) + (counter-constancy CT NEG_2))) + +(defconstraint first-row (:domain {0}) + (vanishes! STAMP)) + +(defconstraint stamp-increments () + (* (will-remain-constant! STAMP) (will-inc! STAMP 1))) + +(defconstraint counter-reset () + (if-not-zero (will-remain-constant! STAMP) + (vanishes! (next CT)))) + +(defconstraint setting-ct-max () + (if-eq OLI 1 (vanishes! CT_MAX))) + +(defconstraint heartbeat (:guard STAMP) + (if-eq-else CT CT_MAX (will-inc! STAMP 1) (will-inc! CT 1))) + +(defconstraint ct-upper-bond () + (eq! (~ (- LLARGE CT)) + 1)) + +(defconstraint lastRow (:domain {-1}) + (eq! CT CT_MAX)) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.6 byte decompositions ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; byte decompositions +(defconstraint byte_decompositions () + (begin (byte-decomposition CT ACC_1 BYTE_1) + (byte-decomposition CT ACC_2 BYTE_2) + (byte-decomposition CT ACC_3 BYTE_3) + (byte-decomposition CT ACC_4 BYTE_4) + (byte-decomposition CT ACC_5 BYTE_5) + (byte-decomposition CT ACC_6 BYTE_6))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.7 BITS and sign bit constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; + +;; (defun (first-eight-bits-bit-dec) +;; (reduce + +;; (for i +;; [0 :7] +;; (* (^ 2 i) +;; (shift BITS +;; (- 0 (+ i 8))))))) + +;; (defun (last-eight-bits-bit-dec) +;; (reduce + +;; (for i +;; [0 :7] +;; (* (^ 2 i) +;; (shift BITS (- 0 i)))))) + +;; (defconstraint bits-and-negs (:guard (+ IS_SLT IS_SGT)) +;; (if-eq CT LLARGEMO +;; (begin (eq! (shift BYTE_1 (- 0 LLARGEMO)) +;; (first-eight-bits-bit-dec)) +;; (eq! (shift BYTE_3 (- 0 LLARGEMO)) +;; (last-eight-bits-bit-dec)) +;; (eq! NEG_1 +;; (shift BITS (- 0 LLARGEMO))) +;; (eq! NEG_2 +;; (shift BITS (- 0 7)))))) + +(defconstraint no-neg-if-small () + (if-not-zero (- CT_MAX LLARGEMO) + (begin (vanishes! NEG_1) + (vanishes! NEG_2)))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.6 target constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defconstraint target-constraints () + (begin (if-not-zero STAMP + (begin (if-eq-else ARG_1_HI ARG_2_HI (eq! BIT_1 1) (vanishes! BIT_1)) + (if-eq-else ARG_1_LO ARG_2_LO (eq! BIT_2 1) (vanishes! BIT_2)))) + (if-eq VLI 1 + (if-eq CT CT_MAX + (begin (eq! ACC_1 ARG_1_HI) + (eq! ACC_2 ARG_1_LO) + (eq! ACC_3 ARG_2_HI) + (eq! ACC_4 ARG_2_LO) + (eq! ACC_5 + (- (* (- (* 2 BIT_3) 1) + (- ARG_1_HI ARG_2_HI)) + BIT_3)) + (eq! ACC_6 + (- (* (- (* 2 BIT_4) 1) + (- ARG_1_LO ARG_2_LO)) + BIT_4))))) + (if-eq IS_ISZERO 1 + (begin (vanishes! ARG_2_HI) + (vanishes! ARG_2_LO))))) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; ;; +;; 2.7 result constraints ;; +;; ;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; eq_ = [[1]] . [[2]] +;; gt_ = [[3]] + [[1]] . [[4]] +;; lt_ = 1 - eq - gt +(defun (eq_) + (* BIT_1 BIT_2)) + +(defun (gt_) + (+ BIT_3 (* BIT_1 BIT_4))) + +(defun (lt_) + (- 1 (eq_) (gt_))) + +;; 2.7.2 +(defconstraint result () + (begin (if-eq OLI 1 (eq! RES (eq_))) + (if-eq IS_LT 1 (eq! RES (lt_))) + (if-eq IS_GT 1 (eq! RES (gt_))) + (if-eq IS_LEQ 1 + (eq! RES (+ (lt_) (eq_)))) + (if-eq IS_GEQ 1 + (eq! RES (+ (gt_) (eq_)))) + (if-eq IS_LT 1 (eq! RES (lt_))) + (if-eq IS_SLT 1 + (if-eq-else NEG_1 NEG_2 (eq! RES (lt_)) (eq! RES NEG_1))) + (if-eq IS_SGT 1 + (if-eq-else NEG_1 NEG_2 (eq! RES (gt_)) (eq! RES NEG_2)))))