Implemented vm routines for OP_OR_*
This commit is contained in:
@@ -366,3 +366,33 @@ void vm_not_word(vm_t *vm)
|
|||||||
vm_push_word(vm, DWORD(!a));
|
vm_push_word(vm, DWORD(!a));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void vm_or_byte(vm_t *vm)
|
||||||
|
{
|
||||||
|
if (vm->stack.ptr < 2)
|
||||||
|
// TODO: Error STACK_UNDERFLOW
|
||||||
|
return;
|
||||||
|
byte a = vm_pop_byte(vm).as_byte;
|
||||||
|
byte b = vm_pop_byte(vm).as_byte;
|
||||||
|
vm_push_byte(vm, DBYTE(a | b));
|
||||||
|
}
|
||||||
|
|
||||||
|
void vm_or_hword(vm_t *vm)
|
||||||
|
{
|
||||||
|
if (vm->stack.ptr < (HWORD_SIZE * 2))
|
||||||
|
// TODO: Error STACK_UNDERFLOW
|
||||||
|
return;
|
||||||
|
hword a = vm_pop_hword(vm).as_hword;
|
||||||
|
hword b = vm_pop_hword(vm).as_hword;
|
||||||
|
vm_push_hword(vm, DHWORD(a | b));
|
||||||
|
}
|
||||||
|
|
||||||
|
void vm_or_word(vm_t *vm)
|
||||||
|
{
|
||||||
|
if (vm->stack.ptr < (WORD_SIZE * 2))
|
||||||
|
// TODO: Error STACK_UNDERFLOW
|
||||||
|
return;
|
||||||
|
word a = vm_pop_word(vm).as_word;
|
||||||
|
word b = vm_pop_word(vm).as_word;
|
||||||
|
vm_push_word(vm, DWORD(a | b));
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -111,4 +111,14 @@ static const not_f NOT_ROUTINES[] = {
|
|||||||
[OP_NOT_WORD] = vm_not_word,
|
[OP_NOT_WORD] = vm_not_word,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void vm_or_byte(vm_t *);
|
||||||
|
void vm_or_hword(vm_t *);
|
||||||
|
void vm_or_word(vm_t *);
|
||||||
|
typedef void (*or_f)(vm_t *);
|
||||||
|
static const or_f OR_ROUTINES[] = {
|
||||||
|
[OP_OR_BYTE] = vm_or_byte,
|
||||||
|
[OP_OR_HWORD] = vm_or_hword,
|
||||||
|
[OP_OR_WORD] = vm_or_word,
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user