aboutsummaryrefslogtreecommitdiff
path: root/src/armv7.rs
AgeCommit message (Collapse)Author
6 daysOpcode and Operand should be non-exhaustiveiximeow
but exhaustiveness checking is very valuable here, so allow it to be disabled. caveats apply. read the docs in Cargo.toml.
6 daysvisitor-oriented fmtiximeow
this makes a decode+format benchmark drop from 75s to 14s... (decode is 5s)
2025-06-02some armv7 decode helpers are trivial functions but didn't inlineiximeow
both from_u8 and the build function here compiled to truly trivial code: four instructions (mov rdi, rax; cmp 0xlim, rax; jae panic; ret) in the hot path, and constrained register choice on the caller side. inlining these makes for a *smaller* armv7 decoder, on the order of 5kb down from 5.5kb. in the process it also gets about 45% faster (400mb/s to 560mb/s) inlining decode_into, then, really just helps the standalone decoder benchmark case. this moves decode throughput from 560mb/s to 724mb/s.
2024-06-25Bump yaxpeax-arch and bitvec, allow use of deprecated yaxpeax-arch traits, ↵novafacing
fix bitvec syntax changes
2023-11-02ah and a doc comment for the public method0.2.4iximeow
2023-11-02make RegShift::into_shift publicwscp
2023-01-31fix 24-bit branch immediate decodingjam1garner
2022-01-02document the crateiximeow
2021-12-29clean up warnings, several of which were real bugsiximeow
2021-09-28handle another unintended panic in display impliximeow
2021-09-28fix various armv8 and armv8 panics that should be Err.iximeow
in fact the decoder should _never_ panic. included here are tests that cover the entire 32-bit instruction space and ensure that decoding and display do not panic. these tests run uncomfortably slowly (1168s to decode the 4b "instruction" sequences on my desktop), but verify that panics are no longer an issue.
2021-09-26fix unimplemented code paths panicking as unreachableiximeow
only in a64 decoding really; there wasn't an "Incomplete" error at the time, but now there is.
2021-09-14Fix display of post-index writeback operandsJonas Schievink
2021-07-21fix DecodeError impl on builds using yaxpeax-arch+std0.1.1iximeow
2021-07-06update yaxpeax_arch and bump version to 0.1.00.1.0iximeow
2021-05-07bump yaxpeax-arch to 0.0.5 to drop the termion dep0.0.7iximeow
fix interface changes around YaxColors as well
2020-12-06support CPS (change processor state) and some warming cleanupiximeow
2020-12-06add ldc/sdc instructions and a slew of 32b thumb2 testsiximeow
2020-12-06support more mul/div variantsiximeow
2020-12-06thumb parallel addition and subtractioniximeow
2020-12-06fill out more missing thumb2 decoderiximeow
2020-12-06fix more incomplete cases, report arm instruction length properlyiximeow
2020-12-06remove "Incomplete" opcode from arm7 non-thumb decoderiximeow
2020-12-06fix regimm masksiximeow
2020-12-06numerous one-off mis-specializations, most of ld/prefetch hintsiximeow
2020-12-06fix some 32-bit thumb2 instructions, hook up .w, `s`, and a few typosiximeow
mostly confusion of pre/post-increment, operand widths, immediate widths, things of that nature
2020-12-06add thumb/thumb2 decodingiximeow
16-bit instructions only, for now
2020-11-29normalize stm/ldm to use RegWBackiximeow
2020-05-03bump to version 0.0.4, bumping yaxpeax-arch to 0.0.40.0.4iximeow
2020-03-15clean up operands someiximeow
2020-03-15armv7 support through neon, some still missing (mainly coproc instrs)iximeow
2020-02-23bring more armv7 tests back to the land of the livingiximeow
2020-02-17more strt/ldrt/strbt/ldrbt variants and operand display cleanupiximeow
2020-02-17strh/ldrh/strht/ldrht and some misc cleanupiximeow
2020-02-17entirely replace armv7 operandsiximeow
Operands was an enum covering all forms of operands and data for each operand for all instructions. this is hard to iterate, and hard to work with when a single operand is the one of interest, so it's now replaced by an array of `Operand` enum instances like other architectures. in the course of this change, several forms of decoding are broken, while adding support for some earlier-unsupported multiplies and instructions like msr and clz also clearly note which document the comments mentioning page numbers/figures is referencing
2020-01-18some of the work to get yaxpeax-arm no-stdiximeow
2020-01-12be nicer about reaching incomplete parts of armv7 decoderiximeow
2020-01-12match changes in arch to have Resulty decode, instead of Optioniximeow
2020-01-12update arm to revised decoder traitiximeow
2020-01-12warnings-b-goneiximeow
2020-01-12immediates are not shifted, what was this about?iximeow
2020-01-12decode blxiximeow
2020-01-12fix issue with incorrectly decoding register shiftsiximeow
2020-01-12fix the hex/bits mismatchiximeow
2020-01-12silence armv7 warningsiximeow
2020-01-12awful tweaks to expose a serde flag on yaxpeax-arch which will trickle ↵iximeow
through everything
2020-01-12add colorized display to arm, as well as a PUSH pseduo-opcodeiximeow
2020-01-12update a bunch of arm stuffiximeow
2020-01-12fix decode issue with stm/ldm/b, add tests, add display impliximeow