The Smart Intermediate Representation
The Smart Intermediate Representation(short for IR) project is a new compiler framework intended for smart contract development, which is mainly inspired by LLVM, MLIR and Solidity/Yul. The compiler's goals are:
- Trust and Security
- Rollup Friendly
- AI Friendly
- High Performance and Low Gas Cost
Table of Contents
Background
Since the circulation of Blockchain and Smart Contracts, there have been many incidents of exploitation. These incidents are mainly caused by attacks on unsafe smart contracts such as reentrancy issues, and compiler bugs. In the existing cases, it is difficult to investigate or locate once the attack occurs. Most safe/secure cases also require 3rd-party auditing which is very costly.
Meanwhile, to wring the most performance out of a regular gas allowance, or something else. It's important to optimize both on-chain and off-chain scenarios.
Currently, we propose a universal technical solution to be adapted to any programming language to help blockchain platform/developer make their smart contract safer, high performance and multi-scenario compatibility.
Installation
Instructions about how to build and install the Smart Intermediate Representation compiler can be found in the Development Guide
Quick Start
Example
Here is a "Hello World" hand-written program with debug information in the IR:
module_name = "HelloWorld"
contract HelloWorld {
state {
}
pub fn HelloWorld.HelloWorld.init() {
0:
ret()
}
pub fn HelloWorld.HelloWorld.greeting() -> str {
1:
call(@ir.builtin.print("hello": str, ) -> void, )
ret("Hello world!": str, )
}
}
For more examples of IR textual format programs, you can see IR Example
Fetch the Docker Image and Build a Test IR Program
docker run smartir/cli:latest ir_cli build sir/example/hello_world.ir
Documentation
The IR Specification document is here
Roadmap
📢 NOTE: This roadmap is tentative, it will be adjusted at any time
The IR has a high level of compatibility with many blockchains. Here is a brief description of what we envision for the next versions.
V0.1
Feature | Status | Show Case |
---|---|---|
Support Solidity/Yul for Ethereum-Compatible | In progress | Yul to IR |
Support IR-AI-based Intent Consistent Analysis | In progress | AI Intent |
Provide a default high-level frontend language | In progress | - |
Enhance Runtime Performance and Lowering Gas Cost | In progress | - |
Support Formal Verification via Static Prover | In progress | - |
Support ZKP by Abstract Circuit IR | Not started | - |
Provide User-Defined Frontend guide | Not started | - |
Provide Solidity -> WASM-based Layer 2 porting guide | Not started | - |
Provide a default optimized VM based on wasmtime | Not started | - |
Contribution
The IR is still under development. Contributions are always welcome. Please follow the Contributing Guide if you want to make a new feature for IR.
Community
coming soon