view tests/mini/asm6.d @ 1623:1d48eced441f

Merge DMD r317: bugzilla 3611 Enum forward referencing regression --- dmd/enum.c | 17 +++++++++++++++-- dmd/mtype.c | 4 ++++ 2 files changed, 19 insertions(+), 2 deletions(-)
author Leandro Lucarella <llucax@gmail.com>
date Wed, 06 Jan 2010 15:18:22 -0300
parents 08f87d8cd101
children
line wrap: on
line source

extern(C) int printf(char*, ...);

version (D_InlineAsm_X86)
    version = InlineAsm_X86_Any;
version (D_InlineAsm_X86_64)
    version = InlineAsm_X86_Any;

void main()
{
    int a,b,c;
    a = int.max-1;
    b = 5;
    version (InlineAsm_X86_Any)
    {
        asm
        {
            mov EAX, a;
            mov ECX, b;
            add EAX, ECX;
            jo Loverflow;
            mov c, EAX;
        }
    }
    printf("a == %d\n", a);
    printf("b == %d\n", b);
    printf("c == %d\n", c);
    assert(c == c);
    return;

Loverflow:
int y=0;
    //assert(0, "overflow");
}