#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <malloc.h>
typedef unsigned char UChar;
typedef unsigned int UInt;
typedef unsigned long int UWord;
typedef unsigned long long int ULong;
typedef struct { UChar cs[40]; } Block;
void showBlock ( char* msg, Block* b )
{
int i;
printf(" %s ", msg);
for (i = 0; i < 40; i++)
printf("%02x", (UInt)b->cs[i]);
printf("\n");
}
UChar randUChar ( void )
{
static UInt seed = 80021;
seed = 1103515245 * seed + 12345;
return (seed >> 17) & 0xFF;
}
void randBlock ( Block* b )
{
int i;
UChar* p = (UChar*)b;
for (i = 0; i < sizeof(Block); i++)
p[i] = randUChar();
}
/* Generate a function test_NAME, that tests the given insn.
The insn may only mention (%rax) and r9. */
#define GEN_test_Monly(_name, _mem_form) \
\
__attribute__ ((noinline)) static void test_##_name ( void ) \
{ \
Block* b = memalign(32, sizeof(Block)); \
randBlock(b); \
printf("%s\n", #_name); \
showBlock("before", b); \
__asm__ __volatile__( \
"leaq 16(%0),%%rax" "\n\t" \
"movq 24(%0),%%r9" "\n\t" \
_mem_form "\n\t" \
"movq %%r9, 32(%0)" "\n\t" \
: /*OUT*/ \
: /*IN*/"r"(b) \
: /*TRASH*/"r9","rax","memory","cc" \
); \
showBlock("after ", b); \
printf("\n"); \
free(b); \
}
GEN_test_Monly( MOVBE_RtoM_64, "movbe %%r9, 1(%%rax)")
GEN_test_Monly( MOVBE_RtoM_32, "movbe %%r9d,1(%%rax)")
GEN_test_Monly( MOVBE_RtoM_16, "movbe %%r9w,1(%%rax)")
GEN_test_Monly( MOVBE_MtoR_64, "movbe 1(%%rax), %%r9")
GEN_test_Monly( MOVBE_MtoR_32, "movbe 1(%%rax), %%r9d")
GEN_test_Monly( MOVBE_MtoR_16, "movbe 1(%%rax), %%r9w")
int main ( void )
{
test_MOVBE_RtoM_64();
test_MOVBE_RtoM_32();
test_MOVBE_RtoM_16();
test_MOVBE_MtoR_64();
test_MOVBE_MtoR_32();
test_MOVBE_MtoR_16();
return 0;
}