ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; $Id$
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync;; @file
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; Disassembly testcase - Valid sign extension instructions.
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync;
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; This is a build test, that means it will be assembled, disassembled,
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; then the disassembly output will be assembled and the new binary will
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; compared with the original.
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync;
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync;
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; Copyright (C) 2008-2011 Oracle Corporation
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync;
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; This file is part of VirtualBox Open Source Edition (OSE), as
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; available from http://www.virtualbox.org. This file is free software;
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; you can redistribute it and/or modify it under the terms of the GNU
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; General Public License (GPL) as published by the Free Software
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; Foundation, in version 2 as it comes in the "COPYING" file of the
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync;
ac97f353c9ad3cbba306d0ec9d8c807bd29ba8a5vboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync%include "tstAsm.mac"
8599686860198730ae53d5895386d1b57dbc060evboxsync BITS TEST_BITS
8599686860198730ae53d5895386d1b57dbc060evboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync movsx ax, al
8599686860198730ae53d5895386d1b57dbc060evboxsync movsx eax, al
8599686860198730ae53d5895386d1b57dbc060evboxsync movsx eax, ax
8599686860198730ae53d5895386d1b57dbc060evboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync ;
8599686860198730ae53d5895386d1b57dbc060evboxsync ; ParseImmByteSX
8599686860198730ae53d5895386d1b57dbc060evboxsync ;
8599686860198730ae53d5895386d1b57dbc060evboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync ; 83 /x
8599686860198730ae53d5895386d1b57dbc060evboxsync add eax, strict byte 8
8599686860198730ae53d5895386d1b57dbc060evboxsync add eax, strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync cmp ebx, strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync add ax, strict byte 8
8599686860198730ae53d5895386d1b57dbc060evboxsync add ax, strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync cmp bx, strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync
2cae8ff5782536dc236e1161d351356ba2ac5e0fvboxsync%if TEST_BITS == 64 ; check that these come out with qword values and not words or dwords.
8599686860198730ae53d5895386d1b57dbc060evboxsync add rax, strict byte 8
8599686860198730ae53d5895386d1b57dbc060evboxsync add rax, strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync cmp rbx, strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync%endif
8599686860198730ae53d5895386d1b57dbc060evboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync ; push %Ib
8599686860198730ae53d5895386d1b57dbc060evboxsync push strict byte -1
8599686860198730ae53d5895386d1b57dbc060evboxsync push strict byte -128
8599686860198730ae53d5895386d1b57dbc060evboxsync push strict byte 127
8599686860198730ae53d5895386d1b57dbc060evboxsync
8599686860198730ae53d5895386d1b57dbc060evboxsync ;; @todo imul