mirror of
https://gitlab.os-k.eu/os-k-team/kvisc.git
synced 2023-08-25 14:05:46 +02:00
keyboard
This commit is contained in:
parent
18e97904e3
commit
27cb6a1b26
2
Makefile
2
Makefile
@ -6,7 +6,7 @@ KODIR=ka/obj
|
|||||||
all: kas
|
all: kas
|
||||||
|
|
||||||
kpc:
|
kpc:
|
||||||
@cd vm && make --no-print-directory verbose=no
|
@cd vm && make --no-print-directory -s verbose=yes
|
||||||
|
|
||||||
kas: kpc as/regs.lst as/k-as.py
|
kas: kpc as/regs.lst as/k-as.py
|
||||||
@cp vm/in/instrs.lst as
|
@cp vm/in/instrs.lst as
|
||||||
|
18
as/k-as.py
18
as/k-as.py
@ -216,6 +216,17 @@ def parse():
|
|||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
escape_dict = {
|
||||||
|
'n': '\n',
|
||||||
|
't': '\t',
|
||||||
|
'r': '\r',
|
||||||
|
'v': '\v',
|
||||||
|
'f': '\f',
|
||||||
|
'"': '"',
|
||||||
|
'\'': '\'',
|
||||||
|
'\\': '\\',
|
||||||
|
}
|
||||||
|
|
||||||
def parse_preproc(line):
|
def parse_preproc(line):
|
||||||
global pdata
|
global pdata
|
||||||
|
|
||||||
@ -286,10 +297,9 @@ def parse_preproc(line):
|
|||||||
if escaping:
|
if escaping:
|
||||||
escaping = False
|
escaping = False
|
||||||
|
|
||||||
if c == 'n':
|
if c in escape_dict:
|
||||||
c = '\n'
|
c = escape_dict[c]
|
||||||
elif c == 't':
|
|
||||||
c = '\t'
|
|
||||||
else:
|
else:
|
||||||
print("Unrecognized escape sequence: {}".format(line))
|
print("Unrecognized escape sequence: {}".format(line))
|
||||||
leave()
|
leave()
|
||||||
|
1
ka/ABI
1
ka/ABI
@ -56,7 +56,6 @@ the function
|
|||||||
- uses no local variables (on the stack)
|
- uses no local variables (on the stack)
|
||||||
- never uses any function that changes 'rbp' nor 'rsp',
|
- never uses any function that changes 'rbp' nor 'rsp',
|
||||||
aside from 'call' and 'ret'
|
aside from 'call' and 'ret'
|
||||||
- never calls a variadic function
|
|
||||||
|
|
||||||
You can never omit 'enter' without omitting 'leave', and vice-versa.
|
You can never omit 'enter' without omitting 'leave', and vice-versa.
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@ itoa:
|
|||||||
j.z .fini
|
j.z .fini
|
||||||
|
|
||||||
mov lx1, ax1
|
mov lx1, ax1
|
||||||
mod lx1, ax2 ; ax1 % base
|
rem lx1, ax2 ; ax1 % base
|
||||||
|
|
||||||
cmp lx1, 9 ; lx1 > 9 ?
|
cmp lx1, 9 ; lx1 > 9 ?
|
||||||
j.a .nondec
|
j.a .nondec
|
||||||
|
4
ka/dos.k
4
ka/dos.k
@ -20,8 +20,8 @@ include "crt/crt.k"
|
|||||||
;
|
;
|
||||||
; Disk Operating System
|
; Disk Operating System
|
||||||
;
|
;
|
||||||
include "sys/cpudev.k"
|
include "sys/drv/cpudev.k"
|
||||||
include "sys/memdev.k"
|
include "sys/drv/memdev.k"
|
||||||
include "sys/tests.k"
|
include "sys/tests.k"
|
||||||
include "sys/main.k"
|
include "sys/main.k"
|
||||||
|
|
||||||
|
@ -5,5 +5,6 @@
|
|||||||
; Main function
|
; Main function
|
||||||
;
|
;
|
||||||
main:
|
main:
|
||||||
|
call keybd_test
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
@ -1,6 +1,19 @@
|
|||||||
; The OS/K Team licenses this file to you under the MIT license.
|
; The OS/K Team licenses this file to you under the MIT license.
|
||||||
; See the LICENSE file in the project root for more information.
|
; See the LICENSE file in the project root for more information.
|
||||||
|
|
||||||
|
keybd_test:
|
||||||
|
.1:
|
||||||
|
scan rax
|
||||||
|
xpause
|
||||||
|
|
||||||
|
test rax, rax
|
||||||
|
j.z .1
|
||||||
|
|
||||||
|
prn rax
|
||||||
|
jmp .1
|
||||||
|
|
||||||
|
ret
|
||||||
|
|
||||||
putc_scroll_test:
|
putc_scroll_test:
|
||||||
mov rdx, 25
|
mov rdx, 25
|
||||||
.1:
|
.1:
|
||||||
|
@ -39,9 +39,9 @@ $(OBJDIR)/%.o: %.c
|
|||||||
$(OBJDIR)/%.d: %.c
|
$(OBJDIR)/%.d: %.c
|
||||||
@mkdir -p $(shell dirname $@)
|
@mkdir -p $(shell dirname $@)
|
||||||
@cc -I. -MM -MT $(@:%.d=%.o) -MF $@ $<
|
@cc -I. -MM -MT $(@:%.d=%.o) -MF $@ $<
|
||||||
@if [ $(verbose) = "yes" ]; then \
|
#@if [ $(verbose) = "yes" ]; then \
|
||||||
echo ${CL2}[$@] ${CL}dependencies generated.${CL3};\
|
# echo ${CL2}[$@] ${CL}dependencies generated.${CL3};\
|
||||||
fi
|
#fi
|
||||||
|
|
||||||
in/instrs.lst: in/INSTRS in/arch_i.py
|
in/instrs.lst: in/INSTRS in/arch_i.py
|
||||||
@cd in && python3 arch_i.py
|
@cd in && python3 arch_i.py
|
||||||
|
265
vm/in/INSTRS
265
vm/in/INSTRS
@ -183,13 +183,13 @@ mulf rm rim
|
|||||||
div rm rim
|
div rm rim
|
||||||
|
|
||||||
#
|
#
|
||||||
# Arithmetical unsigned MOD operation
|
# Arithmetical unsigned modulo operation (REM)
|
||||||
#
|
#
|
||||||
# $1 = $1 MOD $2
|
# $1 = $1 MOD $2
|
||||||
#
|
#
|
||||||
# Preserves all flags
|
# Preserves all flags
|
||||||
#
|
#
|
||||||
mod rm rim
|
rem rm rim
|
||||||
|
|
||||||
#
|
#
|
||||||
# Arithmetical unsigned 128-bit MUL operation
|
# Arithmetical unsigned 128-bit MUL operation
|
||||||
@ -382,10 +382,34 @@ push rim
|
|||||||
#
|
#
|
||||||
pop rm
|
pop rm
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
# I/O instructions #
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Send a character to standard output (PRN)
|
||||||
|
#
|
||||||
|
prn rim
|
||||||
|
|
||||||
|
#
|
||||||
|
# Scan a character from standard input (SCAN)
|
||||||
|
#
|
||||||
|
scan rm
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
#---------------------------------------------------------------------------#
|
||||||
# Supervisor only instructions #
|
# Supervisor only instructions #
|
||||||
#---------------------------------------------------------------------------#
|
#---------------------------------------------------------------------------#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Halt the processor until next E/I (HLT)
|
||||||
|
#
|
||||||
|
hlt
|
||||||
|
|
||||||
|
#
|
||||||
|
# Pause the CPU for a relatively long time (XPAUSE)
|
||||||
|
#
|
||||||
|
xpause
|
||||||
|
|
||||||
#
|
#
|
||||||
# Call an architecture-reserved function slot of device (DEVCTL)
|
# Call an architecture-reserved function slot of device (DEVCTL)
|
||||||
#
|
#
|
||||||
@ -400,6 +424,122 @@ devctl rim rim
|
|||||||
#
|
#
|
||||||
iocall rim rim
|
iocall rim rim
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
# E/I handling instructions #
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Trap into exception handler (TRAP)
|
||||||
|
#
|
||||||
|
# Throw:
|
||||||
|
# #ILL if $1 > 255
|
||||||
|
# #($1+256) otherwise
|
||||||
|
#
|
||||||
|
trap rim
|
||||||
|
|
||||||
|
#
|
||||||
|
# Return from exception/interrupt (IRET)
|
||||||
|
#
|
||||||
|
iret
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
# Misc. instructions #
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Do nothing (NOOP)
|
||||||
|
#
|
||||||
|
# (nothing)
|
||||||
|
#
|
||||||
|
# Throws:
|
||||||
|
# (nothing)
|
||||||
|
#
|
||||||
|
# Preserves all flags
|
||||||
|
#
|
||||||
|
nop
|
||||||
|
|
||||||
|
#
|
||||||
|
# Pause the CPU for a very short amount of time (PAUSE)
|
||||||
|
# Used in spin-like loops
|
||||||
|
#
|
||||||
|
pause
|
||||||
|
|
||||||
|
#
|
||||||
|
# CPU Identification Number
|
||||||
|
#
|
||||||
|
# Does nothing (for now)
|
||||||
|
#
|
||||||
|
cpuid
|
||||||
|
|
||||||
|
#
|
||||||
|
# Pseudo-random number generation (RAND32/RAND64)
|
||||||
|
#
|
||||||
|
# RAND32 generates a 32-bit pseudo-random number using
|
||||||
|
# a nonlinear additive feedback pseudo-random number generator
|
||||||
|
# of period 16 * (2^31 - 1).
|
||||||
|
#
|
||||||
|
# RAND64 generates two such numbers, and store them in the destination
|
||||||
|
# operand's higher and lower double words respectively
|
||||||
|
#
|
||||||
|
# The running program does not control the seeding and the processor
|
||||||
|
# may generate numbers from the same generator for other purposes
|
||||||
|
# than this instruction
|
||||||
|
#
|
||||||
|
#rand32 rm
|
||||||
|
#rand64 rm
|
||||||
|
|
||||||
|
#
|
||||||
|
# Get code/data offset (GCO/GCD)
|
||||||
|
#
|
||||||
|
# $1 = CR1 (GCO)
|
||||||
|
# $1 = CR2 (GCD)
|
||||||
|
#
|
||||||
|
gco rm
|
||||||
|
gcd rm
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
# Debugging instructions #
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Breakpoint instruction (BREAK)
|
||||||
|
#
|
||||||
|
# (cause register dump on standard error)
|
||||||
|
# (wait for user input before proceeeding)
|
||||||
|
#
|
||||||
|
break
|
||||||
|
|
||||||
|
#
|
||||||
|
# Step-by-step execution (STEP)
|
||||||
|
#
|
||||||
|
# IF $1 == 0 THEN
|
||||||
|
# (disable step-by-step execution)
|
||||||
|
# ELSE
|
||||||
|
# (enable step-by-step execution)
|
||||||
|
# FI
|
||||||
|
#
|
||||||
|
step rim
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
# Clean-up misc. instructions #
|
||||||
|
#---------------------------------------------------------------------------#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Clear base volatile registers (CLR)
|
||||||
|
#
|
||||||
|
# RAX = RBX = RCX = RDX = 0
|
||||||
|
# RSX = RBI = RDI = RSI = 0
|
||||||
|
#
|
||||||
|
clr
|
||||||
|
|
||||||
|
#
|
||||||
|
# Clear argument registers (CLA)
|
||||||
|
#
|
||||||
|
# AX0 = AX1 = AX2 = AX3 = 0
|
||||||
|
# AX4 = AX5 = AX6 = AX7 = 0
|
||||||
|
#
|
||||||
|
cla
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
#---------------------------------------------------------------------------#
|
||||||
# Flag manipulation instructions #
|
# Flag manipulation instructions #
|
||||||
#---------------------------------------------------------------------------#
|
#---------------------------------------------------------------------------#
|
||||||
@ -455,127 +595,6 @@ bswap rm rim
|
|||||||
wswap rm rim
|
wswap rm rim
|
||||||
dswap rm rim
|
dswap rm rim
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
# E/I handling instructions #
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
|
|
||||||
#
|
|
||||||
# Trap into exception handler (TRAP)
|
|
||||||
#
|
|
||||||
# Throw:
|
|
||||||
# #ILL if $1 > 255
|
|
||||||
# #($1+256) otherwise
|
|
||||||
#
|
|
||||||
trap rim
|
|
||||||
|
|
||||||
#
|
|
||||||
# Return from exception/interrupt (IRET)
|
|
||||||
#
|
|
||||||
iret
|
|
||||||
|
|
||||||
hlt
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
# Misc. instructions #
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
|
|
||||||
#
|
|
||||||
# Do nothing (NOOP)
|
|
||||||
#
|
|
||||||
# (nothing)
|
|
||||||
#
|
|
||||||
# Throws:
|
|
||||||
# (nothing)
|
|
||||||
#
|
|
||||||
# Preserves all flags
|
|
||||||
#
|
|
||||||
nop
|
|
||||||
|
|
||||||
#
|
|
||||||
# CPU Identification Number
|
|
||||||
#
|
|
||||||
# Does nothing (for now)
|
|
||||||
#
|
|
||||||
cpuid
|
|
||||||
|
|
||||||
#
|
|
||||||
# Pseudo-random number generation (RAND32/RAND64)
|
|
||||||
#
|
|
||||||
# RAND32 generates a 32-bit pseudo-random number using
|
|
||||||
# a nonlinear additive feedback pseudo-random number generator
|
|
||||||
# of period 16 * (2^31 - 1).
|
|
||||||
#
|
|
||||||
# RAND64 generates two such numbers, and store them in the destination
|
|
||||||
# operand's higher and lower double words respectively
|
|
||||||
#
|
|
||||||
# The running program does not control the seeding and the processor
|
|
||||||
# may generate numbers from the same generator for other purposes
|
|
||||||
# than this instruction
|
|
||||||
#
|
|
||||||
#rand32 rm
|
|
||||||
#rand64 rm
|
|
||||||
|
|
||||||
#
|
|
||||||
# Get code/data offset (GCO/GCD)
|
|
||||||
#
|
|
||||||
# $1 = CR1 (GCO)
|
|
||||||
# $1 = CR2 (GCD)
|
|
||||||
#
|
|
||||||
gco rm
|
|
||||||
gcd rm
|
|
||||||
|
|
||||||
#
|
|
||||||
# Send a character to standard output (PRN)
|
|
||||||
#
|
|
||||||
# Throws:
|
|
||||||
# #PRN if DV text mode enabled
|
|
||||||
# #PRN if graphic mode enabled
|
|
||||||
#
|
|
||||||
prn rim
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
# Debugging instructions #
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
|
|
||||||
#
|
|
||||||
# Breakpoint instruction (BREAK)
|
|
||||||
#
|
|
||||||
# (cause register dump on standard error)
|
|
||||||
# (wait for user input before proceeeding)
|
|
||||||
#
|
|
||||||
break
|
|
||||||
|
|
||||||
#
|
|
||||||
# Step-by-step execution (STEP)
|
|
||||||
#
|
|
||||||
# IF $1 == 0 THEN
|
|
||||||
# (disable step-by-step execution)
|
|
||||||
# ELSE
|
|
||||||
# (enable step-by-step execution)
|
|
||||||
# FI
|
|
||||||
#
|
|
||||||
step rim
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
# Clean-up misc. instructions #
|
|
||||||
#---------------------------------------------------------------------------#
|
|
||||||
|
|
||||||
#
|
|
||||||
# Clear base volatile registers (CLR)
|
|
||||||
#
|
|
||||||
# RAX = RBX = RCX = RDX = 0
|
|
||||||
# RSX = RBI = RDI = RSI = 0
|
|
||||||
#
|
|
||||||
clr
|
|
||||||
|
|
||||||
#
|
|
||||||
# Clear argument registers (CLA)
|
|
||||||
#
|
|
||||||
# AX0 = AX1 = AX2 = AX3 = 0
|
|
||||||
# AX4 = AX5 = AX6 = AX7 = 0
|
|
||||||
#
|
|
||||||
cla
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------#
|
#---------------------------------------------------------------------------#
|
||||||
# String manipulation instructions #
|
# String manipulation instructions #
|
||||||
#---------------------------------------------------------------------------#
|
#---------------------------------------------------------------------------#
|
||||||
|
@ -220,7 +220,7 @@ IMPL_START_2(div)
|
|||||||
}
|
}
|
||||||
IMPL_OUT;
|
IMPL_OUT;
|
||||||
|
|
||||||
IMPL_START_2(mod)
|
IMPL_START_2(rem)
|
||||||
{
|
{
|
||||||
v1 %= v2;
|
v1 %= v2;
|
||||||
}
|
}
|
||||||
|
27
vm/in/inout.c
Normal file
27
vm/in/inout.c
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
// 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 <in/instrs.h>
|
||||||
|
#include <pc/console.h>
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
IMPL_START_1(prn)
|
||||||
|
{
|
||||||
|
if (p1->mlen > 1) {
|
||||||
|
trace("prn warning: large access size\n");
|
||||||
|
}
|
||||||
|
console_putc(ctx, (char)v1);
|
||||||
|
}
|
||||||
|
IMPL_END;
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
IMPL_START_1(scan)
|
||||||
|
{
|
||||||
|
v1 = console_scankeybuf(ctx);
|
||||||
|
}
|
||||||
|
IMPL_OUT;
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
#include <in/instrs.h>
|
#include <in/instrs.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <pc/console.h>
|
#include <pc/console.h>
|
||||||
|
|
||||||
@ -18,6 +19,21 @@ IMPL_END;
|
|||||||
|
|
||||||
//----------------------------------------------------------------------------//
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
IMPL_START_0(pause)
|
||||||
|
{
|
||||||
|
usleep(5000);
|
||||||
|
}
|
||||||
|
IMPL_END;
|
||||||
|
|
||||||
|
IMPL_START_0(xpause)
|
||||||
|
{
|
||||||
|
CHK_SUPERV();
|
||||||
|
usleep(25000);
|
||||||
|
}
|
||||||
|
IMPL_END;
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
IMPL_START_0(cpuid)
|
IMPL_START_0(cpuid)
|
||||||
{
|
{
|
||||||
rax = rdx = 0;
|
rax = rdx = 0;
|
||||||
@ -50,17 +66,6 @@ IMPL_OUT;
|
|||||||
|
|
||||||
//----------------------------------------------------------------------------//
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
IMPL_START_1(prn)
|
|
||||||
{
|
|
||||||
if (p1->mlen > 1) {
|
|
||||||
trace("prn warning: large access size\n");
|
|
||||||
}
|
|
||||||
console_putc(ctx, (char)v1);
|
|
||||||
}
|
|
||||||
IMPL_END;
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------//
|
|
||||||
|
|
||||||
IMPL_START_0(clr)
|
IMPL_START_0(clr)
|
||||||
{
|
{
|
||||||
rax = rbx = rcx = rdx = 0;
|
rax = rbx = rcx = rdx = 0;
|
||||||
|
@ -77,6 +77,9 @@ void console_exit(ctx_t *ctx)
|
|||||||
SDL_DestroyTexture(scr_texts[y]);
|
SDL_DestroyTexture(scr_texts[y]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (scr_rend)
|
||||||
|
SDL_DestroyRenderer(scr_rend);
|
||||||
|
|
||||||
if (scr_win)
|
if (scr_win)
|
||||||
SDL_DestroyWindow(scr_win);
|
SDL_DestroyWindow(scr_win);
|
||||||
|
|
||||||
@ -102,6 +105,27 @@ void console_render(ctx_t *ctx)
|
|||||||
|
|
||||||
//----------------------------------------------------------------------------//
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
void console_update(ctx_t *ctx)
|
||||||
|
{
|
||||||
|
SDL_Event evt;
|
||||||
|
|
||||||
|
if (__builtin_expect(SDL_PollEvent(&evt) == 1, 0))
|
||||||
|
{
|
||||||
|
switch (evt.type)
|
||||||
|
{
|
||||||
|
case SDL_QUIT:
|
||||||
|
die(0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDL_KEYDOWN:
|
||||||
|
console_handle_input(ctx, evt.key.keysym.sym);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
void console_putat(ctx_t *ctx, char ch, int x, int y)
|
void console_putat(ctx_t *ctx, char ch, int x, int y)
|
||||||
{
|
{
|
||||||
SDL_Surface *surf;
|
SDL_Surface *surf;
|
||||||
@ -172,16 +196,28 @@ void console_putc(ctx_t *ctx, char ch)
|
|||||||
{
|
{
|
||||||
size_t y;
|
size_t y;
|
||||||
|
|
||||||
if (ch < ' ' && ch != '\n')
|
switch (ch)
|
||||||
ch = 127;
|
|
||||||
|
|
||||||
if (ch == '\n')
|
|
||||||
csn_x = CONSOLE_WIDTH;
|
|
||||||
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
|
case '\n':
|
||||||
|
csn_x = CONSOLE_WIDTH;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case '\r':
|
||||||
|
csn_x = 0;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case '\b':
|
||||||
|
if (csn_x == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
csn_x--;
|
||||||
|
console_putat(ctx, ' ', csn_x, csn_y);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
console_putat(ctx, ch, csn_x, csn_y);
|
console_putat(ctx, ch, csn_x, csn_y);
|
||||||
csn_x++;
|
csn_x++;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (csn_x == CONSOLE_WIDTH)
|
if (csn_x == CONSOLE_WIDTH)
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
// The OS/K Team licenses this file to you under the MIT license.
|
// The OS/K Team licenses this file to you under the MIT license.
|
||||||
// See the LICENSE file in the project root for more information.
|
// See the LICENSE file in the project root for more information.
|
||||||
|
|
||||||
|
// Critical ordering
|
||||||
#include <pc/arch.h>
|
#include <pc/arch.h>
|
||||||
#include <SDL2/SDL.h>
|
#include <SDL2/SDL.h>
|
||||||
#include <SDL2/SDL_ttf.h>
|
#include <SDL2/SDL_ttf.h>
|
||||||
|
#include <pc/keybd.h>
|
||||||
|
|
||||||
void console_init(ctx_t *ctx);
|
void console_init(ctx_t *ctx);
|
||||||
void console_exit(ctx_t *ctx);
|
void console_exit(ctx_t *ctx);
|
||||||
@ -11,4 +13,7 @@ void console_exit(ctx_t *ctx);
|
|||||||
void console_render(ctx_t *ctx);
|
void console_render(ctx_t *ctx);
|
||||||
void console_putat(ctx_t *ctx, char ch, int x, int y);
|
void console_putat(ctx_t *ctx, char ch, int x, int y);
|
||||||
void console_putc(ctx_t *ctx, char ch);
|
void console_putc(ctx_t *ctx, char ch);
|
||||||
|
void console_update(ctx_t *ctx);
|
||||||
|
|
||||||
|
void console_handle_input(ctx_t *, SDL_Keycode);
|
||||||
|
|
||||||
|
@ -20,8 +20,7 @@ enum
|
|||||||
E_DBF, // Double fault
|
E_DBF, // Double fault
|
||||||
E_IMP, // Not implemented
|
E_IMP, // Not implemented
|
||||||
E_ALI, // Alignment error
|
E_ALI, // Alignment error
|
||||||
E_STA, // Stack misalignment
|
E_BRK, // Ctrl+C or similar
|
||||||
E_STU, // Stack underflow
|
|
||||||
NEXCPTS
|
NEXCPTS
|
||||||
};
|
};
|
||||||
|
|
||||||
|
84
vm/pc/keybd.c
Normal file
84
vm/pc/keybd.c
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
// 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 <pc/console.h>
|
||||||
|
|
||||||
|
#define KEYBUFSIZE 8192
|
||||||
|
|
||||||
|
typedef uint keycode_t;
|
||||||
|
|
||||||
|
keycode_t keybuf[KEYBUFSIZE] = { 0 };
|
||||||
|
keycode_t *keybuf_last = &keybuf[0];
|
||||||
|
keycode_t *keybuf_ptr = &keybuf[0];
|
||||||
|
|
||||||
|
void console_addkey(ctx_t *ctx, keycode_t key)
|
||||||
|
{
|
||||||
|
*keybuf_ptr++ = key;
|
||||||
|
|
||||||
|
if (keybuf_ptr == keybuf + KEYBUFSIZE)
|
||||||
|
keybuf_ptr = &keybuf[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
keycode_t console_getkey(ctx_t *ctx)
|
||||||
|
{
|
||||||
|
keycode_t rc = *keybuf_last++;
|
||||||
|
|
||||||
|
if (keybuf_last == keybuf + KEYBUFSIZE)
|
||||||
|
keybuf_last = &keybuf[0];
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
keycode_t console_scankeybuf(ctx_t *ctx)
|
||||||
|
{
|
||||||
|
if (keybuf_last != keybuf_ptr)
|
||||||
|
return console_getkey(ctx);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void console_handle_input(ctx_t *ctx, SDL_Keycode key)
|
||||||
|
{
|
||||||
|
keycode_t code = 0;
|
||||||
|
|
||||||
|
SDL_Keymod mod = SDL_GetModState();
|
||||||
|
|
||||||
|
if (key <= 'z' && key >= 'a')
|
||||||
|
{
|
||||||
|
if (mod & (KMOD_CTRL|KMOD_ALT))
|
||||||
|
{
|
||||||
|
if (key == 'c')
|
||||||
|
_except(ctx, E_BRK, "Ctrl+C received");
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mod & KMOD_SHIFT)
|
||||||
|
key -= ('a' - 'A');
|
||||||
|
|
||||||
|
console_addkey(ctx, key);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (key <= '0' && key >= '9')
|
||||||
|
console_addkey(ctx, key);
|
||||||
|
|
||||||
|
switch (key)
|
||||||
|
{
|
||||||
|
case SDLK_SPACE: code = ' '; break;
|
||||||
|
case SDLK_BACKSLASH: code = '\\'; break;
|
||||||
|
case SDLK_BACKSPACE: code = '\b'; break;
|
||||||
|
|
||||||
|
case SDLK_RETURN:
|
||||||
|
case SDLK_RETURN2:
|
||||||
|
code = '\n';
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
console_addkey(ctx, code);
|
||||||
|
}
|
||||||
|
|
17
vm/pc/keybd.h
Normal file
17
vm/pc/keybd.h
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
// The OS/K Team licenses this file to you under the MIT license.
|
||||||
|
// See the LICENSE file in the project root for more information.
|
||||||
|
|
||||||
|
#define KEYBUFSIZE 8192
|
||||||
|
|
||||||
|
typedef uint keycode_t;
|
||||||
|
|
||||||
|
extern keycode_t keybuf[KEYBUFSIZE];
|
||||||
|
extern keycode_t *keybuf_last;
|
||||||
|
extern keycode_t *keybuf_ptr;
|
||||||
|
|
||||||
|
keycode_t console_getkey(ctx_t *);
|
||||||
|
keycode_t console_scankeybuf(ctx_t *);
|
||||||
|
|
||||||
|
void console_addkey(ctx_t *, keycode_t);
|
||||||
|
void console_handle_input(ctx_t *ctx, SDL_Keycode key);
|
||||||
|
|
10
vm/pc/main.c
10
vm/pc/main.c
@ -34,7 +34,7 @@ ctx_t main_ctx;
|
|||||||
|
|
||||||
void sigcommon(void)
|
void sigcommon(void)
|
||||||
{
|
{
|
||||||
_except(&main_ctx, 1023, "SIGNAL'ed");
|
_except(&main_ctx, E_BRK, "SIGNAL'ed");
|
||||||
}
|
}
|
||||||
|
|
||||||
void sigint(int _)
|
void sigint(int _)
|
||||||
@ -53,8 +53,6 @@ void sigsegv(int _)
|
|||||||
//
|
//
|
||||||
void main_loop(void)
|
void main_loop(void)
|
||||||
{
|
{
|
||||||
SDL_Event evt;
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Start decoding
|
// Start decoding
|
||||||
//
|
//
|
||||||
@ -62,11 +60,7 @@ void main_loop(void)
|
|||||||
// Execute one instruction
|
// Execute one instruction
|
||||||
decode(&main_ctx);
|
decode(&main_ctx);
|
||||||
|
|
||||||
if (__builtin_expect(SDL_PollEvent(&evt) == 1, 0))
|
console_update(&main_ctx);
|
||||||
{
|
|
||||||
if (evt.type == SDL_QUIT)
|
|
||||||
die(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (main_ctx.step)
|
if (main_ctx.step)
|
||||||
getchar();
|
getchar();
|
||||||
|
@ -22,7 +22,7 @@ int create_symtab(const char *name)
|
|||||||
{
|
{
|
||||||
// log("SYM: '%.*s' '%lu'\n", SYMLEN_MAX, buf, addr);
|
// log("SYM: '%.*s' '%lu'\n", SYMLEN_MAX, buf, addr);
|
||||||
|
|
||||||
if (prev_addr >= addr)
|
if (prev_addr > addr)
|
||||||
{
|
{
|
||||||
logerr("Symbol addresses in symbol table not in increasing order\n");
|
logerr("Symbol addresses in symbol table not in increasing order\n");
|
||||||
logerr("Previous symbol: '%s' '%lu'\n", symtab[it-1].name, prev_addr);
|
logerr("Previous symbol: '%s' '%lu'\n", symtab[it-1].name, prev_addr);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user