forked from KolibriOS/kolibrios
- Module files are removed from the source folder.
- Removed fasm debug module. - Added debug function to "kolibri" module. git-svn-id: svn://kolibrios.org@8475 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
4930c1d7a2
commit
6db1f4dd5a
19
programs/develop/tinypy/modules/kolibri/debug.c
Normal file
19
programs/develop/tinypy/modules/kolibri/debug.c
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
#include "tp.h"
|
||||||
|
|
||||||
|
void debug_write_byte(const char ch){
|
||||||
|
__asm__ __volatile__(
|
||||||
|
"int $0x40"
|
||||||
|
::"a"(63), "b"(1), "c"(ch)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
tp_obj kolibri_debug_print(TP)
|
||||||
|
{
|
||||||
|
tp_obj str = TP_TYPE(TP_STRING);
|
||||||
|
for(int i=0; i < str.string.len; i++)
|
||||||
|
{
|
||||||
|
debug_write_byte(str.string.val[i]);
|
||||||
|
}
|
||||||
|
return tp_None;
|
||||||
|
}
|
||||||
|
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
extern tp_obj kolibri_open(TP);
|
extern tp_obj kolibri_open(TP);
|
||||||
extern tp_obj kolibri_mainwindow(TP);
|
extern tp_obj kolibri_mainwindow(TP);
|
||||||
|
extern tp_obj kolibri_debug_print(TP);
|
||||||
extern tp_obj kolibri_socket_module(TP);
|
extern tp_obj kolibri_socket_module(TP);
|
||||||
extern tp_obj tp_dict(TP);
|
extern tp_obj tp_dict(TP);
|
||||||
extern tp_obj tp_fnc(TP,tp_obj v(TP));
|
extern tp_obj tp_fnc(TP,tp_obj v(TP));
|
||||||
@ -13,6 +14,8 @@ void kolibri_init(TP)
|
|||||||
|
|
||||||
tp_set(tp, kolibri_mod, tp_string("open"), tp_fnc(tp, kolibri_open));
|
tp_set(tp, kolibri_mod, tp_string("open"), tp_fnc(tp, kolibri_open));
|
||||||
tp_set(tp, kolibri_mod, tp_string("window"), tp_fnc(tp, kolibri_mainwindow));
|
tp_set(tp, kolibri_mod, tp_string("window"), tp_fnc(tp, kolibri_mainwindow));
|
||||||
|
/* debug */
|
||||||
|
tp_set(tp, kolibri_mod, tp_string("debug_print"), tp_fnc(tp, kolibri_debug_print));
|
||||||
/* socket is a separated module. */
|
/* socket is a separated module. */
|
||||||
tp_set(tp, kolibri_mod, tp_string("socket"), socket_mod);
|
tp_set(tp, kolibri_mod, tp_string("socket"), socket_mod);
|
||||||
|
|
||||||
|
@ -13,21 +13,24 @@ CFLAGS = -U_Win32 -U_WIN32 -U__MINGW32__ -mpreferred-stack-boundary=2 \
|
|||||||
INCLUDES= -I. -I$(SDK_DIR)/sources/newlib/libc/include
|
INCLUDES= -I. -I$(SDK_DIR)/sources/newlib/libc/include
|
||||||
LIBPATH:= -L $(SDK_DIR)/lib -L /home/autobuild/tools/win32/mingw32/lib
|
LIBPATH:= -L $(SDK_DIR)/lib -L /home/autobuild/tools/win32/mingw32/lib
|
||||||
|
|
||||||
|
KOLIBRI_M_OBJ= ../modules/kolibri/init.o \
|
||||||
|
../modules/kolibri/fs.o \
|
||||||
|
../modules/kolibri/net.o \
|
||||||
|
../modules/kolibri/gui.o \
|
||||||
|
../modules/kolibri/debug.o \
|
||||||
|
|
||||||
OBJECTS = tpmain.o kolibri_init.o kolibri_fs.o kolibri_gui.o kolibri_net.o kolibri_dbg.obj
|
|
||||||
|
OBJECTS = tpmain.o $(KOLIBRI_M_OBJ)
|
||||||
|
|
||||||
all:$(NAME)
|
all:$(NAME)
|
||||||
|
|
||||||
$(NAME): $(OBJECTS) Makefile
|
$(NAME): $(OBJECTS)
|
||||||
$(LD) $(LIBPATH) --subsystem native -o $@ $(OBJECTS) $(LDFLAGS) -n -Map $(NAME).map
|
$(LD) $(LIBPATH) --subsystem native -o $@ $(OBJECTS) $(LDFLAGS) -n -Map $(NAME).map
|
||||||
kos32-objcopy $@ -O binary
|
kos32-objcopy $@ -O binary
|
||||||
|
kpack $@
|
||||||
|
|
||||||
%.o : %.c Makefile
|
%.o : %.c Makefile
|
||||||
$(CC) -c $(INCLUDES) $(CFLAGS) -o $@ $<
|
$(CC) -c $(INCLUDES) $(CFLAGS) -o $@ $<
|
||||||
|
|
||||||
kolibri_dbg.obj: fasm_modules/kolibri_dbg.s
|
|
||||||
fasm fasm_modules/kolibri_dbg.s
|
|
||||||
cp fasm_modules/kolibri_dbg.obj .
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
-rm -f *.o $(NAME).map fasm_modules/kolibri_dbg.obj kolibri_dbg.obj
|
rm -f *.o $(NAME).map $(KOLIBRI_M_OBJ)
|
||||||
|
@ -1,155 +0,0 @@
|
|||||||
; TinyPy module
|
|
||||||
; Name: kolibri_dbg
|
|
||||||
;
|
|
||||||
; Exports:
|
|
||||||
; debug_print(msg) - prints a message to debug board.
|
|
||||||
|
|
||||||
format coff
|
|
||||||
use32 ; Tell compiler to use 32 bit instructions
|
|
||||||
|
|
||||||
section '.init' code ; Keep this line before includes or GCC messes up call addresses
|
|
||||||
|
|
||||||
include '../../../proc32.inc'
|
|
||||||
include '../../../struct.inc'
|
|
||||||
purge section,mov,add,sub
|
|
||||||
include 'tinypy.inc'
|
|
||||||
|
|
||||||
include '../../../../programs/dll.inc'
|
|
||||||
|
|
||||||
extrn '_tp_dict' as tp_dict
|
|
||||||
extrn '_tp_set' as tp_set
|
|
||||||
extrn '_tp_get' as tp_get
|
|
||||||
extrn '_tp_None' as tp_None
|
|
||||||
extrn '_tp_fnc' as tp_fnc
|
|
||||||
|
|
||||||
public kolibri_dbg_init as '_kolibri_dbg_init'
|
|
||||||
|
|
||||||
; Module name
|
|
||||||
modname db "kolibri_dbg"
|
|
||||||
modnamelen = $-modname
|
|
||||||
|
|
||||||
; Exported function name
|
|
||||||
debug_print_name db "debug_print"
|
|
||||||
debug_print_namelen = $-debug_print_name
|
|
||||||
; Export dictionary for module
|
|
||||||
kolibri_dbg_dict rb sizeof.tp_obj
|
|
||||||
; tp_obj of exported function
|
|
||||||
debug_print_obj rb sizeof.tp_obj
|
|
||||||
|
|
||||||
; Function debug_print(tp_vm *tp)
|
|
||||||
; return nothing
|
|
||||||
debug_print:
|
|
||||||
push ebp
|
|
||||||
mov ebp, esp
|
|
||||||
; Store registers
|
|
||||||
push eax
|
|
||||||
push ebx
|
|
||||||
push ecx
|
|
||||||
push edx
|
|
||||||
sub esp, sizeof.tp_obj; Reserve tp_obj tmp
|
|
||||||
mov edx, esp
|
|
||||||
push edx ;Store &tmp
|
|
||||||
; Obtain tp_string parameter
|
|
||||||
; tp_get(&tmp, tp, *(tp_obj *)(tp_vm->params), tp_None)
|
|
||||||
push_tp_none
|
|
||||||
mov eax, dword[ebp+12] ;4 for return address, 4 for result pointer; 4 for tp_vm
|
|
||||||
add eax, tp_vm.params
|
|
||||||
push_tp_obj_at_reg eax
|
|
||||||
push dword[ebp+12]
|
|
||||||
push edx ;ebx contains address of reserved tp_obj variable
|
|
||||||
call tp_get
|
|
||||||
|
|
||||||
;Restore stack
|
|
||||||
add esp, sizeof.tp_obj*2+4;2 tp_obj's and 2 pointers in parameters minus 1 pointer to result (cleared inside tp_get)
|
|
||||||
|
|
||||||
;Leave if parameter is not a string. tp_raise() should be called here.
|
|
||||||
pop edx; edx = &tmp
|
|
||||||
cmp dword[edx], TP_STRING ; Check that function returned a TP_STRING
|
|
||||||
jne .exit
|
|
||||||
mov ecx, dword[edx+tp_string_.len] ; String length
|
|
||||||
mov edx, dword[edx+tp_string_.val] ;
|
|
||||||
mov eax, 63
|
|
||||||
mov ebx, 1
|
|
||||||
.cont:
|
|
||||||
; Print message.
|
|
||||||
push ecx ; Store ecx to use it in inner loop
|
|
||||||
mov cl, byte[edx]
|
|
||||||
inc edx
|
|
||||||
int 40h
|
|
||||||
pop ecx ; Get ecx back
|
|
||||||
loop .cont
|
|
||||||
.exit:
|
|
||||||
add esp, sizeof.tp_obj ; Release tp_obj reserved in stack.
|
|
||||||
; Returning tp_None
|
|
||||||
mov eax, dword[ebp+8]
|
|
||||||
mov dword[eax], 0
|
|
||||||
; Restore registers
|
|
||||||
pop edx
|
|
||||||
pop ecx
|
|
||||||
pop ebx
|
|
||||||
pop eax
|
|
||||||
mov esp, ebp
|
|
||||||
pop ebp
|
|
||||||
ret
|
|
||||||
|
|
||||||
;void kolibri_dbg_init(tp_vm *tp);
|
|
||||||
kolibri_dbg_init:
|
|
||||||
push ebp
|
|
||||||
mov ebp, esp
|
|
||||||
;Save registers
|
|
||||||
push eax
|
|
||||||
push ebx
|
|
||||||
push ecx
|
|
||||||
; Create module dictionary and store its address in kolibri_dbg_str
|
|
||||||
mov eax, dword [ebp + 8]
|
|
||||||
push eax
|
|
||||||
push kolibri_dbg_dict
|
|
||||||
call tp_dict
|
|
||||||
add esp, 4 ;Clear stack
|
|
||||||
; Push tp_obj structure pointed by kolibri_dbg_dict
|
|
||||||
push_tp_obj kolibri_dbg_dict
|
|
||||||
; Push modname as a tp_obj object
|
|
||||||
push modnamelen; len
|
|
||||||
push modname ; val
|
|
||||||
push 0 ;_tp_string info
|
|
||||||
push TP_STRING ; type
|
|
||||||
; Push tp_obj structure pointed by tp->modules
|
|
||||||
mov eax, dword [ebp + 8]
|
|
||||||
add eax, tp_vm.modules + 16
|
|
||||||
mov ecx, 4
|
|
||||||
.push_tpobj1:
|
|
||||||
sub eax, 4
|
|
||||||
push dword[eax]
|
|
||||||
loop .push_tpobj1
|
|
||||||
push eax
|
|
||||||
call tp_set
|
|
||||||
add esp, sizeof.tp_obj*3+4
|
|
||||||
; Register "debug_print" function
|
|
||||||
;Reserve memory for function tp_obj object
|
|
||||||
sub esp, sizeof.tp_obj
|
|
||||||
mov eax, esp
|
|
||||||
push debug_print
|
|
||||||
push dword[ebp+8]
|
|
||||||
push eax
|
|
||||||
call tp_fnc
|
|
||||||
add esp, 8; tp_obj is already in stack, adding other arguments
|
|
||||||
;Pushing function name tp_obj
|
|
||||||
;mov eax, esp
|
|
||||||
;push_tp_obj_at_reg eax
|
|
||||||
push debug_print_namelen
|
|
||||||
push debug_print_name
|
|
||||||
push 0
|
|
||||||
push TP_STRING
|
|
||||||
;Pushing module dictionary tp_obj
|
|
||||||
push_tp_obj kolibri_dbg_dict
|
|
||||||
;Pushing tp_vm
|
|
||||||
push dword[ebp+8]
|
|
||||||
call tp_set
|
|
||||||
add esp, sizeof.tp_obj*3+4
|
|
||||||
; Leaving function
|
|
||||||
pop ecx
|
|
||||||
pop ebx
|
|
||||||
pop eax
|
|
||||||
mov esp, ebp
|
|
||||||
pop ebp
|
|
||||||
ret
|
|
@ -1,184 +0,0 @@
|
|||||||
; Python object types
|
|
||||||
TP_NONE equ 0
|
|
||||||
TP_NUMBER equ 1
|
|
||||||
TP_STRING equ 2
|
|
||||||
TP_DICT equ 3
|
|
||||||
TP_LIST equ 4
|
|
||||||
TP_FNC equ 5
|
|
||||||
TP_DATA equ 6
|
|
||||||
|
|
||||||
; Python "number" object. Can be treated as integer or float.
|
|
||||||
struct tp_number_
|
|
||||||
type rd 1
|
|
||||||
val rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; GC information for "string" object
|
|
||||||
struct _tp_string
|
|
||||||
gci rd 1
|
|
||||||
s rb 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; Python "string" object
|
|
||||||
struct tp_string_
|
|
||||||
type rd 1
|
|
||||||
info rd 1 ;pointer to _tp_string
|
|
||||||
val rd 1
|
|
||||||
len rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; GC information for "list" object
|
|
||||||
struct _tp_list
|
|
||||||
gci rd 1
|
|
||||||
items rd 1
|
|
||||||
len rd 1
|
|
||||||
alloc rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; Python "list" object
|
|
||||||
struct tp_list_
|
|
||||||
type rd 1
|
|
||||||
val rd 1 ;pointer to _tp_list
|
|
||||||
ends
|
|
||||||
|
|
||||||
|
|
||||||
; GC information for "dict" object
|
|
||||||
struct _tp_dict
|
|
||||||
gci rd 1
|
|
||||||
items rd 1
|
|
||||||
len rd 1
|
|
||||||
alloc rd 1
|
|
||||||
cur rd 1
|
|
||||||
mask rd 1
|
|
||||||
used rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; Python "dict" object
|
|
||||||
struct tp_dict_
|
|
||||||
type rd 1
|
|
||||||
val rd 1 ;pointer to _tp_dict
|
|
||||||
ends
|
|
||||||
|
|
||||||
; GC information for "function" object
|
|
||||||
; todo
|
|
||||||
|
|
||||||
; Python "function" object
|
|
||||||
struct tp_fnc_
|
|
||||||
type rd 1
|
|
||||||
info rd 1
|
|
||||||
ftype rd 1
|
|
||||||
val rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; Python "data" object
|
|
||||||
struct tp_data_
|
|
||||||
type rd 1
|
|
||||||
info rd 1
|
|
||||||
val rd 1
|
|
||||||
magic rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
struct tp_gc_info
|
|
||||||
type rd 1
|
|
||||||
data rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; Generic Python object
|
|
||||||
struct tp_obj
|
|
||||||
union
|
|
||||||
type rd 1
|
|
||||||
string tp_string_
|
|
||||||
number tp_number_
|
|
||||||
gc_info tp_gc_info
|
|
||||||
dict tp_dict_
|
|
||||||
list tp_list_
|
|
||||||
fnc tp_fnc_
|
|
||||||
dat tp_data_
|
|
||||||
ends
|
|
||||||
ends
|
|
||||||
|
|
||||||
; Bytecode element
|
|
||||||
struct sregs
|
|
||||||
.i rb 1
|
|
||||||
.a rb 1
|
|
||||||
.b rb 1
|
|
||||||
.c rb 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
struct tp_code
|
|
||||||
union
|
|
||||||
i rb 1
|
|
||||||
regs sregs
|
|
||||||
string rb 4
|
|
||||||
number rp 1
|
|
||||||
ends
|
|
||||||
ends
|
|
||||||
|
|
||||||
; TinyPy VM frame
|
|
||||||
struct tp_frame_
|
|
||||||
.codes rd 1
|
|
||||||
.cur rd 1
|
|
||||||
.jump rd 1
|
|
||||||
.regs rd 1
|
|
||||||
.ret_dest rd 1
|
|
||||||
.fname rb sizeof.tp_obj
|
|
||||||
.name rb sizeof.tp_obj
|
|
||||||
.line rb sizeof.tp_obj
|
|
||||||
.globals rb sizeof.tp_obj
|
|
||||||
.lineno rd 1
|
|
||||||
.cregs rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
; TinyPy VM
|
|
||||||
TP_FRAMES equ 256
|
|
||||||
struct tp_vm
|
|
||||||
builtins rb sizeof.tp_obj
|
|
||||||
modules rb sizeof.tp_obj
|
|
||||||
frames rb TP_FRAMES*sizeof.tp_frame_
|
|
||||||
_params rb sizeof.tp_obj
|
|
||||||
params rb sizeof.tp_obj
|
|
||||||
_regs rb sizeof.tp_obj
|
|
||||||
regs rq 1
|
|
||||||
root rb sizeof.tp_obj
|
|
||||||
jmp_buf rd 1
|
|
||||||
jump rd 1
|
|
||||||
ex rb sizeof.tp_obj
|
|
||||||
chars rb 512
|
|
||||||
cur rd 1
|
|
||||||
white rb sizeof._tp_list
|
|
||||||
grey rb sizeof._tp_list
|
|
||||||
black rb sizeof._tp_list
|
|
||||||
strings rb sizeof._tp_dict
|
|
||||||
steps rd 1
|
|
||||||
ends
|
|
||||||
|
|
||||||
macro push_tp_none
|
|
||||||
{
|
|
||||||
local .push_more
|
|
||||||
mov ecx, 4
|
|
||||||
.push_more:
|
|
||||||
push 0
|
|
||||||
loop .push_more
|
|
||||||
}
|
|
||||||
|
|
||||||
macro push_tp_obj obj
|
|
||||||
{
|
|
||||||
local .push_more
|
|
||||||
mov ebx, obj + 12
|
|
||||||
mov ecx, 4
|
|
||||||
.push_more:
|
|
||||||
push dword[ebx]
|
|
||||||
sub ebx, 4
|
|
||||||
loop .push_more
|
|
||||||
}
|
|
||||||
|
|
||||||
macro push_tp_obj_at_reg reg
|
|
||||||
{
|
|
||||||
local .push_more
|
|
||||||
add reg, 12
|
|
||||||
mov ecx, 4
|
|
||||||
.push_more:
|
|
||||||
push dword[reg]
|
|
||||||
sub reg, 4
|
|
||||||
loop .push_more
|
|
||||||
}
|
|
@ -1 +0,0 @@
|
|||||||
#include "../modules/kolibri/fs.c"
|
|
@ -1 +0,0 @@
|
|||||||
#include "../modules/kolibri/init.c"
|
|
@ -10,6 +10,7 @@ def onbtn():
|
|||||||
print("Button pressed")
|
print("Button pressed")
|
||||||
|
|
||||||
if __name__=="__main__":
|
if __name__=="__main__":
|
||||||
|
kolibri.debug_print("Debug test line\n")
|
||||||
w = kolibri.window(10,10,400, 400, False)
|
w = kolibri.window(10,10,400, 400, False)
|
||||||
w.on_show = onshow
|
w.on_show = onshow
|
||||||
w.on_key = onkey
|
w.on_key = onkey
|
||||||
|
@ -2,11 +2,10 @@
|
|||||||
/* INCLUDE */
|
/* INCLUDE */
|
||||||
const char header[]="TinyPy for kolibriOS";
|
const char header[]="TinyPy for kolibriOS";
|
||||||
|
|
||||||
extern void (*kolibri_dbg_init)(tp_vm *tp) __attribute__((__stdcall__));
|
//extern void kolibri_dbg_init(tp_vm *tp); //__attribute__((__stdcall__));
|
||||||
|
|
||||||
void main(int argc, const char *argv[]) {
|
void main(int argc, const char *argv[]) {
|
||||||
tp_vm *tp = tp_init(argc, argv);
|
tp_vm *tp = tp_init(argc, argv);
|
||||||
// kolibri_dbg_init(tp);
|
|
||||||
kolibri_init(tp);
|
kolibri_init(tp);
|
||||||
CONSOLE_INIT(header);
|
CONSOLE_INIT(header);
|
||||||
/* INIT */
|
/* INIT */
|
||||||
|
Loading…
Reference in New Issue
Block a user