1
0
mirror of https://gitlab.os-k.eu/os-k-team/kvisc.git synced 2023-08-25 14:05:46 +02:00
kvisc/vm/in/mov.c

85 lines
1.0 KiB
C
Raw Normal View History

2019-05-30 18:31:50 +02:00
// The OS/K Team licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
2019-06-05 12:53:09 +02:00
#include <in/instrs.h>
2019-05-30 18:31:50 +02:00
//
// Movement instructions
//
IMPL_START_2(mov)
{
v1 = v2;
}
IMPL_OUT;
2019-06-03 15:16:11 +02:00
IMPL_START_2(movb)
{
v1 = (v1 & 0xFFFFFFFFFFFFFF00)
| (v2 & 0x00000000000000FF);
}
IMPL_OUT;
IMPL_START_2(movw)
{
v1 = (v1 & 0xFFFFFFFFFFFF0000)
| (v2 & 0x000000000000FFFF);
}
IMPL_OUT;
IMPL_START_2(movl)
{
v1 = (v1 & 0xFFFFFFFF00000000)
| (v2 & 0x00000000FFFFFFFF);
}
IMPL_OUT;
IMPL_START_2(movt)
{
v1 = (v1 & 0xFFFF000000000000)
| (v2 & 0x0000FFFFFFFFFFFF);
}
IMPL_OUT;
2019-05-30 18:31:50 +02:00
IMPL_START_2(xchg)
{
ulong t = v1;
v1 = v2;
v2 = t;
}
2019-06-05 22:59:32 +02:00
IMPL_OUT_2;
2019-05-30 18:31:50 +02:00
IMPL_START_1(lea)
{
2019-06-07 22:23:38 +02:00
v1 = p2->addr;
2019-05-30 18:31:50 +02:00
}
IMPL_OUT;
2019-06-02 16:33:28 +02:00
IMPL_START_2(cmpxchg)
{
if (rax == v1) {
flg |= ZF;
v1 = v2;
}
else {
flg &= ~ZF;
rax = v1;
}
2019-05-30 18:31:50 +02:00
}
IMPL_OUT;
2019-06-07 13:38:34 +02:00
IMPL_START_1(gco)
{
v1 = cr1;
}
IMPL_OUT;
IMPL_START_1(gcd)
{
v1 = cr2;
}
IMPL_OUT;