diff options
| -rw-r--r-- | tests/from_docs.rs | 42 | 
1 files changed, 42 insertions, 0 deletions
| diff --git a/tests/from_docs.rs b/tests/from_docs.rs new file mode 100644 index 0000000..62d7f0f --- /dev/null +++ b/tests/from_docs.rs @@ -0,0 +1,42 @@ +use yaxpeax_arch::Decoder; + +// for "lazy" reasons i've found fairly few known-correct disassemblies to compare against. but +// what i have are checked here.. + +fn test_display(bytes: &[u8], text: &str) { +    let decoder = yaxpeax_rx::InstDecoder::default(); +    let inst = decoder.decode(&mut yaxpeax_arch::U8Reader::new(bytes)).expect("decode succeeds"); +    let rendered = format!("{}", inst); +    assert_eq!(rendered, text); +} + +#[test] +fn from_support() { +    // this is from the image in +    // https://tool-support.renesas.com/autoupdate/support/onlinehelp/csp/V8.10.00/CS+.chm/DebugTool-RX.chm/Output/db_kinou_prog_disassemble.html +    // and more here +    // https://tool-support.renesas.com/autoupdate/support/onlinehelp/csp/V4.01.00/CS+.chm/DebugTool-RX.chm/Output/db_P_asm.html +    // which is wild but, hey. +    test_display(&[0x60, 0xc0], "sub #ch, r0"); +    test_display(&[0xf8, 0x0a, 0x00, 0x10], "mov.l #1000h, [r0]"); +    test_display(&[0xf9, 0x0a, 0x01, 0x78, 0x10], "mov.l #1078h, 4h[r0]"); +    test_display(&[0x3e, 0x02, 0x00], "mov.l #0h, 8h[r0]"); +    test_display(&[0x2e, 0x20], "bra.b $+0x20"); +    test_display(&[0xa8, 0x81], "mov.l 8h[r0], r1"); +    test_display(&[0xec, 0x02], "mov.l [r0], r2"); +    test_display(&[0xe3, 0x21], "mov.l r1, [r2]"); +    test_display(&[0x62, 0x11], "add #1h, r1"); +    test_display(&[0xa0, 0x81], "mov.l r1, 8h[r0]"); +} + +#[test] +fn from_manual() { +    test_display(&[0x08], "bra.s $+0x8"); +    test_display(&[0x09], "bra.s $+0x9"); +    test_display(&[0x0a], "bra.s $+0xa"); +    test_display(&[0x0b], "bra.s $+0x3"); +    test_display(&[0x0c], "bra.s $+0x4"); +    test_display(&[0x0d], "bra.s $+0x5"); +    test_display(&[0x0e], "bra.s $+0x6"); +    test_display(&[0x0f], "bra.s $+0x7"); +} | 
