mirror of
https://github.com/pezkuwichain/revive.git
synced 2026-06-13 14:11:05 +00:00
dump the elf shared object into the debug output directory (#119)
Signed-off-by: Cyrill Leutwiler <bigcyrill@hotmail.com>
This commit is contained in:
@@ -41,3 +41,6 @@ pub static EXTENSION_POLKAVM_ASSEMBLY: &str = "pvmasm";
|
|||||||
|
|
||||||
/// The PolkaVM bytecode file extension.
|
/// The PolkaVM bytecode file extension.
|
||||||
pub static EXTENSION_POLKAVM_BINARY: &str = "pvm";
|
pub static EXTENSION_POLKAVM_BINARY: &str = "pvm";
|
||||||
|
|
||||||
|
/// The ELF shared object file extension.
|
||||||
|
pub static EXTENSION_SHARED_OBJECT: &str = "so";
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ fn invoke_lld(cmd_args: &[&str]) -> bool {
|
|||||||
unsafe { LLDELFLink(args.as_ptr(), args.len()) == 0 }
|
unsafe { LLDELFLink(args.as_ptr(), args.len()) == 0 }
|
||||||
}
|
}
|
||||||
|
|
||||||
fn polkavm_linker<T: AsRef<[u8]>>(code: T) -> anyhow::Result<Vec<u8>> {
|
pub fn polkavm_linker<T: AsRef<[u8]>>(code: T) -> anyhow::Result<Vec<u8>> {
|
||||||
let mut config = polkavm_linker::Config::default();
|
let mut config = polkavm_linker::Config::default();
|
||||||
config.set_strip(true);
|
config.set_strip(true);
|
||||||
config.set_optimize(true);
|
config.set_optimize(true);
|
||||||
@@ -79,10 +79,5 @@ pub fn link<T: AsRef<[u8]>>(input: T) -> anyhow::Result<Vec<u8>> {
|
|||||||
return Err(anyhow::anyhow!("ld.lld failed"));
|
return Err(anyhow::anyhow!("ld.lld failed"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if env::var("PVM_LINKER_DUMP_SO").is_ok() {
|
Ok(fs::read(&output_path)?)
|
||||||
fs::copy(&output_path, "/tmp/out.so")?;
|
|
||||||
};
|
|
||||||
|
|
||||||
let blob = fs::read(&output_path)?;
|
|
||||||
polkavm_linker(blob)
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,6 +15,8 @@ pub enum IRType {
|
|||||||
LLVM,
|
LLVM,
|
||||||
/// Whether to dump the assembly code.
|
/// Whether to dump the assembly code.
|
||||||
Assembly,
|
Assembly,
|
||||||
|
/// Whether to dump the ELF shared object
|
||||||
|
SO,
|
||||||
/// Whether to jump JSON
|
/// Whether to jump JSON
|
||||||
#[cfg(debug_assertions)]
|
#[cfg(debug_assertions)]
|
||||||
JSON,
|
JSON,
|
||||||
@@ -31,6 +33,7 @@ impl IRType {
|
|||||||
Self::Assembly => revive_common::EXTENSION_POLKAVM_ASSEMBLY,
|
Self::Assembly => revive_common::EXTENSION_POLKAVM_ASSEMBLY,
|
||||||
#[cfg(debug_assertions)]
|
#[cfg(debug_assertions)]
|
||||||
Self::JSON => revive_common::EXTENSION_JSON,
|
Self::JSON => revive_common::EXTENSION_JSON,
|
||||||
|
Self::SO => revive_common::EXTENSION_SHARED_OBJECT,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -94,6 +94,16 @@ impl DebugConfig {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Dumps the code object.
|
||||||
|
pub fn dump_object(&self, contract_path: &str, code: &[u8]) -> anyhow::Result<()> {
|
||||||
|
let mut file_path = self.output_directory.to_owned();
|
||||||
|
let full_file_name = Self::full_file_name(contract_path, None, IRType::SO);
|
||||||
|
file_path.push(full_file_name);
|
||||||
|
std::fs::write(file_path, code)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
/// Dumps the stage output as a json file suitable for use with --recursive-process
|
/// Dumps the stage output as a json file suitable for use with --recursive-process
|
||||||
#[cfg(debug_assertions)]
|
#[cfg(debug_assertions)]
|
||||||
pub fn dump_stage_output(
|
pub fn dump_stage_output(
|
||||||
|
|||||||
@@ -296,11 +296,17 @@ where
|
|||||||
)
|
)
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
let bytecode = revive_linker::link(buffer.as_slice())?;
|
let shared_object = revive_linker::link(buffer.as_slice())?;
|
||||||
|
|
||||||
|
if let Some(ref debug_config) = self.debug_config {
|
||||||
|
debug_config.dump_object(contract_path, &shared_object)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
let polkavm_bytecode = revive_linker::polkavm_linker(shared_object)?;
|
||||||
|
|
||||||
let build = match crate::polkavm::build_assembly_text(
|
let build = match crate::polkavm::build_assembly_text(
|
||||||
contract_path,
|
contract_path,
|
||||||
&bytecode,
|
&polkavm_bytecode,
|
||||||
metadata_hash,
|
metadata_hash,
|
||||||
self.debug_config(),
|
self.debug_config(),
|
||||||
) {
|
) {
|
||||||
|
|||||||
Reference in New Issue
Block a user