mirror of
https://gitlab.os-k.eu/os-k-team/kvisc.git
synced 2023-08-25 14:05:46 +02:00
iocall
This commit is contained in:
parent
1144444eff
commit
609a5a0d28
3
ka/dos.k
3
ka/dos.k
@ -18,7 +18,8 @@ _start:
|
||||
;
|
||||
; Include librairies
|
||||
;
|
||||
include "fmt/fmt.k"
|
||||
include "err/errno.k"
|
||||
include "fmt/format.k"
|
||||
include "prn/print.k"
|
||||
include "str/string.k"
|
||||
|
||||
|
8
ka/err/errno.k
Normal file
8
ka/err/errno.k
Normal file
@ -0,0 +1,8 @@
|
||||
; The OS/K Team licenses this file to you under the MIT license.
|
||||
; See the LICENSE file in the project root for more information.
|
||||
|
||||
EOK := 0
|
||||
EINVAL := 1
|
||||
|
||||
errno = 0
|
||||
|
@ -2,5 +2,102 @@
|
||||
; See the LICENSE file in the project root for more information.
|
||||
|
||||
;
|
||||
; char *itoa(char *buf, int num, int base)
|
||||
; char *_itoa(char *buf, int num, int base, int unsi)
|
||||
;
|
||||
; Acts as itoa if unsi == 0, as utoa otherwise
|
||||
;
|
||||
|
||||
_itoa:
|
||||
mov rax, ax0
|
||||
xor rdx, rdx
|
||||
|
||||
; make sure base is in [2, 32]
|
||||
|
||||
cmp ax2, 2
|
||||
cjmpb .bad
|
||||
|
||||
cmp ax2, 36
|
||||
cjmpa .bad
|
||||
|
||||
; deal with zero
|
||||
test ax1, ax1
|
||||
cjmpz .zero
|
||||
|
||||
; deal with base 10 signedness
|
||||
|
||||
test ax3, ax3 ; unsigned mode
|
||||
cjmpnz .conv
|
||||
|
||||
cmp ax2, 10 ; base 10
|
||||
cjmpnz .conv
|
||||
|
||||
cmp ax2, -9223372036854775808 ; LONG_MIN
|
||||
cjmpz .min
|
||||
|
||||
sgn rdx, ax1 ; extract ax1 sign
|
||||
|
||||
cmp rdx, -1 ; negative?
|
||||
cnotz ax1 ; -x = ~x+1
|
||||
cincz ax1 ; need "neg" inst...
|
||||
|
||||
; main loop
|
||||
.conv:
|
||||
test ax1, ax1
|
||||
cjmpz .fini
|
||||
|
||||
mov rsx, ax1
|
||||
mod rsx, ax2 ; ax1 % base
|
||||
|
||||
cmp rsx, 9 ; rsx > 9 ?
|
||||
caddz rsx, 48 ; '0'
|
||||
cjmpz .next
|
||||
|
||||
add rsx, 87 ; 'a' - 10
|
||||
mov ax1, rsx
|
||||
|
||||
.next:
|
||||
mov b[ax0], rsx
|
||||
inc ax0
|
||||
|
||||
div ax1, ax2
|
||||
break
|
||||
jmp .conv
|
||||
|
||||
; null-terminate and reverse
|
||||
.fini:
|
||||
mov b[ax0], 0
|
||||
ret
|
||||
|
||||
;
|
||||
; exceptional cases
|
||||
;
|
||||
|
||||
.bad:
|
||||
mov q[errno], EINVAL
|
||||
mov b[rax], 0
|
||||
ret
|
||||
|
||||
.zero:
|
||||
mov b[ax0], 48 ; '0'
|
||||
mov b[ax0+1], 0
|
||||
ret
|
||||
|
||||
.min:
|
||||
mov ax1, .min10
|
||||
call strcpy
|
||||
ret
|
||||
|
||||
.min10 = "-9223372036854775808"
|
||||
|
||||
;
|
||||
; wrappers
|
||||
;
|
||||
|
||||
itoa:
|
||||
mov ax3, 0
|
||||
jmp _itoa
|
||||
|
||||
utoa:
|
||||
mov ax3, 1
|
||||
jmp _itoa
|
||||
|
||||
|
28
ka/main.k
28
ka/main.k
@ -7,6 +7,32 @@
|
||||
main:
|
||||
enter
|
||||
|
||||
mov ax0, .buf
|
||||
mov ax1, 65
|
||||
mov ax2, 10
|
||||
call itoa
|
||||
|
||||
mov ax0, rax
|
||||
call print
|
||||
|
||||
; prn 10
|
||||
|
||||
mov ax0, .buf
|
||||
mov ax1, 0xffffffffffffffff
|
||||
mov ax2, 16
|
||||
call itoa
|
||||
|
||||
mov ax0, rax
|
||||
call print
|
||||
|
||||
leave
|
||||
ret
|
||||
|
||||
.buf = [32]
|
||||
|
||||
test:
|
||||
enter
|
||||
|
||||
mov ax0, .buf
|
||||
devctl 0, 1
|
||||
|
||||
@ -20,7 +46,7 @@ main:
|
||||
|
||||
.buf = [32]
|
||||
|
||||
test:
|
||||
test1:
|
||||
enter
|
||||
|
||||
mov ax0, .msg
|
||||
|
11
vm/dv/cpu.c
11
vm/dv/cpu.c
@ -3,28 +3,31 @@
|
||||
|
||||
#include <dv/dev.h>
|
||||
|
||||
void cpudev_testfn(ctx_t *ctx, dev_t *dev)
|
||||
long cpudev_testfn(ctx_t *ctx, dev_t *dev)
|
||||
{
|
||||
assert(dev == &cpudev);
|
||||
|
||||
rax = 4;
|
||||
rdx = 3;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void cpudev_poweron(ctx_t *ctx, dev_t *dev)
|
||||
long cpudev_poweron(ctx_t *ctx, dev_t *dev)
|
||||
{
|
||||
assert(dev == &cpudev);
|
||||
|
||||
dev->fslots[0] = cpudev_testfn;
|
||||
|
||||
dev->state = DEVGOOD;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
dev_t cpudev =
|
||||
{
|
||||
.type = "cpu",
|
||||
.name = "K-CPU",
|
||||
.modl = "K-CPU",
|
||||
.modl = "Prisma 1",
|
||||
.vend = "The OS/K Team",
|
||||
|
||||
.major = 0,
|
||||
|
@ -6,7 +6,7 @@
|
||||
#define DEVLEN 32
|
||||
#define DEVSLOTS 256
|
||||
|
||||
typedef void (*devfn_t)(ctx_t *, dev_t *);
|
||||
typedef long (*devfn_t)(ctx_t *, dev_t *);
|
||||
|
||||
enum
|
||||
{
|
||||
|
@ -86,6 +86,7 @@ IMPL_START_2(iocall)
|
||||
{
|
||||
CHK_SUPERV();
|
||||
|
||||
long rc;
|
||||
dev_t *dev = devctl_common(ctx, v1, v2);
|
||||
|
||||
if (dev == NULL)
|
||||
@ -97,8 +98,10 @@ IMPL_START_2(iocall)
|
||||
else if (dev->fslots[v2] == NULL)
|
||||
rax = -6;
|
||||
|
||||
else
|
||||
dev->fslots[v2](ctx, dev);
|
||||
else {
|
||||
rc = dev->fslots[v2](ctx, dev);
|
||||
if (rc < 0) rax = rc;
|
||||
}
|
||||
}
|
||||
IMPL_END;
|
||||
|
||||
|
26
vm/in/INSTRS
26
vm/in/INSTRS
@ -42,12 +42,19 @@ cshrnz rm rim
|
||||
# rax = rax / $0
|
||||
|
||||
sgn rm rim
|
||||
add rm rim
|
||||
sub rm rim
|
||||
mul rim
|
||||
div rim
|
||||
|
||||
inc rm
|
||||
dec rm
|
||||
add rm rim
|
||||
sub rm rim
|
||||
|
||||
mul rm rim
|
||||
mul2 rim
|
||||
|
||||
div rm rim
|
||||
div2 rim
|
||||
|
||||
mod rm rim
|
||||
|
||||
csgnz rm rim
|
||||
caddz rm rim
|
||||
@ -184,7 +191,16 @@ iocall rim rim
|
||||
# Misc. instructions
|
||||
#
|
||||
|
||||
# Prints a character on the screen
|
||||
# Clear rax...rsi
|
||||
clr
|
||||
|
||||
# Clear ax0...ax7
|
||||
cla
|
||||
|
||||
# Clear nx0...nx7
|
||||
cln
|
||||
|
||||
# Print a character on the screen
|
||||
prn rim
|
||||
|
||||
#
|
||||
|
@ -27,7 +27,13 @@ IMPL_START_2(sub)
|
||||
}
|
||||
IMPL_OUT;
|
||||
|
||||
IMPL_START_1(mul)
|
||||
IMPL_START_2(mul)
|
||||
{
|
||||
v1 *= v2;
|
||||
}
|
||||
IMPL_OUT;
|
||||
|
||||
IMPL_START_1(mul2)
|
||||
{
|
||||
// Adapted from www.codeproject.com/Tips/618570/UInt-Multiplication-Squaring
|
||||
ulong v2 = v1;
|
||||
@ -53,7 +59,19 @@ IMPL_START_1(mul)
|
||||
}
|
||||
IMPL_END;
|
||||
|
||||
IMPL_START_1(div)
|
||||
IMPL_START_2(div)
|
||||
{
|
||||
v1 /= v2;
|
||||
}
|
||||
IMPL_OUT;
|
||||
|
||||
IMPL_START_2(mod)
|
||||
{
|
||||
v1 %= v2;
|
||||
}
|
||||
IMPL_OUT;
|
||||
|
||||
IMPL_START_1(div2)
|
||||
{
|
||||
rdx = rax % v1;
|
||||
rax = rax / v1;
|
||||
|
@ -32,3 +32,24 @@ IMPL_START_1(prn)
|
||||
}
|
||||
IMPL_END;
|
||||
|
||||
IMPL_START_0(clr)
|
||||
{
|
||||
rax = rbx = rcx = rdx = 0;
|
||||
rsx = rbi = rdi = rsi = 0;
|
||||
}
|
||||
IMPL_END;
|
||||
|
||||
IMPL_START_0(cla)
|
||||
{
|
||||
ax0 = ax1 = ax2 = ax3 = 0;
|
||||
ax4 = ax5 = ax6 = ax7 = 0;
|
||||
}
|
||||
IMPL_END;
|
||||
|
||||
IMPL_START_0(cln)
|
||||
{
|
||||
nx0 = nx1 = nx2 = nx3 = 0;
|
||||
nx4 = nx5 = nx6 = nx7 = 0;
|
||||
}
|
||||
IMPL_END;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user