aboutsummaryrefslogtreecommitdiff
path: root/test/real_mode/operand.rs
blob: fb2ce3990ced84524faffeb6992031b7d7cb858f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
use yaxpeax_x86::real_mode::{InstDecoder};

#[test]
fn test_implied_memory_width() {
    fn mem_size_of(data: &[u8]) -> Option<u8> {
        let decoder = InstDecoder::default();
        decoder.decode_slice(data).unwrap().mem_size().unwrap().bytes_size()
    }

    // test push, pop, call, and ret
    assert_eq!(mem_size_of(&[0xc3]), Some(2));
    assert_eq!(mem_size_of(&[0xe8, 0x11, 0x22, 0x33, 0x44]), Some(2));
    assert_eq!(mem_size_of(&[0x50]), Some(2));
    assert_eq!(mem_size_of(&[0x58]), Some(2));
    assert_eq!(mem_size_of(&[0x66, 0x50]), Some(2));
    assert_eq!(mem_size_of(&[0x66, 0x58]), Some(2));
    assert_eq!(mem_size_of(&[0xff, 0xf0]), Some(2));
    assert_eq!(mem_size_of(&[0x66, 0xff, 0xf0]), Some(4));
    // unlike 64-bit mode, operand-size prefixed call and jump do have a different size: they read
    // four bytes.
    assert_eq!(mem_size_of(&[0x66, 0xff, 0x10]), Some(4));
    assert_eq!(mem_size_of(&[0x66, 0xff, 0x20]), Some(4));
    // pushf
    assert_eq!(mem_size_of(&[0x9c]), Some(2));
    // popf
    assert_eq!(mem_size_of(&[0x9d]), Some(2));
    // leave
    assert_eq!(mem_size_of(&[0xc9]), Some(2));
    // xlat
    assert_eq!(mem_size_of(&[0xd7]), Some(1));
    // push fs
    assert_eq!(mem_size_of(&[0x0f, 0xa0]), Some(2));
    // pop fs
    assert_eq!(mem_size_of(&[0x0f, 0xa1]), Some(2));
    // push gs
    assert_eq!(mem_size_of(&[0x0f, 0xa8]), Some(2));
    // pop gs
    assert_eq!(mem_size_of(&[0x0f, 0xa9]), Some(2));

    // "maskmovq mm0, mm1"
    assert_eq!(mem_size_of(&[0x0f, 0xf7, 0xc1]), Some(8));
    assert_eq!(mem_size_of(&[0x67, 0x0f, 0xf7, 0xc1]), Some(8));

    // "maskmovdqu xmm0, xmm1"
    assert_eq!(mem_size_of(&[0x66, 0x0f, 0xf7, 0xc1]), Some(16));
    assert_eq!(mem_size_of(&[0x67, 0x66, 0x0f, 0xf7, 0xc1]), Some(16));

    // "vmaskmovdqu xmm0, xmm1"
    assert_eq!(mem_size_of(&[0xc4, 0xe1, 0x79, 0xf7, 0xc1]), Some(16));
    assert_eq!(mem_size_of(&[0x67, 0xc4, 0xe1, 0x79, 0xf7, 0xc1]), Some(16));

    // callf 0xcf23:0x2d62
    assert_eq!(mem_size_of(&[0x9a, 0x62, 0x2d, 0x23, 0xcf]), Some(4));
    assert_eq!(mem_size_of(&[0x66, 0x9a, 0x62, 0x2d, 0x00, 0x00, 0x23, 0xcf]), Some(6));
}