2019-05-30 12:44:56 +02:00
|
|
|
// The OS/K Team licenses this file to you under the MIT license.
|
2019-05-29 16:57:22 +02:00
|
|
|
// See the LICENSE file in the project root for more information.
|
|
|
|
|
|
|
|
#include "instrs.h"
|
|
|
|
#include "arch_i.h"
|
|
|
|
|
2019-05-30 20:32:52 +02:00
|
|
|
IMPL_COND(push);
|
|
|
|
IMPL_COND(pop);
|
|
|
|
IMPL_COND(call);
|
2019-05-30 20:23:27 +02:00
|
|
|
IMPL_COND(ret);
|
|
|
|
IMPL_COND(leave);
|
|
|
|
|
2019-05-29 16:57:22 +02:00
|
|
|
//
|
|
|
|
// Stack manipulation instructions
|
|
|
|
//
|
|
|
|
|
|
|
|
IMPL_START_1(push)
|
|
|
|
{
|
|
|
|
CHK_STACK(<);
|
|
|
|
PUSH(v1);
|
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|
|
|
|
IMPL_START_1(pop)
|
|
|
|
{
|
|
|
|
CHK_STACK(<=);
|
|
|
|
POP(v1);
|
|
|
|
}
|
|
|
|
IMPL_OUT;
|
|
|
|
|
|
|
|
IMPL_START_1(call)
|
|
|
|
{
|
|
|
|
CHK_STACK(<);
|
2019-06-02 16:33:28 +02:00
|
|
|
PUSH(rip);
|
2019-05-29 16:57:22 +02:00
|
|
|
JUMP(v1);
|
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|
|
|
|
IMPL_START_0(ret)
|
|
|
|
{
|
|
|
|
CHK_STACK(<=);
|
2019-06-02 16:33:28 +02:00
|
|
|
POP(rip);
|
2019-05-29 16:57:22 +02:00
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|
|
|
|
IMPL_START_0(enter)
|
|
|
|
{
|
2019-05-29 19:00:13 +02:00
|
|
|
// We don't CHK_STACK(<) here because ENTER
|
|
|
|
// (should) always be preceded by a CALL,
|
|
|
|
// which already checks the stack
|
2019-06-02 16:33:28 +02:00
|
|
|
PUSH(rbp);
|
|
|
|
rbp = rsp;
|
2019-05-29 16:57:22 +02:00
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|
|
|
|
IMPL_START_0(leave)
|
|
|
|
{
|
2019-05-29 19:00:13 +02:00
|
|
|
// Do NOT check stack here
|
|
|
|
// (it would always fail)
|
2019-06-02 16:33:28 +02:00
|
|
|
POP(rbp);
|
2019-05-29 16:57:22 +02:00
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|
|
|
|
IMPL_START_0(pushf)
|
|
|
|
{
|
|
|
|
CHK_STACK(<);
|
2019-06-02 16:33:28 +02:00
|
|
|
PUSH(flg);
|
2019-05-29 16:57:22 +02:00
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|
|
|
|
IMPL_START_0(popf)
|
|
|
|
{
|
|
|
|
CHK_STACK(<=);
|
2019-05-30 12:44:56 +02:00
|
|
|
|
2019-05-29 19:00:13 +02:00
|
|
|
// XXX
|
|
|
|
CHK_SUPERV();
|
2019-05-29 16:57:22 +02:00
|
|
|
|
2019-06-02 16:33:28 +02:00
|
|
|
POP(flg);
|
2019-05-29 16:57:22 +02:00
|
|
|
}
|
|
|
|
IMPL_END;
|
|
|
|
|