@feelyourprotocol/evm 8141.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +373 -0
- package/README.md +690 -0
- package/dist/cjs/binaryTreeAccessWitness.d.ts +61 -0
- package/dist/cjs/binaryTreeAccessWitness.d.ts.map +1 -0
- package/dist/cjs/binaryTreeAccessWitness.js +314 -0
- package/dist/cjs/binaryTreeAccessWitness.js.map +1 -0
- package/dist/cjs/chunkCache.d.ts +13 -0
- package/dist/cjs/chunkCache.d.ts.map +1 -0
- package/dist/cjs/chunkCache.js +30 -0
- package/dist/cjs/chunkCache.js.map +1 -0
- package/dist/cjs/constructors.d.ts +11 -0
- package/dist/cjs/constructors.d.ts.map +1 -0
- package/dist/cjs/constructors.js +30 -0
- package/dist/cjs/constructors.js.map +1 -0
- package/dist/cjs/eip7708.d.ts +24 -0
- package/dist/cjs/eip7708.d.ts.map +1 -0
- package/dist/cjs/eip7708.js +37 -0
- package/dist/cjs/eip7708.js.map +1 -0
- package/dist/cjs/eof/constants.d.ts +22 -0
- package/dist/cjs/eof/constants.d.ts.map +1 -0
- package/dist/cjs/eof/constants.js +31 -0
- package/dist/cjs/eof/constants.js.map +1 -0
- package/dist/cjs/eof/container.d.ts +87 -0
- package/dist/cjs/eof/container.d.ts.map +1 -0
- package/dist/cjs/eof/container.js +380 -0
- package/dist/cjs/eof/container.js.map +1 -0
- package/dist/cjs/eof/errors.d.ts +66 -0
- package/dist/cjs/eof/errors.d.ts.map +1 -0
- package/dist/cjs/eof/errors.js +200 -0
- package/dist/cjs/eof/errors.js.map +1 -0
- package/dist/cjs/eof/setup.d.ts +9 -0
- package/dist/cjs/eof/setup.d.ts.map +1 -0
- package/dist/cjs/eof/setup.js +26 -0
- package/dist/cjs/eof/setup.js.map +1 -0
- package/dist/cjs/eof/stackDelta.d.ts +10 -0
- package/dist/cjs/eof/stackDelta.d.ts.map +1 -0
- package/dist/cjs/eof/stackDelta.js +164 -0
- package/dist/cjs/eof/stackDelta.js.map +1 -0
- package/dist/cjs/eof/util.d.ts +8 -0
- package/dist/cjs/eof/util.d.ts.map +1 -0
- package/dist/cjs/eof/util.js +18 -0
- package/dist/cjs/eof/util.js.map +1 -0
- package/dist/cjs/eof/verify.d.ts +38 -0
- package/dist/cjs/eof/verify.d.ts.map +1 -0
- package/dist/cjs/eof/verify.js +436 -0
- package/dist/cjs/eof/verify.js.map +1 -0
- package/dist/cjs/errors.d.ts +40 -0
- package/dist/cjs/errors.d.ts.map +1 -0
- package/dist/cjs/errors.js +43 -0
- package/dist/cjs/errors.js.map +1 -0
- package/dist/cjs/evm.d.ts +181 -0
- package/dist/cjs/evm.d.ts.map +1 -0
- package/dist/cjs/evm.js +1142 -0
- package/dist/cjs/evm.js.map +1 -0
- package/dist/cjs/frameContext.d.ts +50 -0
- package/dist/cjs/frameContext.d.ts.map +1 -0
- package/dist/cjs/frameContext.js +17 -0
- package/dist/cjs/frameContext.js.map +1 -0
- package/dist/cjs/index.d.ts +18 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +43 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/interpreter.d.ts +361 -0
- package/dist/cjs/interpreter.d.ts.map +1 -0
- package/dist/cjs/interpreter.js +1057 -0
- package/dist/cjs/interpreter.js.map +1 -0
- package/dist/cjs/journal.d.ts +69 -0
- package/dist/cjs/journal.d.ts.map +1 -0
- package/dist/cjs/journal.js +247 -0
- package/dist/cjs/journal.js.map +1 -0
- package/dist/cjs/logger.d.ts +38 -0
- package/dist/cjs/logger.d.ts.map +1 -0
- package/dist/cjs/logger.js +126 -0
- package/dist/cjs/logger.js.map +1 -0
- package/dist/cjs/memory.d.ts +29 -0
- package/dist/cjs/memory.d.ts.map +1 -0
- package/dist/cjs/memory.js +75 -0
- package/dist/cjs/memory.js.map +1 -0
- package/dist/cjs/message.d.ts +70 -0
- package/dist/cjs/message.d.ts.map +1 -0
- package/dist/cjs/message.js +51 -0
- package/dist/cjs/message.js.map +1 -0
- package/dist/cjs/opcodes/EIP1283.d.ts +13 -0
- package/dist/cjs/opcodes/EIP1283.d.ts.map +1 -0
- package/dist/cjs/opcodes/EIP1283.js +58 -0
- package/dist/cjs/opcodes/EIP1283.js.map +1 -0
- package/dist/cjs/opcodes/EIP2200.d.ts +13 -0
- package/dist/cjs/opcodes/EIP2200.d.ts.map +1 -0
- package/dist/cjs/opcodes/EIP2200.js +64 -0
- package/dist/cjs/opcodes/EIP2200.js.map +1 -0
- package/dist/cjs/opcodes/EIP2929.d.ts +68 -0
- package/dist/cjs/opcodes/EIP2929.d.ts.map +1 -0
- package/dist/cjs/opcodes/EIP2929.js +146 -0
- package/dist/cjs/opcodes/EIP2929.js.map +1 -0
- package/dist/cjs/opcodes/codes.d.ts +45 -0
- package/dist/cjs/opcodes/codes.d.ts.map +1 -0
- package/dist/cjs/opcodes/codes.js +453 -0
- package/dist/cjs/opcodes/codes.js.map +1 -0
- package/dist/cjs/opcodes/functions.d.ts +11 -0
- package/dist/cjs/opcodes/functions.d.ts.map +1 -0
- package/dist/cjs/opcodes/functions.js +1778 -0
- package/dist/cjs/opcodes/functions.js.map +1 -0
- package/dist/cjs/opcodes/gas.d.ts +15 -0
- package/dist/cjs/opcodes/gas.d.ts.map +1 -0
- package/dist/cjs/opcodes/gas.js +1016 -0
- package/dist/cjs/opcodes/gas.js.map +1 -0
- package/dist/cjs/opcodes/index.d.ts +4 -0
- package/dist/cjs/opcodes/index.d.ts.map +1 -0
- package/dist/cjs/opcodes/index.js +20 -0
- package/dist/cjs/opcodes/index.js.map +1 -0
- package/dist/cjs/opcodes/util.d.ts +86 -0
- package/dist/cjs/opcodes/util.d.ts.map +1 -0
- package/dist/cjs/opcodes/util.js +281 -0
- package/dist/cjs/opcodes/util.js.map +1 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/params.d.ts +3 -0
- package/dist/cjs/params.d.ts.map +1 -0
- package/dist/cjs/params.js +424 -0
- package/dist/cjs/params.js.map +1 -0
- package/dist/cjs/precompiles/01-ecrecover.d.ts +4 -0
- package/dist/cjs/precompiles/01-ecrecover.d.ts.map +1 -0
- package/dist/cjs/precompiles/01-ecrecover.js +58 -0
- package/dist/cjs/precompiles/01-ecrecover.js.map +1 -0
- package/dist/cjs/precompiles/02-sha256.d.ts +4 -0
- package/dist/cjs/precompiles/02-sha256.d.ts.map +1 -0
- package/dist/cjs/precompiles/02-sha256.js +27 -0
- package/dist/cjs/precompiles/02-sha256.js.map +1 -0
- package/dist/cjs/precompiles/03-ripemd160.d.ts +4 -0
- package/dist/cjs/precompiles/03-ripemd160.d.ts.map +1 -0
- package/dist/cjs/precompiles/03-ripemd160.js +26 -0
- package/dist/cjs/precompiles/03-ripemd160.js.map +1 -0
- package/dist/cjs/precompiles/04-identity.d.ts +4 -0
- package/dist/cjs/precompiles/04-identity.d.ts.map +1 -0
- package/dist/cjs/precompiles/04-identity.js +24 -0
- package/dist/cjs/precompiles/04-identity.js.map +1 -0
- package/dist/cjs/precompiles/05-modexp.d.ts +5 -0
- package/dist/cjs/precompiles/05-modexp.d.ts.map +1 -0
- package/dist/cjs/precompiles/05-modexp.js +185 -0
- package/dist/cjs/precompiles/05-modexp.js.map +1 -0
- package/dist/cjs/precompiles/06-bn254-add.d.ts +4 -0
- package/dist/cjs/precompiles/06-bn254-add.d.ts.map +1 -0
- package/dist/cjs/precompiles/06-bn254-add.js +42 -0
- package/dist/cjs/precompiles/06-bn254-add.js.map +1 -0
- package/dist/cjs/precompiles/07-bn254-mul.d.ts +4 -0
- package/dist/cjs/precompiles/07-bn254-mul.d.ts.map +1 -0
- package/dist/cjs/precompiles/07-bn254-mul.js +43 -0
- package/dist/cjs/precompiles/07-bn254-mul.js.map +1 -0
- package/dist/cjs/precompiles/08-bn254-pairing.d.ts +4 -0
- package/dist/cjs/precompiles/08-bn254-pairing.d.ts.map +1 -0
- package/dist/cjs/precompiles/08-bn254-pairing.js +45 -0
- package/dist/cjs/precompiles/08-bn254-pairing.js.map +1 -0
- package/dist/cjs/precompiles/09-blake2f.d.ts +5 -0
- package/dist/cjs/precompiles/09-blake2f.d.ts.map +1 -0
- package/dist/cjs/precompiles/09-blake2f.js +201 -0
- package/dist/cjs/precompiles/09-blake2f.js.map +1 -0
- package/dist/cjs/precompiles/0a-kzg-point-evaluation.d.ts +5 -0
- package/dist/cjs/precompiles/0a-kzg-point-evaluation.d.ts.map +1 -0
- package/dist/cjs/precompiles/0a-kzg-point-evaluation.js +68 -0
- package/dist/cjs/precompiles/0a-kzg-point-evaluation.js.map +1 -0
- package/dist/cjs/precompiles/0b-bls12-g1add.d.ts +4 -0
- package/dist/cjs/precompiles/0b-bls12-g1add.d.ts.map +1 -0
- package/dist/cjs/precompiles/0b-bls12-g1add.js +49 -0
- package/dist/cjs/precompiles/0b-bls12-g1add.js.map +1 -0
- package/dist/cjs/precompiles/0c-bls12-g1msm.d.ts +4 -0
- package/dist/cjs/precompiles/0c-bls12-g1msm.d.ts.map +1 -0
- package/dist/cjs/precompiles/0c-bls12-g1msm.js +62 -0
- package/dist/cjs/precompiles/0c-bls12-g1msm.js.map +1 -0
- package/dist/cjs/precompiles/0d-bls12-g2add.d.ts +4 -0
- package/dist/cjs/precompiles/0d-bls12-g2add.d.ts.map +1 -0
- package/dist/cjs/precompiles/0d-bls12-g2add.js +51 -0
- package/dist/cjs/precompiles/0d-bls12-g2add.js.map +1 -0
- package/dist/cjs/precompiles/0e-bls12-g2msm.d.ts +4 -0
- package/dist/cjs/precompiles/0e-bls12-g2msm.d.ts.map +1 -0
- package/dist/cjs/precompiles/0e-bls12-g2msm.js +60 -0
- package/dist/cjs/precompiles/0e-bls12-g2msm.js.map +1 -0
- package/dist/cjs/precompiles/0f-bls12-pairing.d.ts +4 -0
- package/dist/cjs/precompiles/0f-bls12-pairing.d.ts.map +1 -0
- package/dist/cjs/precompiles/0f-bls12-pairing.js +66 -0
- package/dist/cjs/precompiles/0f-bls12-pairing.js.map +1 -0
- package/dist/cjs/precompiles/10-bls12-map-fp-to-g1.d.ts +4 -0
- package/dist/cjs/precompiles/10-bls12-map-fp-to-g1.d.ts.map +1 -0
- package/dist/cjs/precompiles/10-bls12-map-fp-to-g1.js +44 -0
- package/dist/cjs/precompiles/10-bls12-map-fp-to-g1.js.map +1 -0
- package/dist/cjs/precompiles/100-p256verify.d.ts +4 -0
- package/dist/cjs/precompiles/100-p256verify.d.ts.map +1 -0
- package/dist/cjs/precompiles/100-p256verify.js +131 -0
- package/dist/cjs/precompiles/100-p256verify.js.map +1 -0
- package/dist/cjs/precompiles/11-bls12-map-fp2-to-g2.d.ts +4 -0
- package/dist/cjs/precompiles/11-bls12-map-fp2-to-g2.d.ts.map +1 -0
- package/dist/cjs/precompiles/11-bls12-map-fp2-to-g2.js +47 -0
- package/dist/cjs/precompiles/11-bls12-map-fp2-to-g2.js.map +1 -0
- package/dist/cjs/precompiles/bls12_381/constants.d.ts +10 -0
- package/dist/cjs/precompiles/bls12_381/constants.d.ts.map +1 -0
- package/dist/cjs/precompiles/bls12_381/constants.js +274 -0
- package/dist/cjs/precompiles/bls12_381/constants.js.map +1 -0
- package/dist/cjs/precompiles/bls12_381/index.d.ts +5 -0
- package/dist/cjs/precompiles/bls12_381/index.d.ts.map +1 -0
- package/dist/cjs/precompiles/bls12_381/index.js +24 -0
- package/dist/cjs/precompiles/bls12_381/index.js.map +1 -0
- package/dist/cjs/precompiles/bls12_381/mcl.d.ts +45 -0
- package/dist/cjs/precompiles/bls12_381/mcl.d.ts.map +1 -0
- package/dist/cjs/precompiles/bls12_381/mcl.js +264 -0
- package/dist/cjs/precompiles/bls12_381/mcl.js.map +1 -0
- package/dist/cjs/precompiles/bls12_381/noble.d.ts +39 -0
- package/dist/cjs/precompiles/bls12_381/noble.d.ts.map +1 -0
- package/dist/cjs/precompiles/bls12_381/noble.js +228 -0
- package/dist/cjs/precompiles/bls12_381/noble.js.map +1 -0
- package/dist/cjs/precompiles/bls12_381/util.d.ts +35 -0
- package/dist/cjs/precompiles/bls12_381/util.d.ts.map +1 -0
- package/dist/cjs/precompiles/bls12_381/util.js +68 -0
- package/dist/cjs/precompiles/bls12_381/util.js.map +1 -0
- package/dist/cjs/precompiles/bn254/index.d.ts +3 -0
- package/dist/cjs/precompiles/bn254/index.d.ts.map +1 -0
- package/dist/cjs/precompiles/bn254/index.js +8 -0
- package/dist/cjs/precompiles/bn254/index.js.map +1 -0
- package/dist/cjs/precompiles/bn254/noble.d.ts +13 -0
- package/dist/cjs/precompiles/bn254/noble.d.ts.map +1 -0
- package/dist/cjs/precompiles/bn254/noble.js +124 -0
- package/dist/cjs/precompiles/bn254/noble.js.map +1 -0
- package/dist/cjs/precompiles/bn254/rustbn.d.ts +16 -0
- package/dist/cjs/precompiles/bn254/rustbn.d.ts.map +1 -0
- package/dist/cjs/precompiles/bn254/rustbn.js +33 -0
- package/dist/cjs/precompiles/bn254/rustbn.js.map +1 -0
- package/dist/cjs/precompiles/index.d.ts +67 -0
- package/dist/cjs/precompiles/index.d.ts.map +1 -0
- package/dist/cjs/precompiles/index.js +262 -0
- package/dist/cjs/precompiles/index.js.map +1 -0
- package/dist/cjs/precompiles/types.d.ts +13 -0
- package/dist/cjs/precompiles/types.d.ts.map +1 -0
- package/dist/cjs/precompiles/types.js +3 -0
- package/dist/cjs/precompiles/types.js.map +1 -0
- package/dist/cjs/precompiles/util.d.ts +30 -0
- package/dist/cjs/precompiles/util.d.ts.map +1 -0
- package/dist/cjs/precompiles/util.js +63 -0
- package/dist/cjs/precompiles/util.js.map +1 -0
- package/dist/cjs/stack.d.ts +55 -0
- package/dist/cjs/stack.d.ts.map +1 -0
- package/dist/cjs/stack.js +143 -0
- package/dist/cjs/stack.js.map +1 -0
- package/dist/cjs/stemCache.d.ts +20 -0
- package/dist/cjs/stemCache.d.ts.map +1 -0
- package/dist/cjs/stemCache.js +37 -0
- package/dist/cjs/stemCache.js.map +1 -0
- package/dist/cjs/transientStorage.d.ts +54 -0
- package/dist/cjs/transientStorage.d.ts.map +1 -0
- package/dist/cjs/transientStorage.js +113 -0
- package/dist/cjs/transientStorage.js.map +1 -0
- package/dist/cjs/types.d.ts +465 -0
- package/dist/cjs/types.d.ts.map +1 -0
- package/dist/cjs/types.js +28 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/esm/binaryTreeAccessWitness.d.ts +61 -0
- package/dist/esm/binaryTreeAccessWitness.d.ts.map +1 -0
- package/dist/esm/binaryTreeAccessWitness.js +308 -0
- package/dist/esm/binaryTreeAccessWitness.js.map +1 -0
- package/dist/esm/chunkCache.d.ts +13 -0
- package/dist/esm/chunkCache.d.ts.map +1 -0
- package/dist/esm/chunkCache.js +26 -0
- package/dist/esm/chunkCache.js.map +1 -0
- package/dist/esm/constructors.d.ts +11 -0
- package/dist/esm/constructors.d.ts.map +1 -0
- package/dist/esm/constructors.js +27 -0
- package/dist/esm/constructors.js.map +1 -0
- package/dist/esm/eip7708.d.ts +24 -0
- package/dist/esm/eip7708.d.ts.map +1 -0
- package/dist/esm/eip7708.js +32 -0
- package/dist/esm/eip7708.js.map +1 -0
- package/dist/esm/eof/constants.d.ts +22 -0
- package/dist/esm/eof/constants.d.ts.map +1 -0
- package/dist/esm/eof/constants.js +28 -0
- package/dist/esm/eof/constants.js.map +1 -0
- package/dist/esm/eof/container.d.ts +87 -0
- package/dist/esm/eof/container.d.ts.map +1 -0
- package/dist/esm/eof/container.js +375 -0
- package/dist/esm/eof/container.js.map +1 -0
- package/dist/esm/eof/errors.d.ts +66 -0
- package/dist/esm/eof/errors.d.ts.map +1 -0
- package/dist/esm/eof/errors.js +195 -0
- package/dist/esm/eof/errors.js.map +1 -0
- package/dist/esm/eof/setup.d.ts +9 -0
- package/dist/esm/eof/setup.d.ts.map +1 -0
- package/dist/esm/eof/setup.js +23 -0
- package/dist/esm/eof/setup.js.map +1 -0
- package/dist/esm/eof/stackDelta.d.ts +10 -0
- package/dist/esm/eof/stackDelta.d.ts.map +1 -0
- package/dist/esm/eof/stackDelta.js +161 -0
- package/dist/esm/eof/stackDelta.js.map +1 -0
- package/dist/esm/eof/util.d.ts +8 -0
- package/dist/esm/eof/util.d.ts.map +1 -0
- package/dist/esm/eof/util.js +14 -0
- package/dist/esm/eof/util.js.map +1 -0
- package/dist/esm/eof/verify.d.ts +38 -0
- package/dist/esm/eof/verify.d.ts.map +1 -0
- package/dist/esm/eof/verify.js +432 -0
- package/dist/esm/eof/verify.js.map +1 -0
- package/dist/esm/errors.d.ts +40 -0
- package/dist/esm/errors.d.ts.map +1 -0
- package/dist/esm/errors.js +39 -0
- package/dist/esm/errors.js.map +1 -0
- package/dist/esm/evm.d.ts +181 -0
- package/dist/esm/evm.d.ts.map +1 -0
- package/dist/esm/evm.js +1131 -0
- package/dist/esm/evm.js.map +1 -0
- package/dist/esm/frameContext.d.ts +50 -0
- package/dist/esm/frameContext.d.ts.map +1 -0
- package/dist/esm/frameContext.js +14 -0
- package/dist/esm/frameContext.js.map +1 -0
- package/dist/esm/index.d.ts +18 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +15 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/interpreter.d.ts +361 -0
- package/dist/esm/interpreter.d.ts.map +1 -0
- package/dist/esm/interpreter.js +1054 -0
- package/dist/esm/interpreter.js.map +1 -0
- package/dist/esm/journal.d.ts +69 -0
- package/dist/esm/journal.d.ts.map +1 -0
- package/dist/esm/journal.js +243 -0
- package/dist/esm/journal.js.map +1 -0
- package/dist/esm/logger.d.ts +38 -0
- package/dist/esm/logger.d.ts.map +1 -0
- package/dist/esm/logger.js +121 -0
- package/dist/esm/logger.js.map +1 -0
- package/dist/esm/memory.d.ts +29 -0
- package/dist/esm/memory.d.ts.map +1 -0
- package/dist/esm/memory.js +71 -0
- package/dist/esm/memory.js.map +1 -0
- package/dist/esm/message.d.ts +70 -0
- package/dist/esm/message.d.ts.map +1 -0
- package/dist/esm/message.js +47 -0
- package/dist/esm/message.js.map +1 -0
- package/dist/esm/opcodes/EIP1283.d.ts +13 -0
- package/dist/esm/opcodes/EIP1283.d.ts.map +1 -0
- package/dist/esm/opcodes/EIP1283.js +55 -0
- package/dist/esm/opcodes/EIP1283.js.map +1 -0
- package/dist/esm/opcodes/EIP2200.d.ts +13 -0
- package/dist/esm/opcodes/EIP2200.d.ts.map +1 -0
- package/dist/esm/opcodes/EIP2200.js +61 -0
- package/dist/esm/opcodes/EIP2200.js.map +1 -0
- package/dist/esm/opcodes/EIP2929.d.ts +68 -0
- package/dist/esm/opcodes/EIP2929.d.ts.map +1 -0
- package/dist/esm/opcodes/EIP2929.js +138 -0
- package/dist/esm/opcodes/EIP2929.js.map +1 -0
- package/dist/esm/opcodes/codes.d.ts +45 -0
- package/dist/esm/opcodes/codes.d.ts.map +1 -0
- package/dist/esm/opcodes/codes.js +448 -0
- package/dist/esm/opcodes/codes.js.map +1 -0
- package/dist/esm/opcodes/functions.d.ts +11 -0
- package/dist/esm/opcodes/functions.d.ts.map +1 -0
- package/dist/esm/opcodes/functions.js +1775 -0
- package/dist/esm/opcodes/functions.js.map +1 -0
- package/dist/esm/opcodes/gas.d.ts +15 -0
- package/dist/esm/opcodes/gas.d.ts.map +1 -0
- package/dist/esm/opcodes/gas.js +1013 -0
- package/dist/esm/opcodes/gas.js.map +1 -0
- package/dist/esm/opcodes/index.d.ts +4 -0
- package/dist/esm/opcodes/index.d.ts.map +1 -0
- package/dist/esm/opcodes/index.js +4 -0
- package/dist/esm/opcodes/index.js.map +1 -0
- package/dist/esm/opcodes/util.d.ts +86 -0
- package/dist/esm/opcodes/util.d.ts.map +1 -0
- package/dist/esm/opcodes/util.js +257 -0
- package/dist/esm/opcodes/util.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/params.d.ts +3 -0
- package/dist/esm/params.d.ts.map +1 -0
- package/dist/esm/params.js +421 -0
- package/dist/esm/params.js.map +1 -0
- package/dist/esm/precompiles/01-ecrecover.d.ts +4 -0
- package/dist/esm/precompiles/01-ecrecover.d.ts.map +1 -0
- package/dist/esm/precompiles/01-ecrecover.js +55 -0
- package/dist/esm/precompiles/01-ecrecover.js.map +1 -0
- package/dist/esm/precompiles/02-sha256.d.ts +4 -0
- package/dist/esm/precompiles/02-sha256.d.ts.map +1 -0
- package/dist/esm/precompiles/02-sha256.js +24 -0
- package/dist/esm/precompiles/02-sha256.js.map +1 -0
- package/dist/esm/precompiles/03-ripemd160.d.ts +4 -0
- package/dist/esm/precompiles/03-ripemd160.d.ts.map +1 -0
- package/dist/esm/precompiles/03-ripemd160.js +23 -0
- package/dist/esm/precompiles/03-ripemd160.js.map +1 -0
- package/dist/esm/precompiles/04-identity.d.ts +4 -0
- package/dist/esm/precompiles/04-identity.d.ts.map +1 -0
- package/dist/esm/precompiles/04-identity.js +21 -0
- package/dist/esm/precompiles/04-identity.js.map +1 -0
- package/dist/esm/precompiles/05-modexp.d.ts +5 -0
- package/dist/esm/precompiles/05-modexp.d.ts.map +1 -0
- package/dist/esm/precompiles/05-modexp.js +181 -0
- package/dist/esm/precompiles/05-modexp.js.map +1 -0
- package/dist/esm/precompiles/06-bn254-add.d.ts +4 -0
- package/dist/esm/precompiles/06-bn254-add.d.ts.map +1 -0
- package/dist/esm/precompiles/06-bn254-add.js +39 -0
- package/dist/esm/precompiles/06-bn254-add.js.map +1 -0
- package/dist/esm/precompiles/07-bn254-mul.d.ts +4 -0
- package/dist/esm/precompiles/07-bn254-mul.d.ts.map +1 -0
- package/dist/esm/precompiles/07-bn254-mul.js +40 -0
- package/dist/esm/precompiles/07-bn254-mul.js.map +1 -0
- package/dist/esm/precompiles/08-bn254-pairing.d.ts +4 -0
- package/dist/esm/precompiles/08-bn254-pairing.d.ts.map +1 -0
- package/dist/esm/precompiles/08-bn254-pairing.js +42 -0
- package/dist/esm/precompiles/08-bn254-pairing.js.map +1 -0
- package/dist/esm/precompiles/09-blake2f.d.ts +5 -0
- package/dist/esm/precompiles/09-blake2f.d.ts.map +1 -0
- package/dist/esm/precompiles/09-blake2f.js +197 -0
- package/dist/esm/precompiles/09-blake2f.js.map +1 -0
- package/dist/esm/precompiles/0a-kzg-point-evaluation.d.ts +5 -0
- package/dist/esm/precompiles/0a-kzg-point-evaluation.d.ts.map +1 -0
- package/dist/esm/precompiles/0a-kzg-point-evaluation.js +64 -0
- package/dist/esm/precompiles/0a-kzg-point-evaluation.js.map +1 -0
- package/dist/esm/precompiles/0b-bls12-g1add.d.ts +4 -0
- package/dist/esm/precompiles/0b-bls12-g1add.d.ts.map +1 -0
- package/dist/esm/precompiles/0b-bls12-g1add.js +46 -0
- package/dist/esm/precompiles/0b-bls12-g1add.js.map +1 -0
- package/dist/esm/precompiles/0c-bls12-g1msm.d.ts +4 -0
- package/dist/esm/precompiles/0c-bls12-g1msm.d.ts.map +1 -0
- package/dist/esm/precompiles/0c-bls12-g1msm.js +59 -0
- package/dist/esm/precompiles/0c-bls12-g1msm.js.map +1 -0
- package/dist/esm/precompiles/0d-bls12-g2add.d.ts +4 -0
- package/dist/esm/precompiles/0d-bls12-g2add.d.ts.map +1 -0
- package/dist/esm/precompiles/0d-bls12-g2add.js +48 -0
- package/dist/esm/precompiles/0d-bls12-g2add.js.map +1 -0
- package/dist/esm/precompiles/0e-bls12-g2msm.d.ts +4 -0
- package/dist/esm/precompiles/0e-bls12-g2msm.d.ts.map +1 -0
- package/dist/esm/precompiles/0e-bls12-g2msm.js +57 -0
- package/dist/esm/precompiles/0e-bls12-g2msm.js.map +1 -0
- package/dist/esm/precompiles/0f-bls12-pairing.d.ts +4 -0
- package/dist/esm/precompiles/0f-bls12-pairing.d.ts.map +1 -0
- package/dist/esm/precompiles/0f-bls12-pairing.js +63 -0
- package/dist/esm/precompiles/0f-bls12-pairing.js.map +1 -0
- package/dist/esm/precompiles/10-bls12-map-fp-to-g1.d.ts +4 -0
- package/dist/esm/precompiles/10-bls12-map-fp-to-g1.d.ts.map +1 -0
- package/dist/esm/precompiles/10-bls12-map-fp-to-g1.js +41 -0
- package/dist/esm/precompiles/10-bls12-map-fp-to-g1.js.map +1 -0
- package/dist/esm/precompiles/100-p256verify.d.ts +4 -0
- package/dist/esm/precompiles/100-p256verify.d.ts.map +1 -0
- package/dist/esm/precompiles/100-p256verify.js +128 -0
- package/dist/esm/precompiles/100-p256verify.js.map +1 -0
- package/dist/esm/precompiles/11-bls12-map-fp2-to-g2.d.ts +4 -0
- package/dist/esm/precompiles/11-bls12-map-fp2-to-g2.d.ts.map +1 -0
- package/dist/esm/precompiles/11-bls12-map-fp2-to-g2.js +44 -0
- package/dist/esm/precompiles/11-bls12-map-fp2-to-g2.js.map +1 -0
- package/dist/esm/precompiles/bls12_381/constants.d.ts +10 -0
- package/dist/esm/precompiles/bls12_381/constants.d.ts.map +1 -0
- package/dist/esm/precompiles/bls12_381/constants.js +271 -0
- package/dist/esm/precompiles/bls12_381/constants.js.map +1 -0
- package/dist/esm/precompiles/bls12_381/index.d.ts +5 -0
- package/dist/esm/precompiles/bls12_381/index.d.ts.map +1 -0
- package/dist/esm/precompiles/bls12_381/index.js +5 -0
- package/dist/esm/precompiles/bls12_381/index.js.map +1 -0
- package/dist/esm/precompiles/bls12_381/mcl.d.ts +45 -0
- package/dist/esm/precompiles/bls12_381/mcl.d.ts.map +1 -0
- package/dist/esm/precompiles/bls12_381/mcl.js +254 -0
- package/dist/esm/precompiles/bls12_381/mcl.js.map +1 -0
- package/dist/esm/precompiles/bls12_381/noble.d.ts +39 -0
- package/dist/esm/precompiles/bls12_381/noble.d.ts.map +1 -0
- package/dist/esm/precompiles/bls12_381/noble.js +218 -0
- package/dist/esm/precompiles/bls12_381/noble.js.map +1 -0
- package/dist/esm/precompiles/bls12_381/util.d.ts +35 -0
- package/dist/esm/precompiles/bls12_381/util.d.ts.map +1 -0
- package/dist/esm/precompiles/bls12_381/util.js +63 -0
- package/dist/esm/precompiles/bls12_381/util.js.map +1 -0
- package/dist/esm/precompiles/bn254/index.d.ts +3 -0
- package/dist/esm/precompiles/bn254/index.d.ts.map +1 -0
- package/dist/esm/precompiles/bn254/index.js +3 -0
- package/dist/esm/precompiles/bn254/index.js.map +1 -0
- package/dist/esm/precompiles/bn254/noble.d.ts +13 -0
- package/dist/esm/precompiles/bn254/noble.d.ts.map +1 -0
- package/dist/esm/precompiles/bn254/noble.js +120 -0
- package/dist/esm/precompiles/bn254/noble.js.map +1 -0
- package/dist/esm/precompiles/bn254/rustbn.d.ts +16 -0
- package/dist/esm/precompiles/bn254/rustbn.d.ts.map +1 -0
- package/dist/esm/precompiles/bn254/rustbn.js +29 -0
- package/dist/esm/precompiles/bn254/rustbn.js.map +1 -0
- package/dist/esm/precompiles/index.d.ts +67 -0
- package/dist/esm/precompiles/index.d.ts.map +1 -0
- package/dist/esm/precompiles/index.js +251 -0
- package/dist/esm/precompiles/index.js.map +1 -0
- package/dist/esm/precompiles/types.d.ts +13 -0
- package/dist/esm/precompiles/types.d.ts.map +1 -0
- package/dist/esm/precompiles/types.js +2 -0
- package/dist/esm/precompiles/types.js.map +1 -0
- package/dist/esm/precompiles/util.d.ts +30 -0
- package/dist/esm/precompiles/util.d.ts.map +1 -0
- package/dist/esm/precompiles/util.js +57 -0
- package/dist/esm/precompiles/util.js.map +1 -0
- package/dist/esm/stack.d.ts +55 -0
- package/dist/esm/stack.d.ts.map +1 -0
- package/dist/esm/stack.js +139 -0
- package/dist/esm/stack.js.map +1 -0
- package/dist/esm/stemCache.d.ts +20 -0
- package/dist/esm/stemCache.d.ts.map +1 -0
- package/dist/esm/stemCache.js +33 -0
- package/dist/esm/stemCache.js.map +1 -0
- package/dist/esm/transientStorage.d.ts +54 -0
- package/dist/esm/transientStorage.d.ts.map +1 -0
- package/dist/esm/transientStorage.js +109 -0
- package/dist/esm/transientStorage.js.map +1 -0
- package/dist/esm/types.d.ts +465 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +23 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/tsconfig.prod.cjs.tsbuildinfo +1 -0
- package/dist/tsconfig.prod.esm.tsbuildinfo +1 -0
- package/package.json +98 -0
- package/src/binaryTreeAccessWitness.ts +447 -0
- package/src/chunkCache.ts +36 -0
- package/src/constructors.ts +35 -0
- package/src/eip7708.ts +47 -0
- package/src/eof/constants.ts +36 -0
- package/src/eof/container.ts +495 -0
- package/src/eof/errors.ts +214 -0
- package/src/eof/setup.ts +27 -0
- package/src/eof/stackDelta.ts +169 -0
- package/src/eof/util.ts +16 -0
- package/src/eof/verify.ts +531 -0
- package/src/errors.ts +45 -0
- package/src/evm.ts +1415 -0
- package/src/frameContext.ts +56 -0
- package/src/index.ts +75 -0
- package/src/interpreter.ts +1437 -0
- package/src/journal.ts +317 -0
- package/src/logger.ts +180 -0
- package/src/memory.ts +82 -0
- package/src/message.ts +114 -0
- package/src/opcodes/EIP1283.ts +77 -0
- package/src/opcodes/EIP2200.ts +87 -0
- package/src/opcodes/EIP2929.ts +173 -0
- package/src/opcodes/codes.ts +528 -0
- package/src/opcodes/functions.ts +1937 -0
- package/src/opcodes/gas.ts +1329 -0
- package/src/opcodes/index.ts +3 -0
- package/src/opcodes/util.ts +313 -0
- package/src/params.ts +423 -0
- package/src/precompiles/01-ecrecover.ts +77 -0
- package/src/precompiles/02-sha256.ts +32 -0
- package/src/precompiles/03-ripemd160.ts +32 -0
- package/src/precompiles/04-identity.ts +29 -0
- package/src/precompiles/05-modexp.ts +215 -0
- package/src/precompiles/06-bn254-add.ts +49 -0
- package/src/precompiles/07-bn254-mul.ts +50 -0
- package/src/precompiles/08-bn254-pairing.ts +54 -0
- package/src/precompiles/09-blake2f.ts +243 -0
- package/src/precompiles/0a-kzg-point-evaluation.ts +94 -0
- package/src/precompiles/0b-bls12-g1add.ts +63 -0
- package/src/precompiles/0c-bls12-g1msm.ts +87 -0
- package/src/precompiles/0d-bls12-g2add.ts +66 -0
- package/src/precompiles/0e-bls12-g2msm.ts +84 -0
- package/src/precompiles/0f-bls12-pairing.ts +86 -0
- package/src/precompiles/10-bls12-map-fp-to-g1.ts +58 -0
- package/src/precompiles/100-p256verify.ts +152 -0
- package/src/precompiles/11-bls12-map-fp2-to-g2.ts +61 -0
- package/src/precompiles/bls12_381/constants.ts +278 -0
- package/src/precompiles/bls12_381/index.ts +4 -0
- package/src/precompiles/bls12_381/mcl.ts +376 -0
- package/src/precompiles/bls12_381/noble.ts +307 -0
- package/src/precompiles/bls12_381/util.ts +78 -0
- package/src/precompiles/bn254/index.ts +2 -0
- package/src/precompiles/bn254/noble.ts +156 -0
- package/src/precompiles/bn254/rustbn.ts +35 -0
- package/src/precompiles/index.ts +344 -0
- package/src/precompiles/types.ts +15 -0
- package/src/precompiles/util.ts +70 -0
- package/src/stack.ts +166 -0
- package/src/stemCache.ts +45 -0
- package/src/transientStorage.ts +131 -0
- package/src/types.ts +538 -0
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import { BIGINT_0, BIGINT_1, BIGINT_2, BIGINT_7, BIGINT_8, BIGINT_32, BIGINT_64, BIGINT_96, bigIntToBytes, bytesToBigInt, bytesToHex, setLengthLeft, setLengthRight, } from '@feelyourprotocol/util';
|
|
2
|
+
import { OOGResult } from "../evm.js";
|
|
3
|
+
import { getPrecompileName } from "./index.js";
|
|
4
|
+
import { gasLimitCheck } from "./util.js";
|
|
5
|
+
const BIGINT_4 = BigInt(4);
|
|
6
|
+
const BIGINT_16 = BigInt(16);
|
|
7
|
+
const BIGINT_480 = BigInt(480);
|
|
8
|
+
const BIGINT_200 = BigInt(200);
|
|
9
|
+
const BIGINT_500 = BigInt(500);
|
|
10
|
+
const BIGINT_1024 = BigInt(1024);
|
|
11
|
+
const BIGINT_3072 = BigInt(3072);
|
|
12
|
+
const BIGINT_199680 = BigInt(199680);
|
|
13
|
+
const BIGINT_2147483647 = BigInt(2147483647);
|
|
14
|
+
const maxInt = BigInt(Number.MAX_SAFE_INTEGER);
|
|
15
|
+
function multiplicationComplexity(x) {
|
|
16
|
+
let fac1;
|
|
17
|
+
let fac2;
|
|
18
|
+
if (x <= BIGINT_64) {
|
|
19
|
+
return x ** BIGINT_2;
|
|
20
|
+
}
|
|
21
|
+
else if (x <= BIGINT_1024) {
|
|
22
|
+
// return Math.floor(Math.pow(x, 2) / 4) + 96 * x - 3072
|
|
23
|
+
fac1 = x ** BIGINT_2 / BIGINT_4;
|
|
24
|
+
fac2 = x * BIGINT_96;
|
|
25
|
+
return fac1 + fac2 - BIGINT_3072;
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
// return Math.floor(Math.pow(x, 2) / 16) + 480 * x - 199680
|
|
29
|
+
fac1 = x ** BIGINT_2 / BIGINT_16;
|
|
30
|
+
fac2 = x * BIGINT_480;
|
|
31
|
+
return fac1 + fac2 - BIGINT_199680;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function getAdjustedExponentLength(data, opts) {
|
|
35
|
+
let expBytesStart;
|
|
36
|
+
try {
|
|
37
|
+
const baseLen = bytesToBigInt(data.subarray(0, 32));
|
|
38
|
+
expBytesStart = 96 + Number(baseLen); // 96 for base length, then exponent length, and modulus length, then baseLen for the base data, then exponent bytes start
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
expBytesStart = Number.MAX_SAFE_INTEGER - 32;
|
|
42
|
+
}
|
|
43
|
+
const expLen = bytesToBigInt(data.subarray(32, 64));
|
|
44
|
+
let firstExpBytes = data.subarray(expBytesStart, expBytesStart + 32); // first word of the exponent data
|
|
45
|
+
firstExpBytes = setLengthRight(firstExpBytes, 32); // reading past the data reads virtual zeros
|
|
46
|
+
let firstExpBigInt = bytesToBigInt(firstExpBytes);
|
|
47
|
+
let max32expLen = 0;
|
|
48
|
+
if (expLen < BIGINT_32) {
|
|
49
|
+
max32expLen = 32 - Number(expLen);
|
|
50
|
+
}
|
|
51
|
+
firstExpBigInt = firstExpBigInt >> (BIGINT_8 * BigInt(Math.max(max32expLen, 0)));
|
|
52
|
+
let bitLen = -1;
|
|
53
|
+
while (firstExpBigInt > BIGINT_0) {
|
|
54
|
+
bitLen = bitLen + 1;
|
|
55
|
+
firstExpBigInt = firstExpBigInt >> BIGINT_1;
|
|
56
|
+
}
|
|
57
|
+
let expLenMinus32OrZero = expLen - BIGINT_32;
|
|
58
|
+
if (expLenMinus32OrZero < BIGINT_0) {
|
|
59
|
+
expLenMinus32OrZero = BIGINT_0;
|
|
60
|
+
}
|
|
61
|
+
let adjustedExpLen = expLenMinus32OrZero * (opts.common.isActivatedEIP(7883) === true ? BIGINT_16 : BIGINT_8);
|
|
62
|
+
if (bitLen > 0) {
|
|
63
|
+
adjustedExpLen += BigInt(bitLen);
|
|
64
|
+
}
|
|
65
|
+
return adjustedExpLen;
|
|
66
|
+
}
|
|
67
|
+
export function expMod(a, power, modulo) {
|
|
68
|
+
if (power === BIGINT_0) {
|
|
69
|
+
return BIGINT_1 % modulo;
|
|
70
|
+
}
|
|
71
|
+
let res = BIGINT_1;
|
|
72
|
+
while (power > BIGINT_0) {
|
|
73
|
+
if (power & BIGINT_1)
|
|
74
|
+
res = (res * a) % modulo;
|
|
75
|
+
a = (a * a) % modulo;
|
|
76
|
+
power >>= BIGINT_1;
|
|
77
|
+
}
|
|
78
|
+
return res;
|
|
79
|
+
}
|
|
80
|
+
export function precompile05(opts) {
|
|
81
|
+
const pName = getPrecompileName('05');
|
|
82
|
+
const data = opts.data.length < 96 ? setLengthRight(opts.data, 96) : opts.data;
|
|
83
|
+
let adjustedELen = getAdjustedExponentLength(data, opts);
|
|
84
|
+
if (adjustedELen < BIGINT_1) {
|
|
85
|
+
adjustedELen = BIGINT_1;
|
|
86
|
+
}
|
|
87
|
+
const bLen = bytesToBigInt(data.subarray(0, 32));
|
|
88
|
+
const eLen = bytesToBigInt(data.subarray(32, 64));
|
|
89
|
+
const mLen = bytesToBigInt(data.subarray(64, 96));
|
|
90
|
+
let maxLen = bLen;
|
|
91
|
+
if (maxLen < mLen) {
|
|
92
|
+
maxLen = mLen;
|
|
93
|
+
}
|
|
94
|
+
const Gquaddivisor = opts.common.param('modexpGquaddivisorGas');
|
|
95
|
+
let gasUsed;
|
|
96
|
+
const bStart = BIGINT_96;
|
|
97
|
+
const bEnd = bStart + bLen;
|
|
98
|
+
const eStart = bEnd;
|
|
99
|
+
const eEnd = eStart + eLen;
|
|
100
|
+
const mStart = eEnd;
|
|
101
|
+
const mEnd = mStart + mLen;
|
|
102
|
+
if (opts.common.isActivatedEIP(2565)) {
|
|
103
|
+
const words = (maxLen + BIGINT_7) / BIGINT_8;
|
|
104
|
+
if (opts.common.isActivatedEIP(7883)) {
|
|
105
|
+
gasUsed = adjustedELen * (maxLen > BIGINT_32 ? BIGINT_2 * words * words : BIGINT_16);
|
|
106
|
+
if (gasUsed < BIGINT_500) {
|
|
107
|
+
gasUsed = BIGINT_500;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
gasUsed = (adjustedELen * words * words) / Gquaddivisor;
|
|
112
|
+
if (gasUsed < BIGINT_200) {
|
|
113
|
+
gasUsed = BIGINT_200;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
gasUsed = (adjustedELen * multiplicationComplexity(maxLen)) / Gquaddivisor;
|
|
119
|
+
}
|
|
120
|
+
if (!gasLimitCheck(opts, gasUsed, pName)) {
|
|
121
|
+
return OOGResult(opts.gasLimit);
|
|
122
|
+
}
|
|
123
|
+
// Upper bounds by EIP-7823 (Osaka and upwards) or otherwise
|
|
124
|
+
// @feelyourprotocol/util setLengthRight limitation
|
|
125
|
+
const maxSize = opts.common.isActivatedEIP(7823) ? BIGINT_1024 : BIGINT_2147483647;
|
|
126
|
+
if (opts._debug !== undefined) {
|
|
127
|
+
// Lengths value debugging
|
|
128
|
+
const total = BigInt(96) + bLen + eLen + mLen;
|
|
129
|
+
const data = BigInt(opts.data.length);
|
|
130
|
+
let msg = `${pName} length values: maxSize(b/e/m)=${maxSize} bLen=${bLen} eLen=${eLen} mLen=${mLen} 96+b+e+m=${total} `;
|
|
131
|
+
msg += `data=${data} lengthMatch=${total === data}`;
|
|
132
|
+
opts._debug(msg);
|
|
133
|
+
}
|
|
134
|
+
// Optimization: do not compute for b and m being 0 but return early
|
|
135
|
+
if (!opts.common.isActivatedEIP(7823) && bLen === BIGINT_0 && mLen === BIGINT_0) {
|
|
136
|
+
return {
|
|
137
|
+
executionGasUsed: gasUsed,
|
|
138
|
+
returnValue: new Uint8Array(),
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
if (bLen > maxSize || eLen > maxSize || mLen > maxSize) {
|
|
142
|
+
if (opts._debug !== undefined) {
|
|
143
|
+
opts._debug(`${pName} failed: one or more input values too large`);
|
|
144
|
+
}
|
|
145
|
+
return OOGResult(opts.gasLimit);
|
|
146
|
+
}
|
|
147
|
+
if (mEnd > maxInt) {
|
|
148
|
+
if (opts._debug !== undefined) {
|
|
149
|
+
opts._debug(`${pName} failed: total input too large`);
|
|
150
|
+
}
|
|
151
|
+
return OOGResult(opts.gasLimit);
|
|
152
|
+
}
|
|
153
|
+
const B = bytesToBigInt(setLengthRight(data.subarray(Number(bStart), Number(bEnd)), Number(bLen)));
|
|
154
|
+
const E = bytesToBigInt(setLengthRight(data.subarray(Number(eStart), Number(eEnd)), Number(eLen)));
|
|
155
|
+
const M = bytesToBigInt(setLengthRight(data.subarray(Number(mStart), Number(mEnd)), Number(mLen)));
|
|
156
|
+
if (opts._debug !== undefined) {
|
|
157
|
+
opts._debug(`${pName} input: B=${B} E=${E} M=${M}`);
|
|
158
|
+
}
|
|
159
|
+
let R;
|
|
160
|
+
if (M === BIGINT_0) {
|
|
161
|
+
R = new Uint8Array();
|
|
162
|
+
}
|
|
163
|
+
else {
|
|
164
|
+
R = expMod(B, E, M);
|
|
165
|
+
if (R === BIGINT_0) {
|
|
166
|
+
R = new Uint8Array();
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
R = bigIntToBytes(R);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
const res = setLengthLeft(R, Number(mLen));
|
|
173
|
+
if (opts._debug !== undefined) {
|
|
174
|
+
opts._debug(`${pName} return value=${bytesToHex(res)}`);
|
|
175
|
+
}
|
|
176
|
+
return {
|
|
177
|
+
executionGasUsed: gasUsed,
|
|
178
|
+
returnValue: res,
|
|
179
|
+
};
|
|
180
|
+
}
|
|
181
|
+
//# sourceMappingURL=05-modexp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"05-modexp.js","sourceRoot":"","sources":["../../../src/precompiles/05-modexp.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"06-bn254-add.d.ts","sourceRoot":"","sources":["../../../src/precompiles/06-bn254-add.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,wBAAgB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,UAAU,CAqC9D"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { bytesToHex, setLengthRight } from '@feelyourprotocol/util';
|
|
2
|
+
import { EVMErrorResult, OOGResult } from "../evm.js";
|
|
3
|
+
import { getPrecompileName } from "./index.js";
|
|
4
|
+
import { gasLimitCheck } from "./util.js";
|
|
5
|
+
export function precompile06(opts) {
|
|
6
|
+
const pName = getPrecompileName('06');
|
|
7
|
+
const gasUsed = opts.common.param('bn254AddGas');
|
|
8
|
+
if (!gasLimitCheck(opts, gasUsed, pName)) {
|
|
9
|
+
return OOGResult(opts.gasLimit);
|
|
10
|
+
}
|
|
11
|
+
// > 128 bytes: chop off extra bytes
|
|
12
|
+
// < 128 bytes: right-pad with 0-s
|
|
13
|
+
const input = setLengthRight(opts.data.subarray(0, 128), 128);
|
|
14
|
+
let returnData;
|
|
15
|
+
try {
|
|
16
|
+
returnData = opts._EVM['_bn254'].add(input);
|
|
17
|
+
}
|
|
18
|
+
catch (e) {
|
|
19
|
+
if (opts._debug !== undefined) {
|
|
20
|
+
opts._debug(`${pName} failed: ${e.message}`);
|
|
21
|
+
}
|
|
22
|
+
return EVMErrorResult(e, opts.gasLimit);
|
|
23
|
+
}
|
|
24
|
+
// check ecadd success or failure by comparing the output length
|
|
25
|
+
if (returnData.length !== 64) {
|
|
26
|
+
if (opts._debug !== undefined) {
|
|
27
|
+
opts._debug(`${pName} failed: OOG`);
|
|
28
|
+
}
|
|
29
|
+
return OOGResult(opts.gasLimit);
|
|
30
|
+
}
|
|
31
|
+
if (opts._debug !== undefined) {
|
|
32
|
+
opts._debug(`${pName} return value=${bytesToHex(returnData)}`);
|
|
33
|
+
}
|
|
34
|
+
return {
|
|
35
|
+
executionGasUsed: gasUsed,
|
|
36
|
+
returnValue: returnData,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=06-bn254-add.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"06-bn254-add.js","sourceRoot":"","sources":["../../../src/precompiles/06-bn254-add.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAE7D,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AAErD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAMzC,MAAM,UAAU,YAAY,CAAC,IAAqB;IAChD,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACrC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;IAChD,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC;QACzC,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjC,CAAC;IAED,oCAAoC;IACpC,kCAAkC;IAClC,MAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAA;IAE7D,IAAI,UAAU,CAAA;IACd,IAAI,CAAC;QACH,UAAU,GAAI,IAAI,CAAC,IAAY,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IACtD,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,YAAY,CAAC,CAAC,OAAO,EAAE,CAAC,CAAA;QAC9C,CAAC;QACD,OAAO,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;IACzC,CAAC;IAED,gEAAgE;IAChE,IAAI,UAAU,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,cAAc,CAAC,CAAA;QACrC,CAAC;QACD,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjC,CAAC;IAED,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,iBAAiB,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;IAChE,CAAC;IAED,OAAO;QACL,gBAAgB,EAAE,OAAO;QACzB,WAAW,EAAE,UAAU;KACxB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"07-bn254-mul.d.ts","sourceRoot":"","sources":["../../../src/precompiles/07-bn254-mul.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,wBAAgB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,UAAU,CAsC9D"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { bytesToHex, setLengthRight } from '@feelyourprotocol/util';
|
|
2
|
+
import { EVMErrorResult, OOGResult } from "../evm.js";
|
|
3
|
+
import { getPrecompileName } from "./index.js";
|
|
4
|
+
import { gasLimitCheck } from "./util.js";
|
|
5
|
+
export function precompile07(opts) {
|
|
6
|
+
const pName = getPrecompileName('07');
|
|
7
|
+
const gasUsed = opts.common.param('bn254MulGas');
|
|
8
|
+
if (!gasLimitCheck(opts, gasUsed, pName)) {
|
|
9
|
+
return OOGResult(opts.gasLimit);
|
|
10
|
+
}
|
|
11
|
+
// > 128 bytes: chop off extra bytes
|
|
12
|
+
// < 128 bytes: right-pad with 0-s
|
|
13
|
+
const input = setLengthRight(opts.data.subarray(0, 128), 128);
|
|
14
|
+
let returnData;
|
|
15
|
+
try {
|
|
16
|
+
returnData = opts._EVM['_bn254'].mul(input);
|
|
17
|
+
}
|
|
18
|
+
catch (e) {
|
|
19
|
+
if (opts._debug !== undefined) {
|
|
20
|
+
opts._debug(`${pName} failed: ${e.message}`);
|
|
21
|
+
}
|
|
22
|
+
return EVMErrorResult(e, opts.gasLimit);
|
|
23
|
+
}
|
|
24
|
+
// check ecmul success or failure by comparing the output length
|
|
25
|
+
if (returnData.length !== 64) {
|
|
26
|
+
if (opts._debug !== undefined) {
|
|
27
|
+
opts._debug(`${pName} failed: OOG`);
|
|
28
|
+
}
|
|
29
|
+
// TODO: should this really return OOG?
|
|
30
|
+
return OOGResult(opts.gasLimit);
|
|
31
|
+
}
|
|
32
|
+
if (opts._debug !== undefined) {
|
|
33
|
+
opts._debug(`${pName} return value=${bytesToHex(returnData)}`);
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
executionGasUsed: gasUsed,
|
|
37
|
+
returnValue: returnData,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=07-bn254-mul.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"07-bn254-mul.js","sourceRoot":"","sources":["../../../src/precompiles/07-bn254-mul.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAE7D,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AAErD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAMzC,MAAM,UAAU,YAAY,CAAC,IAAqB;IAChD,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACrC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;IAChD,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC;QACzC,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjC,CAAC;IAED,oCAAoC;IACpC,kCAAkC;IAClC,MAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAA;IAE7D,IAAI,UAAU,CAAA;IACd,IAAI,CAAC;QACH,UAAU,GAAI,IAAI,CAAC,IAAY,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IACtD,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,YAAY,CAAC,CAAC,OAAO,EAAE,CAAC,CAAA;QAC9C,CAAC;QACD,OAAO,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;IACzC,CAAC;IAED,gEAAgE;IAChE,IAAI,UAAU,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,cAAc,CAAC,CAAA;QACrC,CAAC;QACD,uCAAuC;QACvC,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjC,CAAC;IAED,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,iBAAiB,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;IAChE,CAAC;IAED,OAAO;QACL,gBAAgB,EAAE,OAAO;QACzB,WAAW,EAAE,UAAU;KACxB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"08-bn254-pairing.d.ts","sourceRoot":"","sources":["../../../src/precompiles/08-bn254-pairing.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,wBAAgB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,UAAU,CAyC9D"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { bytesToHex } from '@feelyourprotocol/util';
|
|
2
|
+
import { EVMError } from "../errors.js";
|
|
3
|
+
import { EVMErrorResult, OOGResult } from "../evm.js";
|
|
4
|
+
import { getPrecompileName } from "./index.js";
|
|
5
|
+
import { gasLimitCheck, moduloLengthCheck } from "./util.js";
|
|
6
|
+
export function precompile08(opts) {
|
|
7
|
+
const pName = getPrecompileName('08');
|
|
8
|
+
if (!moduloLengthCheck(opts, 192, pName)) {
|
|
9
|
+
return EVMErrorResult(new EVMError(EVMError.errorMessages.INVALID_INPUT_LENGTH), opts.gasLimit);
|
|
10
|
+
}
|
|
11
|
+
const inputDataSize = BigInt(Math.floor(opts.data.length / 192));
|
|
12
|
+
const gasUsed = opts.common.param('bn254PairingGas') + inputDataSize * opts.common.param('bn254PairingWordGas');
|
|
13
|
+
if (!gasLimitCheck(opts, gasUsed, pName)) {
|
|
14
|
+
return OOGResult(opts.gasLimit);
|
|
15
|
+
}
|
|
16
|
+
let returnData;
|
|
17
|
+
try {
|
|
18
|
+
returnData = opts._EVM['_bn254'].pairing(opts.data);
|
|
19
|
+
}
|
|
20
|
+
catch (e) {
|
|
21
|
+
if (opts._debug !== undefined) {
|
|
22
|
+
opts._debug(`${pName} failed: ${e.message}`);
|
|
23
|
+
}
|
|
24
|
+
return EVMErrorResult(e, opts.gasLimit);
|
|
25
|
+
}
|
|
26
|
+
// check ecpairing success or failure by comparing the output length
|
|
27
|
+
if (returnData.length !== 32) {
|
|
28
|
+
if (opts._debug !== undefined) {
|
|
29
|
+
opts._debug(`${pName} failed: OOG`);
|
|
30
|
+
}
|
|
31
|
+
// TODO: should this really return OOG?
|
|
32
|
+
return OOGResult(opts.gasLimit);
|
|
33
|
+
}
|
|
34
|
+
if (opts._debug !== undefined) {
|
|
35
|
+
opts._debug(`${pName} return value=${bytesToHex(returnData)}`);
|
|
36
|
+
}
|
|
37
|
+
return {
|
|
38
|
+
executionGasUsed: gasUsed,
|
|
39
|
+
returnValue: returnData,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=08-bn254-pairing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"08-bn254-pairing.js","sourceRoot":"","sources":["../../../src/precompiles/08-bn254-pairing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAE7C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAA;AACvC,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AAErD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAA;AAM5D,MAAM,UAAU,YAAY,CAAC,IAAqB;IAChD,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACrC,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC;QACzC,OAAO,cAAc,CAAC,IAAI,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,oBAAoB,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjG,CAAC;IAED,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC,CAAA;IAChE,MAAM,OAAO,GACX,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAA;IAEjG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC;QACzC,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjC,CAAC;IAED,IAAI,UAAU,CAAA;IACd,IAAI,CAAC;QACH,UAAU,GAAI,IAAI,CAAC,IAAY,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC9D,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,YAAY,CAAC,CAAC,OAAO,EAAE,CAAC,CAAA;QAC9C,CAAC;QACD,OAAO,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;IACzC,CAAC;IAED,oEAAoE;IACpE,IAAI,UAAU,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,cAAc,CAAC,CAAA;QACrC,CAAC;QACD,uCAAuC;QACvC,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjC,CAAC;IAED,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,iBAAiB,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;IAChE,CAAC;IAED,OAAO;QACL,gBAAgB,EAAE,OAAO;QACzB,WAAW,EAAE,UAAU;KACxB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ExecResult } from '../types.ts';
|
|
2
|
+
import type { PrecompileInput } from './types.ts';
|
|
3
|
+
export declare function F(h: Uint32Array, m: Uint32Array, t: Uint32Array, f: boolean, rounds: number): void;
|
|
4
|
+
export declare function precompile09(opts: PrecompileInput): ExecResult;
|
|
5
|
+
//# sourceMappingURL=09-blake2f.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"09-blake2f.d.ts","sourceRoot":"","sources":["../../../src/precompiles/09-blake2f.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAwHjD,wBAAgB,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,QA0C3F;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,UAAU,CAqE9D"}
|
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import { bytesToHex } from '@feelyourprotocol/util';
|
|
2
|
+
import { EVMError } from "../errors.js";
|
|
3
|
+
import { OOGResult } from "../evm.js";
|
|
4
|
+
import { getPrecompileName } from "./index.js";
|
|
5
|
+
import { gasLimitCheck } from "./util.js";
|
|
6
|
+
// The following blake2 code has been taken from (license: Creative Commons CC0):
|
|
7
|
+
// https://github.com/dcposch/blakejs/blob/410c640d0f08d3b26904c6d1ab3d81df3619d282/blake2b.js
|
|
8
|
+
// The modifications include:
|
|
9
|
+
// - Avoiding the use of context in F
|
|
10
|
+
// - F accepts number of rounds as parameter
|
|
11
|
+
// - Expect 2 64-byte t values, xor them both
|
|
12
|
+
// - Take modulo 10 for indices of SIGMA
|
|
13
|
+
// - Added type annotations
|
|
14
|
+
// - Moved previously global `v` and `m` variables inside the F function
|
|
15
|
+
// 64-bit unsigned addition
|
|
16
|
+
// Sets v[a,a+1] += v[b,b+1]
|
|
17
|
+
// v should be a Uint32Array
|
|
18
|
+
function ADD64AA(v, a, b) {
|
|
19
|
+
const o0 = v[a] + v[b];
|
|
20
|
+
let o1 = v[a + 1] + v[b + 1];
|
|
21
|
+
if (o0 >= 0x100000000) {
|
|
22
|
+
o1++;
|
|
23
|
+
}
|
|
24
|
+
v[a] = o0;
|
|
25
|
+
v[a + 1] = o1;
|
|
26
|
+
}
|
|
27
|
+
// 64-bit unsigned addition
|
|
28
|
+
// Sets v[a,a+1] += b
|
|
29
|
+
// b0 is the low 32 bits of b, b1 represents the high 32 bits
|
|
30
|
+
function ADD64AC(v, a, b0, b1) {
|
|
31
|
+
let o0 = v[a] + b0;
|
|
32
|
+
if (b0 < 0) {
|
|
33
|
+
o0 += 0x100000000;
|
|
34
|
+
}
|
|
35
|
+
let o1 = v[a + 1] + b1;
|
|
36
|
+
if (o0 >= 0x100000000) {
|
|
37
|
+
o1++;
|
|
38
|
+
}
|
|
39
|
+
v[a] = o0;
|
|
40
|
+
v[a + 1] = o1;
|
|
41
|
+
}
|
|
42
|
+
// G Mixing function
|
|
43
|
+
// The ROTRs are inlined for speed
|
|
44
|
+
function B2B_G(v, mw, a, b, c, d, ix, iy) {
|
|
45
|
+
const x0 = mw[ix];
|
|
46
|
+
const x1 = mw[ix + 1];
|
|
47
|
+
const y0 = mw[iy];
|
|
48
|
+
const y1 = mw[iy + 1];
|
|
49
|
+
ADD64AA(v, a, b); // v[a,a+1] += v[b,b+1] ... in JS we must store a uint64 as two uint32s
|
|
50
|
+
ADD64AC(v, a, x0, x1); // v[a, a+1] += x ... x0 is the low 32 bits of x, x1 is the high 32 bits
|
|
51
|
+
// v[d,d+1] = (v[d,d+1] xor v[a,a+1]) rotated to the right by 32 bits
|
|
52
|
+
let xor0 = v[d] ^ v[a];
|
|
53
|
+
let xor1 = v[d + 1] ^ v[a + 1];
|
|
54
|
+
v[d] = xor1;
|
|
55
|
+
v[d + 1] = xor0;
|
|
56
|
+
ADD64AA(v, c, d);
|
|
57
|
+
// v[b,b+1] = (v[b,b+1] xor v[c,c+1]) rotated right by 24 bits
|
|
58
|
+
xor0 = v[b] ^ v[c];
|
|
59
|
+
xor1 = v[b + 1] ^ v[c + 1];
|
|
60
|
+
v[b] = (xor0 >>> 24) ^ (xor1 << 8);
|
|
61
|
+
v[b + 1] = (xor1 >>> 24) ^ (xor0 << 8);
|
|
62
|
+
ADD64AA(v, a, b);
|
|
63
|
+
ADD64AC(v, a, y0, y1);
|
|
64
|
+
// v[d,d+1] = (v[d,d+1] xor v[a,a+1]) rotated right by 16 bits
|
|
65
|
+
xor0 = v[d] ^ v[a];
|
|
66
|
+
xor1 = v[d + 1] ^ v[a + 1];
|
|
67
|
+
v[d] = (xor0 >>> 16) ^ (xor1 << 16);
|
|
68
|
+
v[d + 1] = (xor1 >>> 16) ^ (xor0 << 16);
|
|
69
|
+
ADD64AA(v, c, d);
|
|
70
|
+
// v[b,b+1] = (v[b,b+1] xor v[c,c+1]) rotated right by 63 bits
|
|
71
|
+
xor0 = v[b] ^ v[c];
|
|
72
|
+
xor1 = v[b + 1] ^ v[c + 1];
|
|
73
|
+
v[b] = (xor1 >>> 31) ^ (xor0 << 1);
|
|
74
|
+
v[b + 1] = (xor0 >>> 31) ^ (xor1 << 1);
|
|
75
|
+
}
|
|
76
|
+
// Initialization Vector
|
|
77
|
+
// prettier-ignore
|
|
78
|
+
const BLAKE2B_IV32 = new Uint32Array([
|
|
79
|
+
0xf3bcc908, 0x6a09e667, 0x84caa73b, 0xbb67ae85, 0xfe94f82b, 0x3c6ef372, 0x5f1d36f1, 0xa54ff53a,
|
|
80
|
+
0xade682d1, 0x510e527f, 0x2b3e6c1f, 0x9b05688c, 0xfb41bd6b, 0x1f83d9ab, 0x137e2179, 0x5be0cd19,
|
|
81
|
+
]);
|
|
82
|
+
// prettier-ignore
|
|
83
|
+
const SIGMA8 = [
|
|
84
|
+
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11,
|
|
85
|
+
7, 5, 3, 11, 8, 12, 0, 5, 2, 15, 13, 10, 14, 3, 6, 7, 1, 9, 4, 7, 9, 3, 1, 13, 12, 11, 14, 2, 6,
|
|
86
|
+
5, 10, 4, 0, 15, 8, 9, 0, 5, 7, 2, 4, 10, 15, 14, 1, 11, 12, 6, 8, 3, 13, 2, 12, 6, 10, 0, 11, 8,
|
|
87
|
+
3, 4, 13, 7, 5, 15, 14, 1, 9, 12, 5, 1, 15, 14, 13, 4, 10, 0, 7, 6, 3, 9, 2, 8, 11, 13, 11, 7, 14,
|
|
88
|
+
12, 1, 3, 9, 5, 0, 15, 4, 8, 6, 2, 10, 6, 15, 14, 9, 11, 3, 0, 8, 12, 2, 13, 7, 1, 4, 10, 5, 10,
|
|
89
|
+
2, 8, 4, 7, 6, 1, 5, 15, 11, 9, 14, 3, 12, 13, 0, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,
|
|
90
|
+
14, 15, 14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3,
|
|
91
|
+
];
|
|
92
|
+
// These are offsets into a uint64 buffer.
|
|
93
|
+
// Multiply them all by 2 to make them offsets into a uint32 buffer,
|
|
94
|
+
// because this is Javascript and we don't have uint64s
|
|
95
|
+
const SIGMA82 = new Uint8Array(SIGMA8.map(function (x) {
|
|
96
|
+
return x * 2;
|
|
97
|
+
}));
|
|
98
|
+
export function F(h, m, t, f, rounds) {
|
|
99
|
+
const v = new Uint32Array(32);
|
|
100
|
+
let i = 0;
|
|
101
|
+
// init work variables
|
|
102
|
+
for (i = 0; i < 16; i++) {
|
|
103
|
+
v[i] = h[i];
|
|
104
|
+
v[i + 16] = BLAKE2B_IV32[i];
|
|
105
|
+
}
|
|
106
|
+
// 128 bits of offset
|
|
107
|
+
v[24] = v[24] ^ t[0];
|
|
108
|
+
v[25] = v[25] ^ t[1];
|
|
109
|
+
v[26] = v[26] ^ t[2];
|
|
110
|
+
v[27] = v[27] ^ t[3];
|
|
111
|
+
// last block flag set ?
|
|
112
|
+
if (f) {
|
|
113
|
+
v[28] = ~v[28];
|
|
114
|
+
v[29] = ~v[29];
|
|
115
|
+
}
|
|
116
|
+
// twelve rounds of mixing
|
|
117
|
+
// uncomment the DebugPrint calls to log the computation
|
|
118
|
+
// and match the RFC sample documentation
|
|
119
|
+
// util.debugPrint(' m[16]', m, 64)
|
|
120
|
+
for (i = 0; i < rounds; i++) {
|
|
121
|
+
// util.debugPrint(' (i=' + (i < 10 ? ' ' : '') + i + ') v[16]', v, 64)
|
|
122
|
+
const ri = (i % 10) * 16;
|
|
123
|
+
B2B_G(v, m, 0, 8, 16, 24, SIGMA82[ri + 0], SIGMA82[ri + 1]);
|
|
124
|
+
B2B_G(v, m, 2, 10, 18, 26, SIGMA82[ri + 2], SIGMA82[ri + 3]);
|
|
125
|
+
B2B_G(v, m, 4, 12, 20, 28, SIGMA82[ri + 4], SIGMA82[ri + 5]);
|
|
126
|
+
B2B_G(v, m, 6, 14, 22, 30, SIGMA82[ri + 6], SIGMA82[ri + 7]);
|
|
127
|
+
B2B_G(v, m, 0, 10, 20, 30, SIGMA82[ri + 8], SIGMA82[ri + 9]);
|
|
128
|
+
B2B_G(v, m, 2, 12, 22, 24, SIGMA82[ri + 10], SIGMA82[ri + 11]);
|
|
129
|
+
B2B_G(v, m, 4, 14, 16, 26, SIGMA82[ri + 12], SIGMA82[ri + 13]);
|
|
130
|
+
B2B_G(v, m, 6, 8, 18, 28, SIGMA82[ri + 14], SIGMA82[ri + 15]);
|
|
131
|
+
}
|
|
132
|
+
for (i = 0; i < 16; i++) {
|
|
133
|
+
h[i] = h[i] ^ v[i] ^ v[i + 16];
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
export function precompile09(opts) {
|
|
137
|
+
const pName = getPrecompileName('09');
|
|
138
|
+
const data = opts.data;
|
|
139
|
+
if (data.length !== 213) {
|
|
140
|
+
if (opts._debug !== undefined) {
|
|
141
|
+
opts._debug(`${pName} failed: OUT_OF_RANGE dataLength=${data.length}`);
|
|
142
|
+
}
|
|
143
|
+
return {
|
|
144
|
+
returnValue: new Uint8Array(0),
|
|
145
|
+
executionGasUsed: opts.gasLimit,
|
|
146
|
+
exceptionError: new EVMError(EVMError.errorMessages.OUT_OF_RANGE),
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
const lastByte = data.subarray(212, 213)[0];
|
|
150
|
+
if (lastByte !== 1 && lastByte !== 0) {
|
|
151
|
+
if (opts._debug !== undefined) {
|
|
152
|
+
opts._debug(`${pName} failed: OUT_OF_RANGE lastByte=${lastByte}`);
|
|
153
|
+
}
|
|
154
|
+
return {
|
|
155
|
+
returnValue: new Uint8Array(0),
|
|
156
|
+
executionGasUsed: opts.gasLimit,
|
|
157
|
+
exceptionError: new EVMError(EVMError.errorMessages.OUT_OF_RANGE),
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
const rounds = new DataView(data.buffer, data.byteOffset).getUint32(0);
|
|
161
|
+
const hRaw = new DataView(data.buffer, data.byteOffset + 4, 64);
|
|
162
|
+
const mRaw = new DataView(data.buffer, data.byteOffset + 68, 128);
|
|
163
|
+
const tRaw = new DataView(data.buffer, data.byteOffset + 196, 16);
|
|
164
|
+
// final
|
|
165
|
+
const f = lastByte === 1;
|
|
166
|
+
let gasUsed = opts.common.param('blake2RoundGas');
|
|
167
|
+
gasUsed *= BigInt(rounds);
|
|
168
|
+
if (!gasLimitCheck(opts, gasUsed, pName)) {
|
|
169
|
+
return OOGResult(opts.gasLimit);
|
|
170
|
+
}
|
|
171
|
+
const h = new Uint32Array(16);
|
|
172
|
+
for (let i = 0; i < 16; i++) {
|
|
173
|
+
h[i] = hRaw.getUint32(i * 4, true);
|
|
174
|
+
}
|
|
175
|
+
const m = new Uint32Array(32);
|
|
176
|
+
for (let i = 0; i < 32; i++) {
|
|
177
|
+
m[i] = mRaw.getUint32(i * 4, true);
|
|
178
|
+
}
|
|
179
|
+
const t = new Uint32Array(4);
|
|
180
|
+
for (let i = 0; i < 4; i++) {
|
|
181
|
+
t[i] = tRaw.getUint32(i * 4, true);
|
|
182
|
+
}
|
|
183
|
+
F(h, m, t, f, rounds);
|
|
184
|
+
const output = new Uint8Array(64);
|
|
185
|
+
const outputView = new DataView(output.buffer);
|
|
186
|
+
for (let i = 0; i < 16; i++) {
|
|
187
|
+
outputView.setUint32(i * 4, h[i], true);
|
|
188
|
+
}
|
|
189
|
+
if (opts._debug !== undefined) {
|
|
190
|
+
opts._debug(`${pName} return hash=${bytesToHex(output)}`);
|
|
191
|
+
}
|
|
192
|
+
return {
|
|
193
|
+
executionGasUsed: gasUsed,
|
|
194
|
+
returnValue: output,
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
//# sourceMappingURL=09-blake2f.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"09-blake2f.js","sourceRoot":"","sources":["../../../src/precompiles/09-blake2f.ts"],"names":[],"mappings":"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,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;IACjG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC;IAC/F,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;IAChG,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE;IACjG,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ExecResult } from '../types.ts';
|
|
2
|
+
import type { PrecompileInput } from './types.ts';
|
|
3
|
+
export declare const BLS_MODULUS: bigint;
|
|
4
|
+
export declare function precompile0a(opts: PrecompileInput): Promise<ExecResult>;
|
|
5
|
+
//# sourceMappingURL=0a-kzg-point-evaluation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"0a-kzg-point-evaluation.d.ts","sourceRoot":"","sources":["../../../src/precompiles/0a-kzg-point-evaluation.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,eAAO,MAAM,WAAW,QAEvB,CAAA;AAID,wBAAsB,YAAY,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,UAAU,CAAC,CAqE7E"}
|