mirror of
				https://github.com/encounter/objdiff.git
				synced 2025-10-25 11:10:35 +00:00 
			
		
		
		
	WIP ARM64 support
This commit is contained in:
		
							parent
							
								
									21f8f2407c
								
							
						
					
					
						commit
						09aa52d024
					
				
							
								
								
									
										64
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										64
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -434,6 +434,18 @@ dependencies = [ | ||||
|  "serde", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "bitvec" | ||||
| version = "1.0.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "1bc2832c24239b0141d5674bb9174f9d68a8b5b3f2753311927c172ca46f7e9c" | ||||
| dependencies = [ | ||||
|  "funty", | ||||
|  "radium", | ||||
|  "tap", | ||||
|  "wyz", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "block" | ||||
| version = "0.1.6" | ||||
| @ -1514,6 +1526,12 @@ dependencies = [ | ||||
|  "libc", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "funty" | ||||
| version = "2.0.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "e6d5a32815ae3f33302d95fdcb2ce17862f8c65363dcfd29360480ba1001fc9c" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "futures-channel" | ||||
| version = "0.3.30" | ||||
| @ -2919,6 +2937,8 @@ dependencies = [ | ||||
|  "tsify-next", | ||||
|  "unarm", | ||||
|  "wasm-bindgen", | ||||
|  "yaxpeax-arch", | ||||
|  "yaxpeax-arm", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| @ -3495,6 +3515,12 @@ dependencies = [ | ||||
|  "num_enum 0.5.11", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "radium" | ||||
| version = "0.7.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "dc33ff2d4973d518d823d61aa239014831e521c75da58e3df4840d3f47749d09" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "rand" | ||||
| version = "0.8.5" | ||||
| @ -4290,6 +4316,12 @@ dependencies = [ | ||||
|  "futures-core", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "tap" | ||||
| version = "1.0.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "55937e1799185b12863d447f42597ed69d9928686b8d88a1df17376a097d8369" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "tauri-winres" | ||||
| version = "0.1.1" | ||||
| @ -5525,6 +5557,15 @@ dependencies = [ | ||||
|  "winapi", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "wyz" | ||||
| version = "0.5.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "05f360fc0b24296329c78fda852a1e9ae82de9cf7b27dae4b7f62f118f77b9ed" | ||||
| dependencies = [ | ||||
|  "tap", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "x11-dl" | ||||
| version = "2.21.0" | ||||
| @ -5598,6 +5639,29 @@ version = "0.8.22" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "af4e2e2f7cba5a093896c1e150fbfe177d1883e7448200efb81d40b9d339ef26" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "yaxpeax-arch" | ||||
| version = "0.3.2" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "36274fcc5403da2a7636ffda4d02eca12a1b2b8267b9d2e04447bd2ccfc72082" | ||||
| dependencies = [ | ||||
|  "num-traits", | ||||
|  "serde", | ||||
|  "serde_derive", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "yaxpeax-arm" | ||||
| version = "0.3.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "e1c6a2af41f88546a08df3bc77aadf7263884d6dffdac5b32dea7dc2df23f241" | ||||
| dependencies = [ | ||||
|  "bitvec", | ||||
|  "serde", | ||||
|  "serde_derive", | ||||
|  "yaxpeax-arch", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "yeslogic-fontconfig-sys" | ||||
| version = "6.0.0" | ||||
|  | ||||
| @ -16,7 +16,7 @@ documentation = "https://docs.rs/objdiff-core" | ||||
| crate-type = ["cdylib", "rlib"] | ||||
| 
 | ||||
| [features] | ||||
| all = ["config", "dwarf", "mips", "ppc", "x86", "arm", "bindings"] | ||||
| all = ["config", "dwarf", "mips", "ppc", "x86", "arm", "arm64", "bindings"] | ||||
| any-arch = ["config", "dep:bimap", "dep:strum", "dep:similar", "dep:flagset", "dep:log", "dep:memmap2", "dep:byteorder", "dep:num-traits"] # Implicit, used to check if any arch is enabled | ||||
| config = ["dep:bimap", "dep:globset", "dep:semver", "dep:serde_json", "dep:serde_yaml", "dep:serde", "dep:filetime"] | ||||
| dwarf = ["dep:gimli"] | ||||
| @ -24,6 +24,7 @@ mips = ["any-arch", "dep:rabbitizer"] | ||||
| ppc = ["any-arch", "dep:cwdemangle", "dep:cwextab", "dep:ppc750cl"] | ||||
| x86 = ["any-arch", "dep:cpp_demangle", "dep:iced-x86", "dep:msvc-demangler"] | ||||
| arm = ["any-arch", "dep:cpp_demangle", "dep:unarm", "dep:arm-attr"] | ||||
| arm64 = ["any-arch", "dep:cpp_demangle", "dep:yaxpeax-arch", "dep:yaxpeax-arm"] | ||||
| bindings = ["dep:serde_json", "dep:prost", "dep:pbjson", "dep:serde", "dep:prost-build", "dep:pbjson-build"] | ||||
| wasm = ["bindings", "any-arch", "dep:console_error_panic_hook", "dep:console_log", "dep:wasm-bindgen", "dep:tsify-next", "dep:log"] | ||||
| 
 | ||||
| @ -76,6 +77,10 @@ msvc-demangler = { version = "0.10", optional = true } | ||||
| unarm = { version = "1.6", optional = true } | ||||
| arm-attr = { version = "0.1", optional = true } | ||||
| 
 | ||||
| # arm64 | ||||
| yaxpeax-arch = { version = "0.3", optional = true } | ||||
| yaxpeax-arm = { version = "0.3", optional = true } | ||||
| 
 | ||||
| [build-dependencies] | ||||
| prost-build = { version = "0.13", optional = true } | ||||
| pbjson-build = { version = "0.7", optional = true } | ||||
|  | ||||
| @ -124,11 +124,9 @@ impl ObjArch for ObjArchArm { | ||||
|             .get(&SectionIndex(section_index)) | ||||
|             .map(|x| x.as_slice()) | ||||
|             .unwrap_or(&fallback_mappings); | ||||
|         let first_mapping_idx = | ||||
|             match mapping_symbols.binary_search_by_key(&start_addr, |x| x.address) { | ||||
|                 Ok(idx) => idx, | ||||
|                 Err(idx) => idx - 1, | ||||
|             }; | ||||
|         let first_mapping_idx = mapping_symbols | ||||
|             .binary_search_by_key(&start_addr, |x| x.address) | ||||
|             .unwrap_or_else(|idx| idx - 1); | ||||
|         let first_mapping = mapping_symbols[first_mapping_idx].mapping; | ||||
| 
 | ||||
|         let mut mappings_iter = | ||||
| @ -215,7 +213,7 @@ impl ObjArch for ObjArchArm { | ||||
|                 address: address as u64, | ||||
|                 size: (parser.address - address) as u8, | ||||
|                 op: ins.opcode_id(), | ||||
|                 mnemonic: parsed_ins.mnemonic.to_string(), | ||||
|                 mnemonic: Cow::Borrowed(parsed_ins.mnemonic), | ||||
|                 args, | ||||
|                 reloc, | ||||
|                 branch_dest, | ||||
| @ -234,7 +232,7 @@ impl ObjArch for ObjArchArm { | ||||
|         section: &ObjSection, | ||||
|         address: u64, | ||||
|         reloc: &Relocation, | ||||
|     ) -> anyhow::Result<i64> { | ||||
|     ) -> Result<i64> { | ||||
|         let address = address as usize; | ||||
|         Ok(match reloc.flags() { | ||||
|             // ARM calls
 | ||||
|  | ||||
							
								
								
									
										2252
									
								
								objdiff-core/src/arch/arm64.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2252
									
								
								objdiff-core/src/arch/arm64.rs
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -119,7 +119,7 @@ impl ObjArch for ObjArchMips { | ||||
|             let op = instruction.unique_id as u16; | ||||
|             ops.push(op); | ||||
| 
 | ||||
|             let mnemonic = instruction.opcode_name().to_string(); | ||||
|             let mnemonic = instruction.opcode_name(); | ||||
|             let is_branch = instruction.is_branch(); | ||||
|             let branch_offset = instruction.branch_offset(); | ||||
|             let mut branch_dest = if is_branch { | ||||
| @ -202,7 +202,7 @@ impl ObjArch for ObjArchMips { | ||||
|                 address: cur_addr as u64, | ||||
|                 size: 4, | ||||
|                 op, | ||||
|                 mnemonic, | ||||
|                 mnemonic: Cow::Borrowed(mnemonic), | ||||
|                 args, | ||||
|                 reloc: reloc.cloned(), | ||||
|                 branch_dest, | ||||
|  | ||||
| @ -12,6 +12,8 @@ use crate::{ | ||||
| 
 | ||||
| #[cfg(feature = "arm")] | ||||
| mod arm; | ||||
| #[cfg(feature = "arm64")] | ||||
| mod arm64; | ||||
| #[cfg(feature = "mips")] | ||||
| pub mod mips; | ||||
| #[cfg(feature = "ppc")] | ||||
| @ -165,6 +167,8 @@ pub fn new_arch(object: &File) -> Result<Box<dyn ObjArch>> { | ||||
|         Architecture::I386 | Architecture::X86_64 => Box::new(x86::ObjArchX86::new(object)?), | ||||
|         #[cfg(feature = "arm")] | ||||
|         Architecture::Arm => Box::new(arm::ObjArchArm::new(object)?), | ||||
|         #[cfg(feature = "arm64")] | ||||
|         Architecture::Aarch64 => Box::new(arm64::ObjArchArm64::new(object)?), | ||||
|         arch => bail!("Unsupported architecture: {arch:?}"), | ||||
|     }) | ||||
| } | ||||
|  | ||||
| @ -143,7 +143,7 @@ impl ObjArch for ObjArchPpc { | ||||
|             insts.push(ObjIns { | ||||
|                 address: cur_addr as u64, | ||||
|                 size: 4, | ||||
|                 mnemonic: simplified.mnemonic.to_string(), | ||||
|                 mnemonic: Cow::Borrowed(simplified.mnemonic), | ||||
|                 args, | ||||
|                 reloc: reloc.cloned(), | ||||
|                 op: ins.op as u16, | ||||
|  | ||||
| @ -51,7 +51,7 @@ impl ObjArch for ObjArchX86 { | ||||
|                 address: 0, | ||||
|                 size: 0, | ||||
|                 op: 0, | ||||
|                 mnemonic: String::new(), | ||||
|                 mnemonic: Cow::Borrowed("<invalid>"), | ||||
|                 args: vec![], | ||||
|                 reloc: None, | ||||
|                 branch_dest: None, | ||||
| @ -76,7 +76,7 @@ impl ObjArch for ObjArchX86 { | ||||
|                 address, | ||||
|                 size: instruction.len() as u8, | ||||
|                 op, | ||||
|                 mnemonic: String::new(), | ||||
|                 mnemonic: Cow::Borrowed("<invalid>"), | ||||
|                 args: vec![], | ||||
|                 reloc: reloc.cloned(), | ||||
|                 branch_dest: None, | ||||
| @ -242,7 +242,8 @@ impl FormatterOutput for InstructionFormatterOutput { | ||||
| 
 | ||||
|     fn write_mnemonic(&mut self, _instruction: &Instruction, text: &str) { | ||||
|         self.formatted.push_str(text); | ||||
|         self.ins.mnemonic = text.to_string(); | ||||
|         // TODO: can iced-x86 guarantee 'static here?
 | ||||
|         self.ins.mnemonic = Cow::Owned(text.to_string()); | ||||
|     } | ||||
| 
 | ||||
|     fn write_number( | ||||
|  | ||||
| @ -132,7 +132,7 @@ impl Instruction { | ||||
|             address: instruction.address, | ||||
|             size: instruction.size as u32, | ||||
|             opcode: instruction.op as u32, | ||||
|             mnemonic: instruction.mnemonic.clone(), | ||||
|             mnemonic: instruction.mnemonic.to_string(), | ||||
|             formatted: instruction.formatted.clone(), | ||||
|             arguments: instruction.args.iter().map(Argument::new).collect(), | ||||
|             relocation: instruction.reloc.as_ref().map(|reloc| Relocation::new(object, reloc)), | ||||
|  | ||||
| @ -100,7 +100,7 @@ pub struct ObjIns { | ||||
|     pub address: u64, | ||||
|     pub size: u8, | ||||
|     pub op: u16, | ||||
|     pub mnemonic: String, | ||||
|     pub mnemonic: Cow<'static, str>, | ||||
|     pub args: Vec<ObjInsArg>, | ||||
|     pub reloc: Option<ObjReloc>, | ||||
|     pub branch_dest: Option<u64>, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user