mirror of
https://gitlab.os-k.eu/os-k-team/kvisc.git
synced 2023-08-25 14:05:46 +02:00
55 lines
735 B
C
55 lines
735 B
C
// The OS/K Team licenses this file to you under the MIT license.
|
|
// See the LICENSE file in the project root for more information.
|
|
|
|
#include "instrs.h"
|
|
#include "arch_i.h"
|
|
|
|
//
|
|
// Movement instructions
|
|
//
|
|
|
|
IMPL_START_2(mov)
|
|
{
|
|
v1 = v2;
|
|
}
|
|
IMPL_OUT;
|
|
|
|
IMPL_START_2(xchg)
|
|
{
|
|
ulong t = v1;
|
|
v1 = v2;
|
|
v2 = t;
|
|
}
|
|
IMPL_OUT;
|
|
|
|
IMPL_START_1(lea)
|
|
{
|
|
if (!p2->mem) {
|
|
_except(ctx, E_ILL, "Bad LEA format");
|
|
}
|
|
|
|
v1 = (p2->type == A_REG ? ctx->r[p2->val].val : p2->val) + p2->off;
|
|
}
|
|
IMPL_OUT;
|
|
|
|
IMPL_START_1(gcs)
|
|
{
|
|
v1 = ctx->r[CR1].val;
|
|
}
|
|
IMPL_OUT;
|
|
|
|
IMPL_START_2(cmovz)
|
|
{
|
|
if (ctx->r[FLG].val & ZF)
|
|
v1 = v2;
|
|
}
|
|
IMPL_OUT;
|
|
|
|
IMPL_START_2(cmovnz)
|
|
{
|
|
if (!(ctx->r[FLG].val & ZF))
|
|
v1 = v2;
|
|
}
|
|
IMPL_OUT;
|
|
|