mirror of
https://github.com/pezkuwichain/revive.git
synced 2026-06-14 18:01:05 +00:00
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 9c83352fdb | |||
| bb2f829361 | |||
| 1b8fcc4649 | |||
| 0e9e405f21 | |||
| 722dd86c27 |
@@ -3,7 +3,7 @@ inputs:
|
|||||||
version:
|
version:
|
||||||
description: ""
|
description: ""
|
||||||
required: false
|
required: false
|
||||||
default: "3.1.64"
|
default: "4.0.9"
|
||||||
|
|
||||||
|
|
||||||
runs:
|
runs:
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ concurrency:
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
CARGO_TERM_COLOR: always
|
CARGO_TERM_COLOR: always
|
||||||
RUST_MUSL_CROSS_IMAGE: messense/rust-musl-cross@sha256:68b86bc7cb2867259e6b233415a665ff4469c28b57763e78c3bfea1c68091561
|
RUST_MUSL_CROSS_IMAGE: messense/rust-musl-cross@sha256:c0154e992adb791c3b848dd008939d19862549204f8cb26f5ca7a00f629e6067
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
check-version-changed:
|
check-version-changed:
|
||||||
|
|||||||
+7
-2
@@ -4,18 +4,23 @@
|
|||||||
|
|
||||||
This is a development pre-release.
|
This is a development pre-release.
|
||||||
|
|
||||||
Supported `polkadot-sdk` rev:`c29e72a8628835e34deb6aa7db9a78a2e4eabcee`
|
Supported `polkadot-sdk` rev: `2503.0.1`
|
||||||
|
|
||||||
## v0.1.0
|
## v0.1.0
|
||||||
|
|
||||||
This is a development pre-release.
|
This is a development pre-release.
|
||||||
|
|
||||||
Supported `polkadot-sdk` rev:`c29e72a8628835e34deb6aa7db9a78a2e4eabcee`
|
Supported `polkadot-sdk` rev: `2503.0.1`
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
|
- Add the PolkaVM heap size, stack size and debug info CLI compiler options to the standard JSON settings. This makes the standard JSON input succint for reproducible builds.
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
|
- Supported `polkadot-sdk` version is now `2503.0.1`
|
||||||
|
- The `emsdk` version is now `4.0.9`
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
## v0.1.0-dev.16
|
## v0.1.0-dev.16
|
||||||
|
|||||||
Generated
+1798
-2076
File diff suppressed because it is too large
Load Diff
+5
-6
@@ -11,7 +11,7 @@ authors = [
|
|||||||
license = "MIT/Apache-2.0"
|
license = "MIT/Apache-2.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
repository = "https://github.com/paritytech/revive"
|
repository = "https://github.com/paritytech/revive"
|
||||||
rust-version = "1.81.0"
|
rust-version = "1.85.0"
|
||||||
|
|
||||||
[workspace.dependencies]
|
[workspace.dependencies]
|
||||||
revive-benchmarks = { version = "0.1.0-dev.16", path = "crates/benchmarks" }
|
revive-benchmarks = { version = "0.1.0-dev.16", path = "crates/benchmarks" }
|
||||||
@@ -31,7 +31,7 @@ revive-build-utils = { version = "0.1.0-dev.16", path = "crates/build-utils" }
|
|||||||
|
|
||||||
hex = "0.4.3"
|
hex = "0.4.3"
|
||||||
cc = "1.2"
|
cc = "1.2"
|
||||||
libc = "0.2.169"
|
libc = "0.2.172"
|
||||||
tempfile = "3.17"
|
tempfile = "3.17"
|
||||||
anyhow = "1.0"
|
anyhow = "1.0"
|
||||||
semver = { version = "1.0", features = ["serde"] }
|
semver = { version = "1.0", features = ["serde"] }
|
||||||
@@ -73,14 +73,13 @@ assert_fs = "1.1"
|
|||||||
# polkadot-sdk and friends
|
# polkadot-sdk and friends
|
||||||
codec = { version = "3.6.12", default-features = false, package = "parity-scale-codec" }
|
codec = { version = "3.6.12", default-features = false, package = "parity-scale-codec" }
|
||||||
scale-info = { version = "2.11.6", default-features = false }
|
scale-info = { version = "2.11.6", default-features = false }
|
||||||
polkadot-sdk = { git = "https://github.com/paritytech/polkadot-sdk", rev = "c29e72a8628835e34deb6aa7db9a78a2e4eabcee" }
|
polkadot-sdk = { version = "2503.0.1" }
|
||||||
|
|
||||||
# llvm
|
# llvm
|
||||||
[workspace.dependencies.inkwell]
|
[workspace.dependencies.inkwell]
|
||||||
git = "https://github.com/TheDan64/inkwell.git"
|
version = "0.6.0"
|
||||||
rev = "7b410298b6a93450adaa90b1841d5805a3038f12"
|
|
||||||
default-features = false
|
default-features = false
|
||||||
features = ["serde", "llvm18-0", "no-libffi-linking", "target-riscv"]
|
features = ["serde", "llvm18-1", "no-libffi-linking", "target-riscv"]
|
||||||
|
|
||||||
[profile.bench]
|
[profile.bench]
|
||||||
inherits = "release"
|
inherits = "release"
|
||||||
|
|||||||
+2
-2
@@ -1,4 +1,4 @@
|
|||||||
FROM rust:1.84.0 AS llvm-builder
|
FROM rust:1.85.0 AS llvm-builder
|
||||||
WORKDIR /opt/revive
|
WORKDIR /opt/revive
|
||||||
|
|
||||||
RUN apt update && \
|
RUN apt update && \
|
||||||
@@ -11,7 +11,7 @@ RUN make install-llvm-builder
|
|||||||
RUN revive-llvm --target-env musl clone
|
RUN revive-llvm --target-env musl clone
|
||||||
RUN revive-llvm --target-env musl build --llvm-projects lld --llvm-projects clang
|
RUN revive-llvm --target-env musl build --llvm-projects lld --llvm-projects clang
|
||||||
|
|
||||||
FROM messense/rust-musl-cross@sha256:68b86bc7cb2867259e6b233415a665ff4469c28b57763e78c3bfea1c68091561 AS resolc-builder
|
FROM messense/rust-musl-cross@sha256:c0154e992adb791c3b848dd008939d19862549204f8cb26f5ca7a00f629e6067 AS resolc-builder
|
||||||
WORKDIR /opt/revive
|
WORKDIR /opt/revive
|
||||||
|
|
||||||
RUN apt update && \
|
RUN apt update && \
|
||||||
|
|||||||
@@ -1,30 +0,0 @@
|
|||||||
# Known issues
|
|
||||||
|
|
||||||
The following is known and we are either working on it or it is a hard limitation. Please do not open a new issue.
|
|
||||||
|
|
||||||
## Release
|
|
||||||
|
|
||||||
`0.1.0-dev-2`
|
|
||||||
|
|
||||||
## Missing features
|
|
||||||
|
|
||||||
- [Libraries with public functions are not supported](https://github.com/paritytech/revive/issues/91)
|
|
||||||
- [Automatic import resolution is not supported](https://github.com/paritytech/revive/issues/98)
|
|
||||||
- The emulated EVM linear contract memory is limited to 64kb in size. Will be fixed with support for metered dynamic memory.
|
|
||||||
- [The contract calldata is currently limited to 1kb in size](https://github.com/paritytech/revive/issues/57)
|
|
||||||
- [EIP-4844 opcodes are not supported](https://github.com/paritytech/revive/issues/64)
|
|
||||||
- [Delegate calls are not supported](https://github.com/paritytech/revive/issues/67)
|
|
||||||
- [The `blockhash` opcode is not supported](https://github.com/paritytech/revive/issues/61)
|
|
||||||
- [The `extcodesize` opcode is not supported](https://github.com/paritytech/revive/issues/58)
|
|
||||||
- [The `origin` opcode is not supported](https://github.com/paritytech/revive/issues/59)
|
|
||||||
- [Gas limits for contract calls are ignored](https://github.com/paritytech/revive/issues/60)
|
|
||||||
- [Gas related opcodes are not supported](https://github.com/paritytech/revive/issues/60)
|
|
||||||
- IPFS metadata hashes are not supported
|
|
||||||
- [Compiled contract artifacts can exceed the pallet static memory limit and fail to deploy](https://github.com/paritytech/revive/issues/96).
|
|
||||||
- [Transfers to inexistant accounts will fail if the transferred value lies below the ED.](https://github.com/paritytech/revive/issues/83) Will be fixed in the pallet to make the ED completely transparent for contracts.
|
|
||||||
|
|
||||||
## Wontfix
|
|
||||||
|
|
||||||
Please consult our documentation to learn more about Solidity and EVM features likely to remain unsupported (and why they will not be supported).
|
|
||||||
|
|
||||||
TODO: Insert link to the relevant documentation section.
|
|
||||||
@@ -38,7 +38,7 @@ pub const MUSL_SNAPSHOTS_URL: &str = "https://git.musl-libc.org/cgit/musl/snapsh
|
|||||||
pub const EMSDK_SOURCE_URL: &str = "https://github.com/emscripten-core/emsdk.git";
|
pub const EMSDK_SOURCE_URL: &str = "https://github.com/emscripten-core/emsdk.git";
|
||||||
|
|
||||||
/// The emscripten SDK version.
|
/// The emscripten SDK version.
|
||||||
pub const EMSDK_VERSION: &str = "3.1.64";
|
pub const EMSDK_VERSION: &str = "4.0.9";
|
||||||
|
|
||||||
/// The subprocess runner.
|
/// The subprocess runner.
|
||||||
///
|
///
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ use std::sync::OnceLock;
|
|||||||
|
|
||||||
pub use self::debug_config::ir_type::IRType as DebugConfigIR;
|
pub use self::debug_config::ir_type::IRType as DebugConfigIR;
|
||||||
pub use self::debug_config::DebugConfig;
|
pub use self::debug_config::DebugConfig;
|
||||||
pub use self::memory::MemoryConfig;
|
|
||||||
pub use self::optimizer::settings::size_level::SizeLevel as OptimizerSettingsSizeLevel;
|
pub use self::optimizer::settings::size_level::SizeLevel as OptimizerSettingsSizeLevel;
|
||||||
pub use self::optimizer::settings::Settings as OptimizerSettings;
|
pub use self::optimizer::settings::Settings as OptimizerSettings;
|
||||||
pub use self::optimizer::Optimizer;
|
pub use self::optimizer::Optimizer;
|
||||||
@@ -76,7 +75,6 @@ pub use self::target_machine::target::Target;
|
|||||||
pub use self::target_machine::TargetMachine;
|
pub use self::target_machine::TargetMachine;
|
||||||
|
|
||||||
pub(crate) mod debug_config;
|
pub(crate) mod debug_config;
|
||||||
pub(crate) mod memory;
|
|
||||||
pub(crate) mod optimizer;
|
pub(crate) mod optimizer;
|
||||||
pub(crate) mod polkavm;
|
pub(crate) mod polkavm;
|
||||||
pub(crate) mod target_machine;
|
pub(crate) mod target_machine;
|
||||||
|
|||||||
@@ -25,8 +25,8 @@ use inkwell::debug_info::AsDIScope;
|
|||||||
use inkwell::debug_info::DIScope;
|
use inkwell::debug_info::DIScope;
|
||||||
use inkwell::types::BasicType;
|
use inkwell::types::BasicType;
|
||||||
use inkwell::values::BasicValue;
|
use inkwell::values::BasicValue;
|
||||||
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory;
|
||||||
|
|
||||||
use crate::memory::MemoryConfig;
|
|
||||||
use crate::optimizer::settings::Settings as OptimizerSettings;
|
use crate::optimizer::settings::Settings as OptimizerSettings;
|
||||||
use crate::optimizer::Optimizer;
|
use crate::optimizer::Optimizer;
|
||||||
use crate::polkavm::DebugConfig;
|
use crate::polkavm::DebugConfig;
|
||||||
@@ -88,7 +88,7 @@ where
|
|||||||
/// The extra LLVM arguments that were used during target initialization.
|
/// The extra LLVM arguments that were used during target initialization.
|
||||||
llvm_arguments: &'ctx [String],
|
llvm_arguments: &'ctx [String],
|
||||||
/// The PVM memory configuration.
|
/// The PVM memory configuration.
|
||||||
memory_config: MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
|
|
||||||
/// The project dependency manager. It can be any entity implementing the trait.
|
/// The project dependency manager. It can be any entity implementing the trait.
|
||||||
/// The manager is used to get information about contracts and their dependencies during
|
/// The manager is used to get information about contracts and their dependencies during
|
||||||
@@ -228,7 +228,7 @@ where
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: DebugConfig,
|
debug_config: DebugConfig,
|
||||||
llvm_arguments: &'ctx [String],
|
llvm_arguments: &'ctx [String],
|
||||||
memory_config: MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
Self::set_data_layout(llvm, &module);
|
Self::set_data_layout(llvm, &module);
|
||||||
Self::link_stdlib_module(llvm, &module);
|
Self::link_stdlib_module(llvm, &module);
|
||||||
|
|||||||
@@ -7,12 +7,12 @@ pub mod evm;
|
|||||||
pub use self::r#const::*;
|
pub use self::r#const::*;
|
||||||
|
|
||||||
use crate::debug_config::DebugConfig;
|
use crate::debug_config::DebugConfig;
|
||||||
use crate::memory::MemoryConfig;
|
|
||||||
use crate::optimizer::settings::Settings as OptimizerSettings;
|
use crate::optimizer::settings::Settings as OptimizerSettings;
|
||||||
|
|
||||||
use anyhow::Context as AnyhowContext;
|
use anyhow::Context as AnyhowContext;
|
||||||
use polkavm_common::program::ProgramBlob;
|
use polkavm_common::program::ProgramBlob;
|
||||||
use polkavm_disassembler::{Disassembler, DisassemblyFormat};
|
use polkavm_disassembler::{Disassembler, DisassemblyFormat};
|
||||||
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory;
|
||||||
use sha3::Digest;
|
use sha3::Digest;
|
||||||
|
|
||||||
use self::context::build::Build;
|
use self::context::build::Build;
|
||||||
@@ -91,7 +91,7 @@ pub trait Dependency {
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: DebugConfig,
|
debug_config: DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<String>;
|
) -> anyhow::Result<String>;
|
||||||
|
|
||||||
/// Resolves a full contract path.
|
/// Resolves a full contract path.
|
||||||
@@ -113,7 +113,7 @@ impl Dependency for DummyDependency {
|
|||||||
_include_metadata_hash: bool,
|
_include_metadata_hash: bool,
|
||||||
_debug_config: DebugConfig,
|
_debug_config: DebugConfig,
|
||||||
_llvm_arguments: &[String],
|
_llvm_arguments: &[String],
|
||||||
_memory_config: MemoryConfig,
|
_memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<String> {
|
) -> anyhow::Result<String> {
|
||||||
Ok(String::new())
|
Ok(String::new())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -94,6 +94,12 @@ impl FindAuthor<<Runtime as frame_system::Config>::AccountId> for Runtime {
|
|||||||
where
|
where
|
||||||
I: 'a + IntoIterator<Item = (frame_support::ConsensusEngineId, &'a [u8])>,
|
I: 'a + IntoIterator<Item = (frame_support::ConsensusEngineId, &'a [u8])>,
|
||||||
{
|
{
|
||||||
Some([0xff; 32].into())
|
Some(
|
||||||
|
[[0xff; 20].as_slice(), [0xee; 12].as_slice()]
|
||||||
|
.concat()
|
||||||
|
.as_slice()
|
||||||
|
.try_into()
|
||||||
|
.unwrap(),
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ description = "Implements the low level runtime API bindings with pallet contrac
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
anyhow = { workspace = true }
|
anyhow = { workspace = true }
|
||||||
inkwell = { workspace = true, features = ["target-riscv", "no-libffi-linking", "llvm18-0"] }
|
inkwell = { workspace = true, features = ["target-riscv", "no-libffi-linking", "llvm18-1"] }
|
||||||
|
|
||||||
revive-common = { workspace = true }
|
revive-common = { workspace = true }
|
||||||
|
|
||||||
|
|||||||
@@ -8,6 +8,8 @@ pub use self::standard_json::input::language::Language as SolcStandardJsonInputL
|
|||||||
pub use self::standard_json::input::settings::metadata::Metadata as SolcStandardJsonInputSettingsMetadata;
|
pub use self::standard_json::input::settings::metadata::Metadata as SolcStandardJsonInputSettingsMetadata;
|
||||||
pub use self::standard_json::input::settings::metadata_hash::MetadataHash as SolcStandardJsonInputSettingsMetadataHash;
|
pub use self::standard_json::input::settings::metadata_hash::MetadataHash as SolcStandardJsonInputSettingsMetadataHash;
|
||||||
pub use self::standard_json::input::settings::optimizer::Optimizer as SolcStandardJsonInputSettingsOptimizer;
|
pub use self::standard_json::input::settings::optimizer::Optimizer as SolcStandardJsonInputSettingsOptimizer;
|
||||||
|
pub use self::standard_json::input::settings::polkavm::memory::MemoryConfig as SolcStandardJsonInputSettingsPolkaVMMemory;
|
||||||
|
pub use self::standard_json::input::settings::polkavm::PolkaVM as SolcStandardJsonInputSettingsPolkaVM;
|
||||||
pub use self::standard_json::input::settings::selection::file::flag::Flag as SolcStandardJsonInputSettingsSelectionFileFlag;
|
pub use self::standard_json::input::settings::selection::file::flag::Flag as SolcStandardJsonInputSettingsSelectionFileFlag;
|
||||||
pub use self::standard_json::input::settings::selection::file::File as SolcStandardJsonInputSettingsSelectionFile;
|
pub use self::standard_json::input::settings::selection::file::File as SolcStandardJsonInputSettingsSelectionFile;
|
||||||
pub use self::standard_json::input::settings::selection::Selection as SolcStandardJsonInputSettingsSelection;
|
pub use self::standard_json::input::settings::selection::Selection as SolcStandardJsonInputSettingsSelection;
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ use crate::standard_json::input::settings::optimizer::Optimizer as SolcStandardJ
|
|||||||
use crate::standard_json::input::settings::selection::Selection as SolcStandardJsonInputSettingsSelection;
|
use crate::standard_json::input::settings::selection::Selection as SolcStandardJsonInputSettingsSelection;
|
||||||
#[cfg(feature = "resolc")]
|
#[cfg(feature = "resolc")]
|
||||||
use crate::warning::Warning;
|
use crate::warning::Warning;
|
||||||
|
use crate::SolcStandardJsonInputSettingsPolkaVM;
|
||||||
|
|
||||||
use self::language::Language;
|
use self::language::Language;
|
||||||
use self::settings::Settings;
|
use self::settings::Settings;
|
||||||
@@ -63,6 +64,7 @@ impl Input {
|
|||||||
optimizer: SolcStandardJsonInputSettingsOptimizer,
|
optimizer: SolcStandardJsonInputSettingsOptimizer,
|
||||||
metadata: Option<SolcStandardJsonInputSettingsMetadata>,
|
metadata: Option<SolcStandardJsonInputSettingsMetadata>,
|
||||||
#[cfg(feature = "resolc")] suppressed_warnings: Option<Vec<Warning>>,
|
#[cfg(feature = "resolc")] suppressed_warnings: Option<Vec<Warning>>,
|
||||||
|
polkavm: Option<SolcStandardJsonInputSettingsPolkaVM>,
|
||||||
) -> anyhow::Result<Self> {
|
) -> anyhow::Result<Self> {
|
||||||
let mut paths: BTreeSet<PathBuf> = paths.iter().cloned().collect();
|
let mut paths: BTreeSet<PathBuf> = paths.iter().cloned().collect();
|
||||||
let libraries = Settings::parse_libraries(library_map)?;
|
let libraries = Settings::parse_libraries(library_map)?;
|
||||||
@@ -90,6 +92,7 @@ impl Input {
|
|||||||
output_selection,
|
output_selection,
|
||||||
optimizer,
|
optimizer,
|
||||||
metadata,
|
metadata,
|
||||||
|
polkavm,
|
||||||
),
|
),
|
||||||
#[cfg(feature = "resolc")]
|
#[cfg(feature = "resolc")]
|
||||||
suppressed_warnings,
|
suppressed_warnings,
|
||||||
@@ -109,6 +112,7 @@ impl Input {
|
|||||||
optimizer: SolcStandardJsonInputSettingsOptimizer,
|
optimizer: SolcStandardJsonInputSettingsOptimizer,
|
||||||
metadata: Option<SolcStandardJsonInputSettingsMetadata>,
|
metadata: Option<SolcStandardJsonInputSettingsMetadata>,
|
||||||
suppressed_warnings: Option<Vec<Warning>>,
|
suppressed_warnings: Option<Vec<Warning>>,
|
||||||
|
polkavm: Option<SolcStandardJsonInputSettingsPolkaVM>,
|
||||||
) -> anyhow::Result<Self> {
|
) -> anyhow::Result<Self> {
|
||||||
#[cfg(feature = "parallel")]
|
#[cfg(feature = "parallel")]
|
||||||
let iter = sources.into_par_iter(); // Parallel iterator
|
let iter = sources.into_par_iter(); // Parallel iterator
|
||||||
@@ -129,6 +133,7 @@ impl Input {
|
|||||||
output_selection,
|
output_selection,
|
||||||
optimizer,
|
optimizer,
|
||||||
metadata,
|
metadata,
|
||||||
|
polkavm,
|
||||||
),
|
),
|
||||||
suppressed_warnings,
|
suppressed_warnings,
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
pub mod metadata;
|
pub mod metadata;
|
||||||
pub mod metadata_hash;
|
pub mod metadata_hash;
|
||||||
pub mod optimizer;
|
pub mod optimizer;
|
||||||
|
pub mod polkavm;
|
||||||
pub mod selection;
|
pub mod selection;
|
||||||
|
|
||||||
use std::collections::BTreeMap;
|
use std::collections::BTreeMap;
|
||||||
@@ -13,6 +14,7 @@ use serde::Serialize;
|
|||||||
|
|
||||||
use self::metadata::Metadata;
|
use self::metadata::Metadata;
|
||||||
use self::optimizer::Optimizer;
|
use self::optimizer::Optimizer;
|
||||||
|
use self::polkavm::PolkaVM;
|
||||||
use self::selection::Selection;
|
use self::selection::Selection;
|
||||||
|
|
||||||
/// The `solc --standard-json` input settings.
|
/// The `solc --standard-json` input settings.
|
||||||
@@ -43,6 +45,9 @@ pub struct Settings {
|
|||||||
/// The metadata settings.
|
/// The metadata settings.
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub metadata: Option<Metadata>,
|
pub metadata: Option<Metadata>,
|
||||||
|
/// The resolc custom PolkaVM settings.
|
||||||
|
#[serde(skip_serializing)]
|
||||||
|
pub polkavm: Option<PolkaVM>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Settings {
|
impl Settings {
|
||||||
@@ -54,6 +59,7 @@ impl Settings {
|
|||||||
output_selection: Selection,
|
output_selection: Selection,
|
||||||
optimizer: Optimizer,
|
optimizer: Optimizer,
|
||||||
metadata: Option<Metadata>,
|
metadata: Option<Metadata>,
|
||||||
|
polkavm: Option<PolkaVM>,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
Self {
|
Self {
|
||||||
evm_version,
|
evm_version,
|
||||||
@@ -63,6 +69,7 @@ impl Settings {
|
|||||||
optimizer,
|
optimizer,
|
||||||
metadata,
|
metadata,
|
||||||
via_ir: Some(true),
|
via_ir: Some(true),
|
||||||
|
polkavm,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,26 @@
|
|||||||
|
//! The `resolc --standard-json` polkavm settings.
|
||||||
|
//!
|
||||||
|
//! Used for options specific to PolkaVM which therefor don't exist in solc.
|
||||||
|
|
||||||
|
use memory::MemoryConfig;
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
pub mod memory;
|
||||||
|
|
||||||
|
/// PVM specific compiler settings.
|
||||||
|
#[derive(Clone, Copy, Default, Debug, Serialize, Deserialize)]
|
||||||
|
pub struct PolkaVM {
|
||||||
|
/// The PolkaVM target machine memory configuration settings.
|
||||||
|
pub memory_config: MemoryConfig,
|
||||||
|
/// Instruct LLVM to emit debug information.
|
||||||
|
pub debug_information: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PolkaVM {
|
||||||
|
pub fn new(memory_config: Option<MemoryConfig>, debug_information: bool) -> Self {
|
||||||
|
Self {
|
||||||
|
memory_config: memory_config.unwrap_or_default(),
|
||||||
|
debug_information,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -44,7 +44,7 @@ mimalloc = { version = "*", default-features = false }
|
|||||||
|
|
||||||
[target.'cfg(target_os = "emscripten")'.dependencies]
|
[target.'cfg(target_os = "emscripten")'.dependencies]
|
||||||
libc = { workspace = true }
|
libc = { workspace = true }
|
||||||
inkwell = { workspace = true, features = ["target-riscv", "llvm18-0-no-llvm-linking"]}
|
inkwell = { workspace = true, features = ["target-riscv", "llvm18-1-no-llvm-linking"]}
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
git2 = { workspace = true, default-features = false }
|
git2 = { workspace = true, default-features = false }
|
||||||
|
|||||||
@@ -45,6 +45,8 @@ use revive_solc_json_interface::ResolcWarning;
|
|||||||
use revive_solc_json_interface::SolcStandardJsonInput;
|
use revive_solc_json_interface::SolcStandardJsonInput;
|
||||||
use revive_solc_json_interface::SolcStandardJsonInputLanguage;
|
use revive_solc_json_interface::SolcStandardJsonInputLanguage;
|
||||||
use revive_solc_json_interface::SolcStandardJsonInputSettingsOptimizer;
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsOptimizer;
|
||||||
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVM;
|
||||||
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory;
|
||||||
use revive_solc_json_interface::SolcStandardJsonInputSettingsSelection;
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsSelection;
|
||||||
|
|
||||||
/// Runs the Yul mode.
|
/// Runs the Yul mode.
|
||||||
@@ -55,7 +57,7 @@ pub fn yul<T: Compiler>(
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<Build> {
|
) -> anyhow::Result<Build> {
|
||||||
let path = match input_files.len() {
|
let path = match input_files.len() {
|
||||||
1 => input_files.first().expect("Always exists"),
|
1 => input_files.first().expect("Always exists"),
|
||||||
@@ -94,7 +96,7 @@ pub fn llvm_ir(
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<Build> {
|
) -> anyhow::Result<Build> {
|
||||||
let path = match input_files.len() {
|
let path = match input_files.len() {
|
||||||
1 => input_files.first().expect("Always exists"),
|
1 => input_files.first().expect("Always exists"),
|
||||||
@@ -135,7 +137,7 @@ pub fn standard_output<T: Compiler>(
|
|||||||
suppressed_warnings: Option<Vec<ResolcWarning>>,
|
suppressed_warnings: Option<Vec<ResolcWarning>>,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<Build> {
|
) -> anyhow::Result<Build> {
|
||||||
let solc_version = solc.version()?;
|
let solc_version = solc.version()?;
|
||||||
|
|
||||||
@@ -154,6 +156,10 @@ pub fn standard_output<T: Compiler>(
|
|||||||
),
|
),
|
||||||
None,
|
None,
|
||||||
suppressed_warnings,
|
suppressed_warnings,
|
||||||
|
Some(SolcStandardJsonInputSettingsPolkaVM::new(
|
||||||
|
Some(memory_config),
|
||||||
|
debug_config.emit_debug_info,
|
||||||
|
)),
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let source_code_files = solc_input
|
let source_code_files = solc_input
|
||||||
@@ -208,9 +214,8 @@ pub fn standard_json<T: Compiler>(
|
|||||||
base_path: Option<String>,
|
base_path: Option<String>,
|
||||||
include_paths: Vec<String>,
|
include_paths: Vec<String>,
|
||||||
allow_paths: Option<String>,
|
allow_paths: Option<String>,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
mut debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
|
||||||
) -> anyhow::Result<()> {
|
) -> anyhow::Result<()> {
|
||||||
let solc_version = solc.version()?;
|
let solc_version = solc.version()?;
|
||||||
|
|
||||||
@@ -224,6 +229,9 @@ pub fn standard_json<T: Compiler>(
|
|||||||
let optimizer_settings =
|
let optimizer_settings =
|
||||||
revive_llvm_context::OptimizerSettings::try_from(&solc_input.settings.optimizer)?;
|
revive_llvm_context::OptimizerSettings::try_from(&solc_input.settings.optimizer)?;
|
||||||
|
|
||||||
|
let polkavm_settings = solc_input.settings.polkavm.unwrap_or_default();
|
||||||
|
debug_config.emit_debug_info = polkavm_settings.debug_information;
|
||||||
|
|
||||||
let include_metadata_hash = match solc_input.settings.metadata {
|
let include_metadata_hash = match solc_input.settings.metadata {
|
||||||
Some(ref metadata) => metadata.bytecode_hash != Some(MetadataHash::None),
|
Some(ref metadata) => metadata.bytecode_hash != Some(MetadataHash::None),
|
||||||
None => true,
|
None => true,
|
||||||
@@ -258,7 +266,7 @@ pub fn standard_json<T: Compiler>(
|
|||||||
include_metadata_hash,
|
include_metadata_hash,
|
||||||
debug_config,
|
debug_config,
|
||||||
llvm_arguments,
|
llvm_arguments,
|
||||||
memory_config,
|
polkavm_settings.memory_config,
|
||||||
)?;
|
)?;
|
||||||
build.write_to_standard_json(&mut solc_output, &solc_version)?;
|
build.write_to_standard_json(&mut solc_output, &solc_version)?;
|
||||||
}
|
}
|
||||||
@@ -286,7 +294,7 @@ pub fn combined_json<T: Compiler>(
|
|||||||
output_directory: Option<PathBuf>,
|
output_directory: Option<PathBuf>,
|
||||||
overwrite: bool,
|
overwrite: bool,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<()> {
|
) -> anyhow::Result<()> {
|
||||||
let build = standard_output(
|
let build = standard_output(
|
||||||
input_files,
|
input_files,
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
//! Process for compiling a single compilation unit.
|
//! Process for compiling a single compilation unit.
|
||||||
//! The input data.
|
//! The input data.
|
||||||
|
|
||||||
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
use serde::Serialize;
|
use serde::Serialize;
|
||||||
|
|
||||||
@@ -23,7 +24,7 @@ pub struct Input {
|
|||||||
/// The extra LLVM arguments give used for manual control.
|
/// The extra LLVM arguments give used for manual control.
|
||||||
pub llvm_arguments: Vec<String>,
|
pub llvm_arguments: Vec<String>,
|
||||||
/// The PVM memory configuration.
|
/// The PVM memory configuration.
|
||||||
pub memory_config: revive_llvm_context::MemoryConfig,
|
pub memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Input {
|
impl Input {
|
||||||
@@ -35,7 +36,7 @@ impl Input {
|
|||||||
optimizer_settings: revive_llvm_context::OptimizerSettings,
|
optimizer_settings: revive_llvm_context::OptimizerSettings,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: Vec<String>,
|
llvm_arguments: Vec<String>,
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
Self {
|
Self {
|
||||||
contract,
|
contract,
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ pub mod metadata;
|
|||||||
|
|
||||||
use std::collections::HashSet;
|
use std::collections::HashSet;
|
||||||
|
|
||||||
|
use revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
use serde::Serialize;
|
use serde::Serialize;
|
||||||
use sha3::Digest;
|
use sha3::Digest;
|
||||||
@@ -78,7 +79,7 @@ impl Contract {
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<ContractBuild> {
|
) -> anyhow::Result<ContractBuild> {
|
||||||
let llvm = inkwell::context::Context::create();
|
let llvm = inkwell::context::Context::create();
|
||||||
let optimizer = revive_llvm_context::Optimizer::new(optimizer_settings);
|
let optimizer = revive_llvm_context::Optimizer::new(optimizer_settings);
|
||||||
|
|||||||
@@ -67,7 +67,7 @@ impl Project {
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<Build> {
|
) -> anyhow::Result<Build> {
|
||||||
let project = self.clone();
|
let project = self.clone();
|
||||||
#[cfg(feature = "parallel")]
|
#[cfg(feature = "parallel")]
|
||||||
@@ -321,7 +321,7 @@ impl revive_llvm_context::PolkaVMDependency for Project {
|
|||||||
include_metadata_hash: bool,
|
include_metadata_hash: bool,
|
||||||
debug_config: revive_llvm_context::DebugConfig,
|
debug_config: revive_llvm_context::DebugConfig,
|
||||||
llvm_arguments: &[String],
|
llvm_arguments: &[String],
|
||||||
memory_config: revive_llvm_context::MemoryConfig,
|
memory_config: revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory,
|
||||||
) -> anyhow::Result<String> {
|
) -> anyhow::Result<String> {
|
||||||
let contract_path = project.resolve_path(identifier)?;
|
let contract_path = project.resolve_path(identifier)?;
|
||||||
let contract = project
|
let contract = project
|
||||||
|
|||||||
@@ -185,8 +185,8 @@ pub struct Arguments {
|
|||||||
/// 1.Increasing the heap size will increase startup costs.
|
/// 1.Increasing the heap size will increase startup costs.
|
||||||
/// 2.The heap size contributes to the total memory size a contract can use,
|
/// 2.The heap size contributes to the total memory size a contract can use,
|
||||||
/// which includes the contracts code size
|
/// which includes the contracts code size
|
||||||
#[arg(long = "heap-size", default_value = "65536")]
|
#[arg(long = "heap-size")]
|
||||||
pub heap_size: u32,
|
pub heap_size: Option<u32>,
|
||||||
|
|
||||||
/// The contracts total stack size in bytes.
|
/// The contracts total stack size in bytes.
|
||||||
///
|
///
|
||||||
@@ -200,8 +200,8 @@ pub struct Arguments {
|
|||||||
/// 1.Increasing the heap size will increase startup costs.
|
/// 1.Increasing the heap size will increase startup costs.
|
||||||
/// 2.The stack size contributes to the total memory size a contract can use,
|
/// 2.The stack size contributes to the total memory size a contract can use,
|
||||||
/// which includes the contracts code size
|
/// which includes the contracts code size
|
||||||
#[arg(long = "stack-size", default_value = "32768")]
|
#[arg(long = "stack-size")]
|
||||||
pub stack_size: u32,
|
pub stack_size: Option<u32>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Arguments {
|
impl Arguments {
|
||||||
@@ -330,6 +330,22 @@ impl Arguments {
|
|||||||
if self.metadata_hash.is_some() {
|
if self.metadata_hash.is_some() {
|
||||||
anyhow::bail!("Metadata hash mode must specified in standard JSON input settings.");
|
anyhow::bail!("Metadata hash mode must specified in standard JSON input settings.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if self.heap_size.is_some() {
|
||||||
|
anyhow::bail!(
|
||||||
|
"Heap size must be specified in standard JSON input polkavm memory settings."
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if self.stack_size.is_some() {
|
||||||
|
anyhow::bail!(
|
||||||
|
"Stack size must be specified in standard JSON input polkavm memory settings."
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if self.emit_source_debug_info {
|
||||||
|
anyhow::bail!(
|
||||||
|
"Debug info must be requested in standard JSON input polkavm settings."
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|||||||
@@ -148,10 +148,14 @@ fn main_inner() -> anyhow::Result<()> {
|
|||||||
None => true,
|
None => true,
|
||||||
};
|
};
|
||||||
|
|
||||||
let memory_config = revive_llvm_context::MemoryConfig {
|
let mut memory_config =
|
||||||
heap_size: arguments.heap_size,
|
revive_solc_json_interface::SolcStandardJsonInputSettingsPolkaVMMemory::default();
|
||||||
stack_size: arguments.stack_size,
|
if let Some(heap_size) = arguments.heap_size {
|
||||||
};
|
memory_config.heap_size = heap_size
|
||||||
|
}
|
||||||
|
if let Some(stack_size) = arguments.stack_size {
|
||||||
|
memory_config.stack_size = stack_size
|
||||||
|
}
|
||||||
|
|
||||||
let build = if arguments.yul {
|
let build = if arguments.yul {
|
||||||
revive_solidity::yul(
|
revive_solidity::yul(
|
||||||
@@ -181,7 +185,6 @@ fn main_inner() -> anyhow::Result<()> {
|
|||||||
arguments.allow_paths,
|
arguments.allow_paths,
|
||||||
debug_config,
|
debug_config,
|
||||||
&arguments.llvm_arguments,
|
&arguments.llvm_arguments,
|
||||||
memory_config,
|
|
||||||
)?;
|
)?;
|
||||||
return Ok(());
|
return Ok(());
|
||||||
} else if let Some(format) = arguments.combined_json {
|
} else if let Some(format) = arguments.combined_json {
|
||||||
|
|||||||
@@ -98,6 +98,7 @@ pub fn build_solidity_with_options(
|
|||||||
),
|
),
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
|
None,
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let mut output = solc.standard_json(input, None, vec![], None)?;
|
let mut output = solc.standard_json(input, None, vec![], None)?;
|
||||||
@@ -162,6 +163,7 @@ pub fn build_solidity_with_options_evm(
|
|||||||
),
|
),
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
|
None,
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let mut output = solc.standard_json(input, None, vec![], None)?;
|
let mut output = solc.standard_json(input, None, vec![], None)?;
|
||||||
@@ -213,6 +215,7 @@ pub fn build_solidity_and_detect_missing_libraries(
|
|||||||
SolcStandardJsonInputSettingsOptimizer::new(true, None, &solc_version.default, false),
|
SolcStandardJsonInputSettingsOptimizer::new(true, None, &solc_version.default, false),
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
|
None,
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let mut output = solc.standard_json(input, None, vec![], None)?;
|
let mut output = solc.standard_json(input, None, vec![], None)?;
|
||||||
@@ -286,6 +289,7 @@ pub fn check_solidity_warning(
|
|||||||
SolcStandardJsonInputSettingsOptimizer::new(true, None, &solc_version.default, false),
|
SolcStandardJsonInputSettingsOptimizer::new(true, None, &solc_version.default, false),
|
||||||
None,
|
None,
|
||||||
suppressed_warnings,
|
suppressed_warnings,
|
||||||
|
None,
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let output = solc.standard_json(input, None, vec![], None)?;
|
let output = solc.standard_json(input, None, vec![], None)?;
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ repository.workspace = true
|
|||||||
description = "revive compiler stdlib components"
|
description = "revive compiler stdlib components"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
inkwell = { workspace = true, features = ["target-riscv", "no-libffi-linking", "llvm18-0"] }
|
inkwell = { workspace = true, features = ["target-riscv", "no-libffi-linking", "llvm18-1"] }
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
revive-build-utils = { workspace = true }
|
revive-build-utils = { workspace = true }
|
||||||
|
|||||||
Generated
+1
-1
@@ -44,7 +44,7 @@
|
|||||||
},
|
},
|
||||||
"js/resolc": {
|
"js/resolc": {
|
||||||
"name": "@parity/resolc",
|
"name": "@parity/resolc",
|
||||||
"version": "0.0.0-updated-via-gh-releases",
|
"version": "0.1.0-dev.16",
|
||||||
"license": "Apache-2.0",
|
"license": "Apache-2.0",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/node": "^22.9.0",
|
"@types/node": "^22.9.0",
|
||||||
|
|||||||
Reference in New Issue
Block a user