Age | Commit message (Collapse) | Author | |
---|---|---|---|
5 days | Opcode and Operand should be non-exhaustive | iximeow | |
but exhaustiveness checking is very valuable here, so allow it to be disabled. caveats apply. read the docs in Cargo.toml. | |||
5 days | visitor-oriented fmt | iximeow | |
this makes a decode+format benchmark drop from 75s to 14s... (decode is 5s) | |||
2025-06-02 | some armv7 decode helpers are trivial functions but didn't inline | iximeow | |
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-25 | Bump yaxpeax-arch and bitvec, allow use of deprecated yaxpeax-arch traits, ↵ | novafacing | |
fix bitvec syntax changes | |||
2023-11-02 | ah and a doc comment for the public method0.2.4 | iximeow | |
2023-11-02 | make RegShift::into_shift public | wscp | |
2023-01-31 | fix 24-bit branch immediate decoding | jam1garner | |
2022-01-02 | document the crate | iximeow | |
2021-12-29 | clean up warnings, several of which were real bugs | iximeow | |
2021-09-28 | handle another unintended panic in display impl | iximeow | |
2021-09-28 | fix 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-26 | fix unimplemented code paths panicking as unreachable | iximeow | |
only in a64 decoding really; there wasn't an "Incomplete" error at the time, but now there is. | |||
2021-09-14 | Fix display of post-index writeback operands | Jonas Schievink | |
2021-07-21 | fix DecodeError impl on builds using yaxpeax-arch+std0.1.1 | iximeow | |
2021-07-06 | update yaxpeax_arch and bump version to 0.1.00.1.0 | iximeow | |
2021-05-07 | bump yaxpeax-arch to 0.0.5 to drop the termion dep0.0.7 | iximeow | |
fix interface changes around YaxColors as well | |||
2020-12-06 | support CPS (change processor state) and some warming cleanup | iximeow | |
2020-12-06 | add ldc/sdc instructions and a slew of 32b thumb2 tests | iximeow | |
2020-12-06 | support more mul/div variants | iximeow | |
2020-12-06 | thumb parallel addition and subtraction | iximeow | |
2020-12-06 | fill out more missing thumb2 decoder | iximeow | |
2020-12-06 | fix more incomplete cases, report arm instruction length properly | iximeow | |
2020-12-06 | remove "Incomplete" opcode from arm7 non-thumb decoder | iximeow | |
2020-12-06 | fix regimm masks | iximeow | |
2020-12-06 | numerous one-off mis-specializations, most of ld/prefetch hints | iximeow | |
2020-12-06 | fix some 32-bit thumb2 instructions, hook up .w, `s`, and a few typos | iximeow | |
mostly confusion of pre/post-increment, operand widths, immediate widths, things of that nature | |||
2020-12-06 | add thumb/thumb2 decoding | iximeow | |
16-bit instructions only, for now | |||
2020-11-29 | normalize stm/ldm to use RegWBack | iximeow | |
2020-05-03 | bump to version 0.0.4, bumping yaxpeax-arch to 0.0.40.0.4 | iximeow | |
2020-03-15 | clean up operands some | iximeow | |
2020-03-15 | armv7 support through neon, some still missing (mainly coproc instrs) | iximeow | |
2020-02-23 | bring more armv7 tests back to the land of the living | iximeow | |
2020-02-17 | more strt/ldrt/strbt/ldrbt variants and operand display cleanup | iximeow | |
2020-02-17 | strh/ldrh/strht/ldrht and some misc cleanup | iximeow | |
2020-02-17 | entirely replace armv7 operands | iximeow | |
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-18 | some of the work to get yaxpeax-arm no-std | iximeow | |
2020-01-12 | be nicer about reaching incomplete parts of armv7 decoder | iximeow | |
2020-01-12 | match changes in arch to have Resulty decode, instead of Option | iximeow | |
2020-01-12 | update arm to revised decoder trait | iximeow | |
2020-01-12 | warnings-b-gone | iximeow | |
2020-01-12 | immediates are not shifted, what was this about? | iximeow | |
2020-01-12 | decode blx | iximeow | |
2020-01-12 | fix issue with incorrectly decoding register shifts | iximeow | |
2020-01-12 | fix the hex/bits mismatch | iximeow | |
2020-01-12 | silence armv7 warnings | iximeow | |
2020-01-12 | awful tweaks to expose a serde flag on yaxpeax-arch which will trickle ↵ | iximeow | |
through everything | |||
2020-01-12 | add colorized display to arm, as well as a PUSH pseduo-opcode | iximeow | |
2020-01-12 | update a bunch of arm stuff | iximeow | |
2020-01-12 | fix decode issue with stm/ldm/b, add tests, add display impl | iximeow | |