forked from KolibriOS/kolibrios
gfx-revertion bugs liced
git-svn-id: svn://kolibrios.org@1929 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
7413c9cd9d
commit
883ade9e49
@ -206,8 +206,8 @@ FDD_BUFF equ (OS_BASE+0x000D000)
|
|||||||
;unused ? only one reference
|
;unused ? only one reference
|
||||||
;ENABLE_TASKSWITCH equ (OS_BASE+0x000E000)
|
;ENABLE_TASKSWITCH equ (OS_BASE+0x000E000)
|
||||||
|
|
||||||
;PUTPIXEL equ (OS_BASE+0x000E020)
|
PUTPIXEL equ (OS_BASE+0x000E020)
|
||||||
;GETPIXEL equ (OS_BASE+0x000E024)
|
GETPIXEL equ (OS_BASE+0x000E024)
|
||||||
|
|
||||||
;unused ? only one reference
|
;unused ? only one reference
|
||||||
; BANK_SWITCH equ (OS_BASE+0x000E030) ; VESA 1.2 - not used
|
; BANK_SWITCH equ (OS_BASE+0x000E030) ; VESA 1.2 - not used
|
||||||
|
@ -333,8 +333,8 @@ img_screen_x rd 1
|
|||||||
img_screen_y rd 1
|
img_screen_y rd 1
|
||||||
|
|
||||||
align 64
|
align 64
|
||||||
_WinMapWidth rd 1
|
;_WinMapWidth rd 1
|
||||||
_WinMapHeight rd 1
|
;_WinMapHeight rd 1
|
||||||
_WinMapAddress rd 1
|
_WinMapAddress rd 1
|
||||||
_WinMapSize rd 1
|
_WinMapSize rd 1
|
||||||
|
|
||||||
@ -413,9 +413,9 @@ MouseTickCounter rd 1
|
|||||||
|
|
||||||
;* end code - Mario79
|
;* end code - Mario79
|
||||||
|
|
||||||
;img_background rd 1
|
img_background rd 1
|
||||||
;mem_BACKGROUND rd 1
|
mem_BACKGROUND rd 1
|
||||||
;static_background_data rd 1
|
static_background_data rd 1
|
||||||
|
|
||||||
cache_ide0:
|
cache_ide0:
|
||||||
cache_ide0_pointer rd 1
|
cache_ide0_pointer rd 1
|
||||||
|
@ -71,14 +71,14 @@ dtext: ; Text String Output (rw by Johnny_B[john@kolibrios.org])
|
|||||||
shr dl, 1
|
shr dl, 1
|
||||||
jz .pixloop1end
|
jz .pixloop1end
|
||||||
jnc .nopix
|
jnc .nopix
|
||||||
call _putpixel
|
call [putpixel]
|
||||||
jmp .pixloop1cont
|
jmp .pixloop1cont
|
||||||
.nopix:
|
.nopix:
|
||||||
test ecx, 0x40000000
|
test ecx, 0x40000000
|
||||||
jz .pixloop1cont
|
jz .pixloop1cont
|
||||||
push ecx
|
push ecx
|
||||||
mov ecx, [esp+4+20h+20h] ; original eax?
|
mov ecx, [esp+4+20h+20h] ; original eax?
|
||||||
call _putpixel
|
call [putpixel]
|
||||||
pop ecx
|
pop ecx
|
||||||
.pixloop1cont:
|
.pixloop1cont:
|
||||||
inc eax
|
inc eax
|
||||||
@ -103,14 +103,14 @@ dtext: ; Text String Output (rw by Johnny_B[john@kolibrios.org])
|
|||||||
.pixloop2:
|
.pixloop2:
|
||||||
shr dl, 1
|
shr dl, 1
|
||||||
jnc .nopix2
|
jnc .nopix2
|
||||||
call _putpixel
|
call [putpixel]
|
||||||
jmp .pixloop2cont
|
jmp .pixloop2cont
|
||||||
.nopix2:
|
.nopix2:
|
||||||
test ecx, 0x40000000
|
test ecx, 0x40000000
|
||||||
jz .pixloop2cont
|
jz .pixloop2cont
|
||||||
push ecx
|
push ecx
|
||||||
mov ecx, [esp+12+20h+20h]
|
mov ecx, [esp+12+20h+20h]
|
||||||
call _putpixel
|
call [putpixel]
|
||||||
pop ecx
|
pop ecx
|
||||||
.pixloop2cont:
|
.pixloop2cont:
|
||||||
inc eax
|
inc eax
|
||||||
|
@ -378,11 +378,9 @@ mouse._.move_handler: ;////////////////////////////////////////////////////////
|
|||||||
|
|
||||||
mov eax, [mouse.state.pos.x]
|
mov eax, [mouse.state.pos.x]
|
||||||
sub eax, [mouse.active_sys_window.delta.x]
|
sub eax, [mouse.active_sys_window.delta.x]
|
||||||
and al, 0xFC ; <<<<<<<<<<<<<<<<<<<
|
|
||||||
mov [mouse.active_sys_window.new_box.left], eax
|
mov [mouse.active_sys_window.new_box.left], eax
|
||||||
mov eax, [mouse.state.pos.y]
|
mov eax, [mouse.state.pos.y]
|
||||||
sub eax, [mouse.active_sys_window.delta.y]
|
sub eax, [mouse.active_sys_window.delta.y]
|
||||||
and al, 0xFE ; <<<<<<<<<<<<<<<<<<<
|
|
||||||
mov [mouse.active_sys_window.new_box.top], eax
|
mov [mouse.active_sys_window.new_box.top], eax
|
||||||
|
|
||||||
mov eax, [mouse.active_sys_window.new_box.left]
|
mov eax, [mouse.active_sys_window.new_box.left]
|
||||||
@ -413,7 +411,6 @@ mouse._.move_handler: ;////////////////////////////////////////////////////////
|
|||||||
|
|
||||||
mov eax, [mouse.state.pos.x]
|
mov eax, [mouse.state.pos.x]
|
||||||
sub eax, [mouse.active_sys_window.delta.x]
|
sub eax, [mouse.active_sys_window.delta.x]
|
||||||
and al, 0xFC ; <<<<<<<<<<<<<<<<<<<
|
|
||||||
mov [mouse.active_sys_window.new_box.left], eax
|
mov [mouse.active_sys_window.new_box.left], eax
|
||||||
sub eax, [mouse.active_sys_window.old_box.left]
|
sub eax, [mouse.active_sys_window.old_box.left]
|
||||||
sub [mouse.active_sys_window.new_box.width], eax
|
sub [mouse.active_sys_window.new_box.width], eax
|
||||||
@ -437,7 +434,6 @@ mouse._.move_handler: ;////////////////////////////////////////////////////////
|
|||||||
mov eax, [mouse.state.pos.y]
|
mov eax, [mouse.state.pos.y]
|
||||||
add eax, [mouse.active_sys_window.delta.y]
|
add eax, [mouse.active_sys_window.delta.y]
|
||||||
sub eax, [mouse.active_sys_window.old_box.top]
|
sub eax, [mouse.active_sys_window.old_box.top]
|
||||||
and al, 0xFC ; <<<<<<<<<<<<<<<<<<<
|
|
||||||
mov [mouse.active_sys_window.new_box.height], eax
|
mov [mouse.active_sys_window.new_box.height], eax
|
||||||
|
|
||||||
push eax
|
push eax
|
||||||
@ -470,7 +466,6 @@ mouse._.move_handler: ;////////////////////////////////////////////////////////
|
|||||||
mov eax, [mouse.state.pos.x]
|
mov eax, [mouse.state.pos.x]
|
||||||
add eax, [mouse.active_sys_window.delta.x]
|
add eax, [mouse.active_sys_window.delta.x]
|
||||||
sub eax, [mouse.active_sys_window.old_box.left]
|
sub eax, [mouse.active_sys_window.old_box.left]
|
||||||
and al, 0xFC ; <<<<<<<<<<<<<<<<<<<
|
|
||||||
mov [mouse.active_sys_window.new_box.width], eax
|
mov [mouse.active_sys_window.new_box.width], eax
|
||||||
|
|
||||||
mov eax, [mouse.active_sys_window.new_box.width]
|
mov eax, [mouse.active_sys_window.new_box.width]
|
||||||
@ -518,13 +513,11 @@ mouse._.find_sys_window_under_cursor: ;////////////////////////////////////////
|
|||||||
;< esi = process slot
|
;< esi = process slot
|
||||||
;< edi = pointer to WDATA struct
|
;< edi = pointer to WDATA struct
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
mov esi, [mouse.state.pos.y]
|
mov esi, [Screen_Max_X]
|
||||||
mov edi, [mouse.state.pos.x]
|
inc esi
|
||||||
shr esi, 1
|
imul esi, [mouse.state.pos.y]
|
||||||
shr edi, 2
|
add esi, [_WinMapAddress]
|
||||||
imul esi, [_WinMapWidth]
|
add esi, [mouse.state.pos.x]
|
||||||
add edi, [_WinMapAddress]
|
|
||||||
add esi, edi
|
|
||||||
movzx esi, byte[esi]
|
movzx esi, byte[esi]
|
||||||
mov edi, esi
|
mov edi, esi
|
||||||
shl edi, 5
|
shl edi, 5
|
||||||
|
@ -12,7 +12,7 @@ $Revision$
|
|||||||
;///// public functions ///////////////////////////////////////////////////////
|
;///// public functions ///////////////////////////////////////////////////////
|
||||||
;==============================================================================
|
;==============================================================================
|
||||||
|
|
||||||
window.BORDER_SIZE = 4
|
window.BORDER_SIZE = 5
|
||||||
|
|
||||||
macro FuncTable name, table_name, [label]
|
macro FuncTable name, table_name, [label]
|
||||||
{
|
{
|
||||||
@ -328,19 +328,15 @@ syscall_move_window: ;///// system function 67 ////////////////////////////////
|
|||||||
cmp ebx, -1
|
cmp ebx, -1
|
||||||
jne @f
|
jne @f
|
||||||
mov ebx, [edi + WDATA.box.left]
|
mov ebx, [edi + WDATA.box.left]
|
||||||
and bl, 0xFC
|
|
||||||
@@: cmp ecx, -1
|
@@: cmp ecx, -1
|
||||||
jne @f
|
jne @f
|
||||||
mov ecx, [edi + WDATA.box.top]
|
mov ecx, [edi + WDATA.box.top]
|
||||||
and cl, 0xFE
|
|
||||||
@@: cmp edx, -1
|
@@: cmp edx, -1
|
||||||
jne @f
|
jne @f
|
||||||
mov edx, [edi + WDATA.box.width]
|
mov edx, [edi + WDATA.box.width]
|
||||||
; and dl, 0xFC
|
|
||||||
@@: cmp esi, -1
|
@@: cmp esi, -1
|
||||||
jne @f
|
jne @f
|
||||||
mov esi, [edi + WDATA.box.height]
|
mov esi, [edi + WDATA.box.height]
|
||||||
; and esi, 0xFFFFFFFE
|
|
||||||
|
|
||||||
@@: push esi edx ecx ebx
|
@@: push esi edx ecx ebx
|
||||||
mov eax, esp
|
mov eax, esp
|
||||||
@ -515,10 +511,8 @@ repos_windows: ;///////////////////////////////////////////////////////////////
|
|||||||
mov eax, [edi + WDATA.box.width]
|
mov eax, [edi + WDATA.box.width]
|
||||||
sub eax, ebx
|
sub eax, ebx
|
||||||
jle @f
|
jle @f
|
||||||
; and bl, 0xFC ; <<<<<<<
|
|
||||||
mov [edi + WDATA.box.width], ebx
|
mov [edi + WDATA.box.width], ebx
|
||||||
@@: sub ebx, [edi + WDATA.box.width]
|
@@: sub ebx, [edi + WDATA.box.width]
|
||||||
; and bl, 0xFC ; <<<<<<<
|
|
||||||
mov [edi + WDATA.box.left], ebx
|
mov [edi + WDATA.box.left], ebx
|
||||||
|
|
||||||
.fix_vertical:
|
.fix_vertical:
|
||||||
@ -530,10 +524,8 @@ repos_windows: ;///////////////////////////////////////////////////////////////
|
|||||||
mov eax, [edi + WDATA.box.height]
|
mov eax, [edi + WDATA.box.height]
|
||||||
sub eax, ebx
|
sub eax, ebx
|
||||||
jle @f
|
jle @f
|
||||||
; and bl, 0xFE ; <<<<<<<
|
|
||||||
mov [edi + WDATA.box.height], ebx
|
mov [edi + WDATA.box.height], ebx
|
||||||
@@: sub ebx, [edi + WDATA.box.height]
|
@@: sub ebx, [edi + WDATA.box.height]
|
||||||
; and bl, 0xFE ; <<<<<<<
|
|
||||||
mov [edi + WDATA.box.top], ebx
|
mov [edi + WDATA.box.top], ebx
|
||||||
jmp .fix_client_box
|
jmp .fix_client_box
|
||||||
|
|
||||||
@ -556,7 +548,7 @@ repos_windows: ;///////////////////////////////////////////////////////////////
|
|||||||
|
|
||||||
add edi, WDATA.sizeof
|
add edi, WDATA.sizeof
|
||||||
dec ecx
|
dec ecx
|
||||||
jne .next_window ; <<<<<<<<<<<
|
jne .next_window
|
||||||
|
|
||||||
.exit:
|
.exit:
|
||||||
ret
|
ret
|
||||||
@ -565,23 +557,8 @@ align 4
|
|||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
sys_window_mouse: ;////////////////////////////////////////////////////////////
|
sys_window_mouse: ;////////////////////////////////////////////////////////////
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
;? <description>
|
;? <description> (not used)
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
; NOTE: commented out since doesn't provide necessary functionality
|
|
||||||
; anyway, to be reworked
|
|
||||||
; push eax
|
|
||||||
;
|
|
||||||
; mov eax, [timer_ticks]
|
|
||||||
; cmp [new_window_starting], eax
|
|
||||||
; jb .exit
|
|
||||||
;
|
|
||||||
; mov byte[MOUSE_BACKGROUND], 0
|
|
||||||
; mov byte[DONT_DRAW_MOUSE], 0
|
|
||||||
;
|
|
||||||
; mov [new_window_starting], eax
|
|
||||||
;
|
|
||||||
; .exit:
|
|
||||||
; pop eax
|
|
||||||
ret
|
ret
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
@ -666,7 +643,6 @@ drawwindow_I_caption: ;////////////////////////////////////////////////////////
|
|||||||
add ebx, edx
|
add ebx, edx
|
||||||
mov eax, [esi + WDATA.box.left]
|
mov eax, [esi + WDATA.box.left]
|
||||||
inc eax
|
inc eax
|
||||||
|
|
||||||
shl eax, 16
|
shl eax, 16
|
||||||
add eax, [esi + WDATA.box.left]
|
add eax, [esi + WDATA.box.left]
|
||||||
add eax, [esi + WDATA.box.width]
|
add eax, [esi + WDATA.box.width]
|
||||||
@ -1209,11 +1185,6 @@ iglobal
|
|||||||
5, ? ;type 4 {set by skin}
|
5, ? ;type 4 {set by skin}
|
||||||
endg
|
endg
|
||||||
|
|
||||||
;uglobal
|
|
||||||
; NOTE: commented out since doesn't provide necessary functionality anyway,
|
|
||||||
; to be reworked
|
|
||||||
; new_window_starting dd ?
|
|
||||||
;endg
|
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
@ -1444,21 +1415,13 @@ window._.sys_set_window: ;/////////////////////////////////////////////////////
|
|||||||
jnz .set_client_box
|
jnz .set_client_box
|
||||||
or [edi + WDATA.fl_wdrawn], 1
|
or [edi + WDATA.fl_wdrawn], 1
|
||||||
|
|
||||||
; NOTE: commented out since doesn't provide necessary functionality
|
; performing initial window definition
|
||||||
; anyway, to be reworked
|
|
||||||
; mov eax, [timer_ticks] ; [0xfdf0]
|
|
||||||
; add eax, 100
|
|
||||||
; mov [new_window_starting], eax
|
|
||||||
|
|
||||||
; no it wasn't, performing initial window definition
|
|
||||||
movzx eax, bx
|
movzx eax, bx
|
||||||
mov [edi + WDATA.box.width], eax
|
mov [edi + WDATA.box.width], eax
|
||||||
movzx eax, cx
|
movzx eax, cx
|
||||||
mov [edi + WDATA.box.height], eax
|
mov [edi + WDATA.box.height], eax
|
||||||
sar ebx, 16
|
sar ebx, 16
|
||||||
; and bl, 0xFC ; <<<<<<<<
|
|
||||||
sar ecx, 16
|
sar ecx, 16
|
||||||
; and cl, 0xFE ; <<<<<<<<
|
|
||||||
mov [edi + WDATA.box.left], ebx
|
mov [edi + WDATA.box.left], ebx
|
||||||
mov [edi + WDATA.box.top], ecx
|
mov [edi + WDATA.box.top], ecx
|
||||||
|
|
||||||
@ -1642,15 +1605,6 @@ window._.set_screen: ;/////////////////////////////////////////////////////////
|
|||||||
;> edx = bottom
|
;> edx = bottom
|
||||||
;> esi = process number
|
;> esi = process number
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
virtual at esp
|
|
||||||
ff_x dd ?
|
|
||||||
ff_y dd ?
|
|
||||||
ff_width dd ?
|
|
||||||
ff_xsz dd ?
|
|
||||||
ff_ysz dd ?
|
|
||||||
ff_map dd ?
|
|
||||||
ff_scale dd ?
|
|
||||||
end virtual
|
|
||||||
|
|
||||||
pushad
|
pushad
|
||||||
|
|
||||||
@ -1675,144 +1629,40 @@ end virtual
|
|||||||
sub edx, ebx
|
sub edx, ebx
|
||||||
inc ecx
|
inc ecx
|
||||||
inc edx
|
inc edx
|
||||||
shr ecx, 2 ; 1 tile = 4 pix
|
|
||||||
shr edx, 1 ; 1 tile = 2 lines
|
|
||||||
|
|
||||||
; get WinMap start
|
; get WinMap start
|
||||||
push esi
|
push esi
|
||||||
mov edi, [_WinMapWidth]
|
mov edi, [Screen_Max_X]
|
||||||
mov esi, edi
|
mov esi, edi
|
||||||
shr ebx, 1
|
|
||||||
imul edi, ebx
|
imul edi, ebx
|
||||||
shr eax, 2
|
|
||||||
add edi, eax
|
add edi, eax
|
||||||
add edi, [_WinMapAddress]
|
add edi, [_WinMapAddress]
|
||||||
pop eax ; al = process#
|
pop eax ; al = process#
|
||||||
; mov ah, al
|
mov ah, al
|
||||||
; push ax
|
push ax
|
||||||
; shl eax, 16
|
shl eax, 16
|
||||||
; pop ax ; eax = 4 dup PROCESS_NUM
|
pop ax ; eax = 4 dup PROCESS_NUM
|
||||||
|
|
||||||
sub esi, ecx ; map line increment (bytes)
|
|
||||||
mov ebx, ecx ; map line width
|
|
||||||
.next_line:
|
.next_line:
|
||||||
; shr ecx, 2 ; 1dword = 4 tiles
|
push ecx
|
||||||
; rep stosd ; filling the screen map
|
shr ecx, 2
|
||||||
; mov ecx, ebx
|
rep stosd ; filling the screen map
|
||||||
; and ecx, 3 ; 0 to 3 tiles remaining
|
mov ecx,[esp]
|
||||||
|
and ecx, 3
|
||||||
rep stosb
|
rep stosb
|
||||||
mov ecx, ebx
|
pop ecx
|
||||||
add edi, esi
|
add edi, esi
|
||||||
|
sub edi, ecx
|
||||||
dec edx
|
dec edx
|
||||||
jnz .next_line
|
jnz .next_line
|
||||||
jmp .exit
|
; jmp .exit
|
||||||
|
|
||||||
.shaped_window:
|
.shaped_window:
|
||||||
; for (y=0; y <= y_size; y++)
|
; (not supported any more)
|
||||||
; for (x=0; x <= x_size; x++)
|
|
||||||
; if (shape[coord(x,y,scale)]==1)
|
|
||||||
; set_pixel(x, y, process_number);
|
|
||||||
|
|
||||||
sub ecx, eax
|
|
||||||
sub edx, ebx
|
|
||||||
inc ecx
|
|
||||||
inc edx
|
|
||||||
|
|
||||||
push [edi + APPDATA.wnd_shape_scale] ; push scale first -> for loop
|
|
||||||
|
|
||||||
push ebx
|
|
||||||
push eax
|
|
||||||
mov ebp, eax
|
|
||||||
shr ebp, 2
|
|
||||||
add ebp, [_WinMapAddress]
|
|
||||||
mov eax, [_WinMapWidth]
|
|
||||||
shr ebx, 1
|
|
||||||
imul eax, ebx
|
|
||||||
add ebp, eax ; ebp = map origin
|
|
||||||
|
|
||||||
mov edi, [edi + APPDATA.wnd_shape]
|
|
||||||
pop eax
|
|
||||||
pop ebx
|
|
||||||
|
|
||||||
push ebp ; for loop - screen map origin
|
|
||||||
|
|
||||||
; eax = x_start
|
|
||||||
; ebx = y_start
|
|
||||||
; ecx = x_size
|
|
||||||
; edx = y_size
|
|
||||||
; esi = process_number
|
|
||||||
; edi = &shape
|
|
||||||
; ebp = [ff_map]
|
|
||||||
; [scale]
|
|
||||||
|
|
||||||
push edx ecx ; for loop - x,y size
|
|
||||||
mov ecx, esi
|
|
||||||
shl ecx, 5
|
|
||||||
mov edx, [window_data + ecx + WDATA.box.top]
|
|
||||||
push [window_data + ecx + WDATA.box.width] ; for loop - width
|
|
||||||
mov ecx, [window_data + ecx + WDATA.box.left]
|
|
||||||
sub ebx, edx
|
|
||||||
sub eax, ecx
|
|
||||||
push ebx eax ; for loop - x,y
|
|
||||||
|
|
||||||
add [ff_xsz], eax
|
|
||||||
add [ff_ysz], ebx
|
|
||||||
|
|
||||||
mov ebx, [ff_y]
|
|
||||||
|
|
||||||
.ff_new_y:
|
|
||||||
mov edx, [ff_x]
|
|
||||||
|
|
||||||
.ff_new_x:
|
|
||||||
; -- body --
|
|
||||||
mov ecx, [ff_scale]
|
|
||||||
mov eax, [ff_width]
|
|
||||||
inc eax
|
|
||||||
shr eax, cl
|
|
||||||
push ebx edx
|
|
||||||
shr ebx, cl
|
|
||||||
shr edx, cl
|
|
||||||
imul eax, ebx
|
|
||||||
add eax, edx
|
|
||||||
pop edx ebx
|
|
||||||
add eax, edi
|
|
||||||
call .read_byte ; al= shaped window pix-mask at a given point
|
|
||||||
test al,al
|
|
||||||
jz @f
|
|
||||||
mov eax, esi
|
|
||||||
mov [ebp], al ; a tile belongs to the window if the 1st pixel's mask = 1
|
|
||||||
; -- end body --
|
|
||||||
@@:
|
|
||||||
add edx, 4
|
|
||||||
inc ebp
|
|
||||||
cmp edx, [ff_xsz]
|
|
||||||
jb .ff_new_x
|
|
||||||
|
|
||||||
inc ebx
|
|
||||||
inc ebx
|
|
||||||
cmp ebx, [ff_ysz]
|
|
||||||
jnb @f
|
|
||||||
mov ebp, [ff_map]
|
|
||||||
add ebp, [_WinMapWidth] ; even line: jump to next map row
|
|
||||||
mov [ff_map], ebp
|
|
||||||
jmp .ff_new_y
|
|
||||||
@@:
|
|
||||||
add esp, 7*4
|
|
||||||
.exit:
|
.exit:
|
||||||
popad
|
popad
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.read_byte:
|
|
||||||
; eax - buffer address
|
|
||||||
; esi - slot#
|
|
||||||
push eax ecx edx esi
|
|
||||||
xchg eax, esi
|
|
||||||
lea ecx, [esp + 12] ; buffer addr = stacked [eax] to return
|
|
||||||
mov edx, 1 ; buffer size
|
|
||||||
call read_process_memory ; (core/taskman.inc) returns #bytes read
|
|
||||||
pop esi edx ecx eax ; eax = PID
|
|
||||||
ret
|
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
window._.window_activate: ;////////////////////////////////////////////////////
|
window._.window_activate: ;////////////////////////////////////////////////////
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
$Revision$
|
$Revision$
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; check mouse
|
; check mouse
|
||||||
;
|
;
|
||||||
;
|
;
|
||||||
@ -33,8 +32,6 @@ mouse_speed_factor: dd 3
|
|||||||
mouse_timer_ticks dd 0
|
mouse_timer_ticks dd 0
|
||||||
endg
|
endg
|
||||||
|
|
||||||
;include 'm_com.inc'
|
|
||||||
|
|
||||||
|
|
||||||
draw_mouse_under:
|
draw_mouse_under:
|
||||||
; return old picture
|
; return old picture
|
||||||
@ -97,12 +94,9 @@ save_draw_mouse:
|
|||||||
push eax
|
push eax
|
||||||
push ebx
|
push ebx
|
||||||
|
|
||||||
mov ecx, ebx ; <<<<
|
mov ecx, [Screen_Max_X]
|
||||||
shr ecx, 1
|
inc ecx
|
||||||
imul ecx, [_WinMapWidth]
|
mul ecx
|
||||||
shr eax, 1
|
|
||||||
shr eax, 1
|
|
||||||
add eax, ecx
|
|
||||||
add eax, [_WinMapAddress]
|
add eax, [_WinMapAddress]
|
||||||
movzx edx, byte [ebx+eax]
|
movzx edx, byte [ebx+eax]
|
||||||
shl edx, 8
|
shl edx, 8
|
||||||
@ -277,11 +271,9 @@ __sys_disable_mouse:
|
|||||||
add edx,window_data
|
add edx,window_data
|
||||||
movzx eax, word [MOUSE_X]
|
movzx eax, word [MOUSE_X]
|
||||||
movzx ebx, word [MOUSE_Y]
|
movzx ebx, word [MOUSE_Y]
|
||||||
mov ecx, ebx ; <<<<
|
mov ecx,[Screen_Max_X]
|
||||||
shr ecx, 1
|
inc ecx
|
||||||
imul ecx, [_WinMapWidth]
|
imul ecx,ebx
|
||||||
shr eax, 1
|
|
||||||
shr eax, 1
|
|
||||||
add ecx,eax
|
add ecx,eax
|
||||||
add ecx, [_WinMapAddress]
|
add ecx, [_WinMapAddress]
|
||||||
mov eax, [CURRENT_TASK]
|
mov eax, [CURRENT_TASK]
|
||||||
|
@ -320,10 +320,10 @@ high_code:
|
|||||||
; -----------------------------------------
|
; -----------------------------------------
|
||||||
mov al, [BOOT_VAR+0x901F] ; DMA access
|
mov al, [BOOT_VAR+0x901F] ; DMA access
|
||||||
mov [allow_dma_access], al
|
mov [allow_dma_access], al
|
||||||
mov eax, 32 ; <<<<<<<<< bpp
|
mov eax, 32 ; bpp
|
||||||
mov [ScreenBPP],al
|
mov [ScreenBPP],al
|
||||||
|
|
||||||
mov [_display.bpp], eax
|
mov [_display.bpp], eax
|
||||||
|
|
||||||
mov [_display.vrefresh], 60
|
mov [_display.vrefresh], 60
|
||||||
mov [_display.disable_mouse], __sys_disable_mouse
|
mov [_display.disable_mouse], __sys_disable_mouse
|
||||||
|
|
||||||
@ -332,9 +332,6 @@ high_code:
|
|||||||
dec eax
|
dec eax
|
||||||
mov [Screen_Max_X],eax
|
mov [Screen_Max_X],eax
|
||||||
mov [screen_workarea.right],eax
|
mov [screen_workarea.right],eax
|
||||||
inc eax
|
|
||||||
shr eax, 2
|
|
||||||
mov [_WinMapWidth], eax ; 1 tyle = 4 pixels
|
|
||||||
movzx eax,word [BOOT_VAR+0x900C] ; Y max
|
movzx eax,word [BOOT_VAR+0x900C] ; Y max
|
||||||
mov [_display.height], eax
|
mov [_display.height], eax
|
||||||
dec eax
|
dec eax
|
||||||
@ -342,15 +339,13 @@ high_code:
|
|||||||
mov [screen_workarea.bottom],eax
|
mov [screen_workarea.bottom],eax
|
||||||
movzx eax,word [BOOT_VAR+0x9008] ; screen mode
|
movzx eax,word [BOOT_VAR+0x9008] ; screen mode
|
||||||
mov [SCR_MODE],eax
|
mov [SCR_MODE],eax
|
||||||
; mov eax,[BOOT_VAR+0x9014] ; Vesa 1.2 bnk sw add == not used any more
|
|
||||||
; mov [BANK_SWITCH],eax
|
|
||||||
movzx eax, word[BOOT_VAR+0x9001] ; for other modes
|
movzx eax, word[BOOT_VAR+0x9001] ; for other modes
|
||||||
mov [BytesPerScanLine],ax
|
mov [BytesPerScanLine],ax
|
||||||
mov [_display.pitch], eax
|
mov [_display.pitch], eax
|
||||||
@@:
|
|
||||||
mov eax, [_display.height]
|
mov eax, [_display.width]
|
||||||
shr eax, 1
|
mul [_display.height]
|
||||||
mul [_WinMapWidth]
|
|
||||||
mov [_WinMapSize], eax
|
mov [_WinMapSize], eax
|
||||||
|
|
||||||
mov esi, BOOT_VAR+0x9080
|
mov esi, BOOT_VAR+0x9080
|
||||||
@ -373,8 +368,8 @@ high_code:
|
|||||||
; === EGA, VGA & Vesa 1.2 modes not supported ===
|
; === EGA, VGA & Vesa 1.2 modes not supported ===
|
||||||
setvesa20:
|
setvesa20:
|
||||||
v20ga32:
|
v20ga32:
|
||||||
; mov [PUTPIXEL],dword put_pixel
|
mov [PUTPIXEL],dword __sys_putpixel
|
||||||
; mov [GETPIXEL],dword get_pixel
|
mov [GETPIXEL],dword get_pixel
|
||||||
|
|
||||||
; -------- Fast System Call init ----------
|
; -------- Fast System Call init ----------
|
||||||
.SEnP:
|
.SEnP:
|
||||||
@ -411,7 +406,6 @@ v20ga32:
|
|||||||
; LOAD IDT
|
; LOAD IDT
|
||||||
|
|
||||||
call build_interrupt_table ;lidt is executed
|
call build_interrupt_table ;lidt is executed
|
||||||
;lidt [idtreg]
|
|
||||||
|
|
||||||
call init_kernel_heap
|
call init_kernel_heap
|
||||||
stdcall kernel_alloc, RING0_STACK_SIZE+512
|
stdcall kernel_alloc, RING0_STACK_SIZE+512
|
||||||
@ -512,8 +506,8 @@ v20ga32:
|
|||||||
mov [BgrDrawMode],eax
|
mov [BgrDrawMode],eax
|
||||||
mov [BgrDataWidth],eax
|
mov [BgrDataWidth],eax
|
||||||
mov [BgrDataHeight],eax
|
mov [BgrDataHeight],eax
|
||||||
; mov [mem_BACKGROUND], 4
|
mov [mem_BACKGROUND], 4
|
||||||
; mov [img_background], static_background_data
|
mov [img_background], static_background_data
|
||||||
|
|
||||||
mov [SLOT_BASE + 256 + APPDATA.dir_table], sys_pgdir - OS_BASE
|
mov [SLOT_BASE + 256 + APPDATA.dir_table], sys_pgdir - OS_BASE
|
||||||
|
|
||||||
@ -632,7 +626,7 @@ end if
|
|||||||
|
|
||||||
mov esi,boot_bgr
|
mov esi,boot_bgr
|
||||||
call boot_log
|
call boot_log
|
||||||
call _init_background ;graph32.inc ?
|
call init_background ;
|
||||||
call calculatebackground
|
call calculatebackground
|
||||||
|
|
||||||
; SET UP OS TASK
|
; SET UP OS TASK
|
||||||
@ -686,137 +680,6 @@ end if
|
|||||||
mov [SLOT_BASE+APPDATA.cursor],eax
|
mov [SLOT_BASE+APPDATA.cursor],eax
|
||||||
mov [SLOT_BASE+APPDATA.cursor+256],eax
|
mov [SLOT_BASE+APPDATA.cursor+256],eax
|
||||||
|
|
||||||
; <<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>
|
|
||||||
|
|
||||||
; mov esi, img_test_struct_8
|
|
||||||
; mov edi, 151
|
|
||||||
|
|
||||||
; mov ebp, edi
|
|
||||||
; imul edi, [BytesPerScanLine]
|
|
||||||
; add edi, LFB_BASE + 32*4
|
|
||||||
; mov [img_lfb_origin], edi
|
|
||||||
; shr ebp, 1
|
|
||||||
; imul ebp, [_WinMapWidth]
|
|
||||||
; add ebp, 32/4
|
|
||||||
; add ebp, [_WinMapAddress]
|
|
||||||
; mov ecx, ebp
|
|
||||||
; add ecx, [_WinMapWidth]
|
|
||||||
; mov byte[ecx+1], 2
|
|
||||||
; mov ecx, 6
|
|
||||||
; mov [img_pix_y], ecx
|
|
||||||
; mov eax, 1
|
|
||||||
; mov [img_bytes_per_pix], eax
|
|
||||||
; mov ebx, 1
|
|
||||||
; bts ebx, 24
|
|
||||||
; mov eax, 8-1
|
|
||||||
; mov [img_pix_x], eax
|
|
||||||
; inc eax
|
|
||||||
; shr eax, 2
|
|
||||||
; mov [img_map_x], eax
|
|
||||||
; mov [img_draw_core_fn], draw_core_8bpp
|
|
||||||
; mov [img_draw_edge_fn], draw_edge_8bpp
|
|
||||||
; mov [img_buf_line_size], 9
|
|
||||||
; mov [img_palette], img_test_palette
|
|
||||||
|
|
||||||
; call draw_aligned_box
|
|
||||||
; add edi, 48
|
|
||||||
; mov edx, 8
|
|
||||||
; call draw_unaligned_edge
|
|
||||||
; mono
|
|
||||||
; bts ebx, 25
|
|
||||||
; add edi, [_WinMapWidth] ; = 1/16 of the screen width
|
|
||||||
; mov esi, img_test_struct_1
|
|
||||||
; mov [img_lfb_origin], edi
|
|
||||||
; mov ecx, 9
|
|
||||||
; mov [img_map_x], 4
|
|
||||||
; mov [img_bitoffset], 1
|
|
||||||
; mov [img_edgeoffset], 16
|
|
||||||
; mov [img_draw_core_fn], draw_core_1bpp
|
|
||||||
; mov [img_draw_edge_fn], draw_edge_1bpp
|
|
||||||
; mov [img_buf_line_size], 2
|
|
||||||
; mov [img_bytes_per_pix], 0
|
|
||||||
; call draw_aligned_box
|
|
||||||
; add edi, 48
|
|
||||||
; mov edx, 8
|
|
||||||
; call draw_unaligned_edge
|
|
||||||
; btr ebx, 25
|
|
||||||
; 32bpp
|
|
||||||
; add edi, [_WinMapWidth] ; = 1/16 of the screen width
|
|
||||||
; mov esi, img_test_struct_32
|
|
||||||
; mov [img_lfb_origin], edi
|
|
||||||
; mov ecx, 6
|
|
||||||
; mov [img_map_x], 2
|
|
||||||
; mov [img_draw_core_fn], draw_core_32bpp
|
|
||||||
; mov [img_draw_edge_fn], draw_edge_32bpp
|
|
||||||
; mov [img_buf_line_size], 32
|
|
||||||
; mov [img_bytes_per_pix], 4
|
|
||||||
; call draw_aligned_box
|
|
||||||
; add edi, 48
|
|
||||||
; mov edx, 8
|
|
||||||
; call draw_unaligned_edge
|
|
||||||
|
|
||||||
; 24bpp
|
|
||||||
; add edi, [_WinMapWidth] ; = 1/16 of the screen width
|
|
||||||
; mov esi, img_test_struct_24
|
|
||||||
; mov [img_lfb_origin], edi
|
|
||||||
; mov ecx, 7
|
|
||||||
; mov [img_map_x], 4
|
|
||||||
; mov [img_draw_core_fn], draw_core_24bpp
|
|
||||||
; mov [img_draw_edge_fn], draw_edge_24bpp
|
|
||||||
; mov [img_buf_line_size], 45
|
|
||||||
; mov [img_bytes_per_pix], 3
|
|
||||||
; call draw_aligned_box
|
|
||||||
; add edi, 80
|
|
||||||
; mov edx, 4
|
|
||||||
; call draw_unaligned_edge
|
|
||||||
|
|
||||||
; mov [TASK_BASE-twdw + WDATA.box.left], 0
|
|
||||||
; mov [TASK_BASE-twdw + WDATA.box.top], 0
|
|
||||||
; mov eax, [Screen_Max_X]
|
|
||||||
; mov [TASK_BASE-twdw + WDATA.box.width], eax
|
|
||||||
; mov eax, [Screen_Max_Y]
|
|
||||||
; mov [TASK_BASE-twdw + WDATA.box.height], eax
|
|
||||||
|
|
||||||
; mov ebx, img_test_struct_24
|
|
||||||
; mov ecx, 16*65536 + 7
|
|
||||||
; mov edx, 512*65536 + 400
|
|
||||||
|
|
||||||
; call _putimage
|
|
||||||
|
|
||||||
|
|
||||||
;-----------
|
|
||||||
; mov ebx, img_test_struct_32
|
|
||||||
; mov ecx, 6*65536 + 6
|
|
||||||
; mov edx, 32*65536 + 512
|
|
||||||
; mov esi, 32
|
|
||||||
; xor edi, edi
|
|
||||||
; mov ebp, edi
|
|
||||||
; call sys_putimage_palette.forced
|
|
||||||
|
|
||||||
; mov [img_palette], img_test_palette
|
|
||||||
; mov [img_bytes_per_pix], 0
|
|
||||||
; mov [img_buf_line_size], 0
|
|
||||||
; mov ebx, img_test_palette
|
|
||||||
; mov [img_draw_core_fn], draw_core_0bpp
|
|
||||||
; mov [img_draw_edge_fn], draw_edge_0bpp
|
|
||||||
; mov ecx, 20*65536 + 9
|
|
||||||
; mov edx, 513*65536 + 401
|
|
||||||
; call _putimage
|
|
||||||
|
|
||||||
; mov eax, 561
|
|
||||||
; mov ebx, 461
|
|
||||||
; mov ecx, 555
|
|
||||||
; mov edx, 333
|
|
||||||
; mov edi, 0xAA5533
|
|
||||||
; call _drawbar
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; jmp $
|
|
||||||
|
|
||||||
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; READ TSC / SECOND
|
; READ TSC / SECOND
|
||||||
|
|
||||||
@ -856,8 +719,6 @@ end if
|
|||||||
|
|
||||||
call set_variables
|
call set_variables
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; SET MOUSE
|
; SET MOUSE
|
||||||
|
|
||||||
;call detect_devices
|
;call detect_devices
|
||||||
@ -1023,7 +884,6 @@ osloop:
|
|||||||
call checkmisc
|
call checkmisc
|
||||||
call stack_handler
|
call stack_handler
|
||||||
call checkidle
|
call checkidle
|
||||||
; call check_fdd_motor_status
|
|
||||||
jmp osloop
|
jmp osloop
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
; ;
|
; ;
|
||||||
@ -1832,7 +1692,6 @@ sys_end:
|
|||||||
test eax, eax
|
test eax, eax
|
||||||
jz @F
|
jz @F
|
||||||
|
|
||||||
|
|
||||||
stdcall user_free, eax
|
stdcall user_free, eax
|
||||||
@@:
|
@@:
|
||||||
|
|
||||||
@ -2220,24 +2079,271 @@ bgrlock db 0
|
|||||||
endg
|
endg
|
||||||
|
|
||||||
;=============================== SysFn 15 ================================
|
;=============================== SysFn 15 ================================
|
||||||
; no background service supported so far ...
|
|
||||||
;===========================================
|
|
||||||
|
|
||||||
sys_background:
|
sys_background:
|
||||||
|
|
||||||
cmp ebx,6 ; subfns 1..5 do not return anything
|
cmp ebx,1 ; BACKGROUND SIZE
|
||||||
jb .exit
|
jnz nosb1
|
||||||
mov dword [esp+32], 0 ; subfns 6,7 return 0 as error
|
test ecx,ecx
|
||||||
|
; cmp ecx,0
|
||||||
|
jz sbgrr
|
||||||
|
test edx,edx
|
||||||
|
; cmp edx,0
|
||||||
|
jz sbgrr
|
||||||
|
@@:
|
||||||
|
;;Maxis use atomic bts for mutexes 4.4.2009
|
||||||
|
bts dword [bgrlock], 0
|
||||||
|
jnc @f
|
||||||
|
call change_task
|
||||||
|
jmp @b
|
||||||
|
@@:
|
||||||
|
mov [BgrDataWidth],ecx
|
||||||
|
mov [BgrDataHeight],edx
|
||||||
|
; mov [bgrchanged],1
|
||||||
|
|
||||||
|
pushad
|
||||||
|
; return memory for old background
|
||||||
|
mov eax, [img_background]
|
||||||
|
cmp eax, static_background_data
|
||||||
|
jz @f
|
||||||
|
stdcall kernel_free, eax
|
||||||
|
@@:
|
||||||
|
; calculate RAW size
|
||||||
|
xor eax,eax
|
||||||
|
inc eax
|
||||||
|
cmp [BgrDataWidth],eax
|
||||||
|
jae @f
|
||||||
|
mov [BgrDataWidth],eax
|
||||||
|
@@:
|
||||||
|
cmp [BgrDataHeight],eax
|
||||||
|
jae @f
|
||||||
|
mov [BgrDataHeight],eax
|
||||||
|
@@:
|
||||||
|
mov eax,[BgrDataWidth]
|
||||||
|
imul eax,[BgrDataHeight]
|
||||||
|
lea eax,[eax*3]
|
||||||
|
mov [mem_BACKGROUND],eax
|
||||||
|
; get memory for new background
|
||||||
|
stdcall kernel_alloc, eax
|
||||||
|
test eax, eax
|
||||||
|
jz .memfailed
|
||||||
|
mov [img_background], eax
|
||||||
|
jmp .exit
|
||||||
|
.memfailed:
|
||||||
|
; revert to static monotone data
|
||||||
|
mov [img_background], static_background_data
|
||||||
|
xor eax, eax
|
||||||
|
inc eax
|
||||||
|
mov [BgrDataWidth], eax
|
||||||
|
mov [BgrDataHeight], eax
|
||||||
|
mov [mem_BACKGROUND], 4
|
||||||
.exit:
|
.exit:
|
||||||
|
popad
|
||||||
|
mov [bgrlock], 0
|
||||||
|
|
||||||
|
sbgrr:
|
||||||
|
ret
|
||||||
|
|
||||||
|
nosb1:
|
||||||
|
|
||||||
|
cmp ebx,2 ; SET PIXEL
|
||||||
|
jnz nosb2
|
||||||
|
|
||||||
|
mov eax, [img_background]
|
||||||
|
test ecx, ecx
|
||||||
|
jz @f
|
||||||
|
cmp eax, static_background_data
|
||||||
|
|
||||||
|
jz .ret
|
||||||
|
@@:
|
||||||
|
mov ebx, [mem_BACKGROUND]
|
||||||
|
add ebx, 4095
|
||||||
|
and ebx, -4096
|
||||||
|
sub ebx, 4
|
||||||
|
cmp ecx, ebx
|
||||||
|
ja .ret
|
||||||
|
|
||||||
|
mov ebx,[eax+ecx]
|
||||||
|
and ebx,0xFF000000 ;255*256*256*256
|
||||||
|
and edx,0x00FFFFFF ;255*256*256+255*256+255
|
||||||
|
add edx,ebx
|
||||||
|
mov [eax+ecx],edx
|
||||||
|
.ret:
|
||||||
|
ret
|
||||||
|
nosb2:
|
||||||
|
|
||||||
|
cmp ebx,3 ; DRAW BACKGROUND
|
||||||
|
jnz nosb3
|
||||||
|
draw_background_temp:
|
||||||
|
; cmp [bgrchanged],1 ;0
|
||||||
|
; je nosb31
|
||||||
|
;draw_background_temp:
|
||||||
|
; mov [bgrchanged],1 ;0
|
||||||
|
mov [background_defined], 1
|
||||||
|
mov byte[BACKGROUND_CHANGED], 1
|
||||||
|
call force_redraw_background
|
||||||
|
nosb31:
|
||||||
|
ret
|
||||||
|
nosb3:
|
||||||
|
|
||||||
|
cmp ebx,4 ; TILED / STRETCHED
|
||||||
|
jnz nosb4
|
||||||
|
cmp ecx,[BgrDrawMode]
|
||||||
|
je nosb41
|
||||||
|
mov [BgrDrawMode],ecx
|
||||||
|
; mov [bgrchanged],1
|
||||||
|
nosb41:
|
||||||
|
ret
|
||||||
|
nosb4:
|
||||||
|
|
||||||
|
cmp ebx,5 ; BLOCK MOVE TO BGR
|
||||||
|
jnz nosb5
|
||||||
|
cmp [img_background], static_background_data
|
||||||
|
jnz @f
|
||||||
|
test edx, edx
|
||||||
|
jnz .fin
|
||||||
|
cmp esi, 4
|
||||||
|
ja .fin
|
||||||
|
@@:
|
||||||
|
; bughere
|
||||||
|
mov eax, ecx
|
||||||
|
mov ebx, edx
|
||||||
|
add ebx, [img_background] ;IMG_BACKGROUND
|
||||||
|
mov ecx, esi
|
||||||
|
call memmove
|
||||||
|
.fin:
|
||||||
|
ret
|
||||||
|
nosb5:
|
||||||
|
|
||||||
|
cmp ebx, 6
|
||||||
|
jnz nosb6
|
||||||
|
;;Maxis use atomic bts for mutex 4.4.2009
|
||||||
|
@@:
|
||||||
|
bts dword [bgrlock], 0
|
||||||
|
jnc @f
|
||||||
|
call change_task
|
||||||
|
jmp @b
|
||||||
|
@@:
|
||||||
|
mov eax, [CURRENT_TASK]
|
||||||
|
mov [bgrlockpid], eax
|
||||||
|
cmp [img_background], static_background_data
|
||||||
|
jz .nomem
|
||||||
|
stdcall user_alloc, [mem_BACKGROUND]
|
||||||
|
mov [esp+32], eax
|
||||||
|
test eax, eax
|
||||||
|
jz .nomem
|
||||||
|
mov ebx, eax
|
||||||
|
shr ebx, 12
|
||||||
|
or dword [page_tabs+(ebx-1)*4], DONT_FREE_BLOCK
|
||||||
|
mov esi, [img_background]
|
||||||
|
shr esi, 12
|
||||||
|
mov ecx, [mem_BACKGROUND]
|
||||||
|
add ecx, 0xFFF
|
||||||
|
shr ecx, 12
|
||||||
|
.z:
|
||||||
|
mov eax, [page_tabs+ebx*4]
|
||||||
|
test al, 1
|
||||||
|
jz @f
|
||||||
|
call free_page
|
||||||
|
@@:
|
||||||
|
mov eax, [page_tabs+esi*4]
|
||||||
|
or al, PG_UW
|
||||||
|
mov [page_tabs+ebx*4], eax
|
||||||
|
mov eax, ebx
|
||||||
|
shl eax, 12
|
||||||
|
invlpg [eax]
|
||||||
|
inc ebx
|
||||||
|
inc esi
|
||||||
|
loop .z
|
||||||
|
ret
|
||||||
|
.nomem:
|
||||||
|
and [bgrlockpid], 0
|
||||||
|
mov [bgrlock], 0
|
||||||
|
nosb6:
|
||||||
|
cmp ebx, 7
|
||||||
|
jnz nosb7
|
||||||
|
cmp [bgrlock], 0
|
||||||
|
jz .err
|
||||||
|
mov eax, [CURRENT_TASK]
|
||||||
|
cmp [bgrlockpid], eax
|
||||||
|
jnz .err
|
||||||
|
mov eax, ecx
|
||||||
|
mov ebx, ecx
|
||||||
|
shr eax, 12
|
||||||
|
mov ecx, [page_tabs+(eax-1)*4]
|
||||||
|
test cl, USED_BLOCK+DONT_FREE_BLOCK
|
||||||
|
jz .err
|
||||||
|
jnp .err
|
||||||
|
push eax
|
||||||
|
shr ecx, 12
|
||||||
|
dec ecx
|
||||||
|
@@:
|
||||||
|
and dword [page_tabs+eax*4], 0
|
||||||
|
mov edx, eax
|
||||||
|
shl edx, 12
|
||||||
|
push eax
|
||||||
|
invlpg [edx]
|
||||||
|
pop eax
|
||||||
|
inc eax
|
||||||
|
loop @b
|
||||||
|
pop eax
|
||||||
|
and dword [page_tabs+(eax-1)*4], not DONT_FREE_BLOCK
|
||||||
|
stdcall user_free, ebx
|
||||||
|
mov [esp+32], eax
|
||||||
|
and [bgrlockpid], 0
|
||||||
|
mov [bgrlock], 0
|
||||||
|
ret
|
||||||
|
.err:
|
||||||
|
and dword [esp+32], 0
|
||||||
|
ret
|
||||||
|
|
||||||
|
nosb7:
|
||||||
ret
|
ret
|
||||||
|
|
||||||
;=============================== SysFn 39 ================================
|
;=============================== SysFn 39 ================================
|
||||||
; no background service supported so far ...
|
|
||||||
;===========================================
|
|
||||||
align 4
|
align 4
|
||||||
|
|
||||||
sys_getbackground:
|
sys_getbackground:
|
||||||
mov dword [esp+32], 0
|
dec ebx
|
||||||
|
jnz nogb1
|
||||||
|
mov eax,[BgrDataWidth]
|
||||||
|
shl eax,16
|
||||||
|
mov ax,[BgrDataHeight]
|
||||||
|
mov [esp+32],eax
|
||||||
|
ret
|
||||||
|
|
||||||
|
nogb1:
|
||||||
|
; cmp eax,2 ; PIXEL
|
||||||
|
dec ebx
|
||||||
|
jnz nogb2
|
||||||
|
|
||||||
|
mov eax, [img_background]
|
||||||
|
test ecx, ecx
|
||||||
|
jz @f
|
||||||
|
cmp eax, static_background_data
|
||||||
|
jz .ret
|
||||||
|
@@:
|
||||||
|
mov ebx, [mem_BACKGROUND]
|
||||||
|
add ebx, 4095
|
||||||
|
and ebx, -4096
|
||||||
|
sub ebx, 4
|
||||||
|
cmp ecx, ebx
|
||||||
|
ja .ret
|
||||||
|
|
||||||
|
mov eax,[ecx+eax]
|
||||||
|
|
||||||
|
and eax, 0xFFFFFF
|
||||||
|
mov [esp+32],eax
|
||||||
|
.ret:
|
||||||
|
ret
|
||||||
|
nogb2:
|
||||||
|
|
||||||
|
; cmp eax,4 ; TILED / STRETCHED
|
||||||
|
dec ebx
|
||||||
|
dec ebx
|
||||||
|
jnz nogb4
|
||||||
|
mov eax,[BgrDrawMode]
|
||||||
|
nogb4:
|
||||||
|
mov [esp+32],eax
|
||||||
ret
|
ret
|
||||||
|
|
||||||
;===========================================
|
;===========================================
|
||||||
@ -3096,13 +3202,37 @@ f_irqs:
|
|||||||
endg
|
endg
|
||||||
|
|
||||||
drawbackground:
|
drawbackground:
|
||||||
|
; inc [mouse_pause]
|
||||||
|
; call draw_background ; graph32.inc
|
||||||
|
; dec [mouse_pause]
|
||||||
|
; call [draw_pointer]
|
||||||
|
; ret
|
||||||
inc [mouse_pause]
|
inc [mouse_pause]
|
||||||
call draw_background ; graph32.inc
|
cmp [SCR_MODE],word 0x12
|
||||||
|
je dbrv20
|
||||||
|
dbrv12:
|
||||||
|
cmp [SCR_MODE],word 0100000000000000b
|
||||||
|
jge dbrv20
|
||||||
|
dec [mouse_pause]
|
||||||
|
call [draw_pointer]
|
||||||
|
ret
|
||||||
|
dbrv20:
|
||||||
|
cmp [BgrDrawMode],dword 1
|
||||||
|
jne bgrstr
|
||||||
|
call vesa20_drawbackground_tiled
|
||||||
|
dec [mouse_pause]
|
||||||
|
call [draw_pointer]
|
||||||
|
ret
|
||||||
|
bgrstr:
|
||||||
|
call vesa20_drawbackground_stretch
|
||||||
dec [mouse_pause]
|
dec [mouse_pause]
|
||||||
call [draw_pointer]
|
call [draw_pointer]
|
||||||
ret
|
ret
|
||||||
|
|
||||||
; ====================================================================
|
; ====================================================================
|
||||||
|
if 0
|
||||||
|
; the new GFX sys
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
syscall_putimage: ; PutImage = SysFn07
|
syscall_putimage: ; PutImage = SysFn07
|
||||||
sys_putimage:
|
sys_putimage:
|
||||||
@ -3203,6 +3333,311 @@ img_edge_proc_2 dd draw_edge_16bpp
|
|||||||
img_edge_proc_3 dd draw_edge_24bpp
|
img_edge_proc_3 dd draw_edge_24bpp
|
||||||
img_edge_proc_4 dd draw_edge_32bpp
|
img_edge_proc_4 dd draw_edge_32bpp
|
||||||
|
|
||||||
|
end if
|
||||||
|
; <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
|
||||||
|
; the old GFX sys
|
||||||
|
align 4
|
||||||
|
|
||||||
|
syscall_putimage: ; PutImage
|
||||||
|
sys_putimage:
|
||||||
|
test ecx,0x80008000
|
||||||
|
jnz .exit
|
||||||
|
test ecx,0x0000FFFF
|
||||||
|
jz .exit
|
||||||
|
test ecx,0xFFFF0000
|
||||||
|
jnz @f
|
||||||
|
.exit:
|
||||||
|
ret
|
||||||
|
@@:
|
||||||
|
mov edi,[current_slot]
|
||||||
|
add dx,word[edi+APPDATA.wnd_clientbox.top]
|
||||||
|
rol edx,16
|
||||||
|
add dx,word[edi+APPDATA.wnd_clientbox.left]
|
||||||
|
rol edx,16
|
||||||
|
.forced:
|
||||||
|
push ebp esi 0
|
||||||
|
mov ebp, putimage_get24bpp
|
||||||
|
mov esi, putimage_init24bpp
|
||||||
|
sys_putimage_bpp:
|
||||||
|
; cmp [SCR_MODE], word 0x12
|
||||||
|
; jz @f ;.doit
|
||||||
|
; mov eax, vesa12_putimage
|
||||||
|
; cmp [SCR_MODE], word 0100000000000000b
|
||||||
|
; jae @f
|
||||||
|
; cmp [SCR_MODE], word 0x13
|
||||||
|
; jnz .doit
|
||||||
|
;@@:
|
||||||
|
mov eax, vesa20_putimage
|
||||||
|
.doit:
|
||||||
|
inc [mouse_pause]
|
||||||
|
call eax
|
||||||
|
dec [mouse_pause]
|
||||||
|
pop ebp esi ebp
|
||||||
|
jmp [draw_pointer]
|
||||||
|
align 4
|
||||||
|
sys_putimage_palette:
|
||||||
|
; ebx = pointer to image
|
||||||
|
; ecx = [xsize]*65536 + [ysize]
|
||||||
|
; edx = [xstart]*65536 + [ystart]
|
||||||
|
; esi = number of bits per pixel, must be 8, 24 or 32
|
||||||
|
; edi = pointer to palette
|
||||||
|
; ebp = row delta
|
||||||
|
mov eax, [CURRENT_TASK]
|
||||||
|
shl eax, 8
|
||||||
|
add dx, word [eax+SLOT_BASE+APPDATA.wnd_clientbox.top]
|
||||||
|
rol edx, 16
|
||||||
|
add dx, word [eax+SLOT_BASE+APPDATA.wnd_clientbox.left]
|
||||||
|
rol edx, 16
|
||||||
|
.forced:
|
||||||
|
cmp esi, 1
|
||||||
|
jnz @f
|
||||||
|
push edi
|
||||||
|
mov eax, [edi+4]
|
||||||
|
sub eax, [edi]
|
||||||
|
push eax
|
||||||
|
push dword [edi]
|
||||||
|
push 0ffffff80h
|
||||||
|
mov edi, esp
|
||||||
|
call put_mono_image
|
||||||
|
add esp, 12
|
||||||
|
pop edi
|
||||||
|
ret
|
||||||
|
@@:
|
||||||
|
cmp esi, 2
|
||||||
|
jnz @f
|
||||||
|
push edi
|
||||||
|
push 0ffffff80h
|
||||||
|
mov edi, esp
|
||||||
|
call put_2bit_image
|
||||||
|
pop eax
|
||||||
|
pop edi
|
||||||
|
ret
|
||||||
|
@@:
|
||||||
|
cmp esi, 4
|
||||||
|
jnz @f
|
||||||
|
push edi
|
||||||
|
push 0ffffff80h
|
||||||
|
mov edi, esp
|
||||||
|
call put_4bit_image
|
||||||
|
pop eax
|
||||||
|
pop edi
|
||||||
|
ret
|
||||||
|
@@:
|
||||||
|
push ebp esi ebp
|
||||||
|
cmp esi, 8
|
||||||
|
jnz @f
|
||||||
|
mov ebp, putimage_get8bpp
|
||||||
|
mov esi, putimage_init8bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
@@:
|
||||||
|
cmp esi, 15
|
||||||
|
jnz @f
|
||||||
|
mov ebp, putimage_get15bpp
|
||||||
|
mov esi, putimage_init15bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
@@:
|
||||||
|
cmp esi, 16
|
||||||
|
jnz @f
|
||||||
|
mov ebp, putimage_get16bpp
|
||||||
|
mov esi, putimage_init16bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
@@:
|
||||||
|
cmp esi, 24
|
||||||
|
jnz @f
|
||||||
|
mov ebp, putimage_get24bpp
|
||||||
|
mov esi, putimage_init24bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
@@:
|
||||||
|
cmp esi, 32
|
||||||
|
jnz @f
|
||||||
|
mov ebp, putimage_get32bpp
|
||||||
|
mov esi, putimage_init32bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
@@:
|
||||||
|
pop ebp esi ebp
|
||||||
|
ret
|
||||||
|
|
||||||
|
put_mono_image:
|
||||||
|
push ebp esi ebp
|
||||||
|
mov ebp, putimage_get1bpp
|
||||||
|
mov esi, putimage_init1bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
put_2bit_image:
|
||||||
|
push ebp esi ebp
|
||||||
|
mov ebp, putimage_get2bpp
|
||||||
|
mov esi, putimage_init2bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
put_4bit_image:
|
||||||
|
push ebp esi ebp
|
||||||
|
mov ebp, putimage_get4bpp
|
||||||
|
mov esi, putimage_init4bpp
|
||||||
|
jmp sys_putimage_bpp
|
||||||
|
|
||||||
|
putimage_init24bpp:
|
||||||
|
lea eax, [eax*3]
|
||||||
|
putimage_init8bpp:
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 16
|
||||||
|
putimage_get24bpp:
|
||||||
|
movzx eax, byte [esi+2]
|
||||||
|
shl eax, 16
|
||||||
|
mov ax, [esi]
|
||||||
|
add esi, 3
|
||||||
|
ret 4
|
||||||
|
align 16
|
||||||
|
putimage_get8bpp:
|
||||||
|
movzx eax, byte [esi]
|
||||||
|
push edx
|
||||||
|
mov edx, [esp+8]
|
||||||
|
mov eax, [edx+eax*4]
|
||||||
|
pop edx
|
||||||
|
inc esi
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
putimage_init1bpp:
|
||||||
|
add eax, ecx
|
||||||
|
push ecx
|
||||||
|
add eax, 7
|
||||||
|
add ecx, 7
|
||||||
|
shr eax, 3
|
||||||
|
shr ecx, 3
|
||||||
|
sub eax, ecx
|
||||||
|
pop ecx
|
||||||
|
ret
|
||||||
|
align 16
|
||||||
|
putimage_get1bpp:
|
||||||
|
push edx
|
||||||
|
mov edx, [esp+8]
|
||||||
|
mov al, [edx]
|
||||||
|
add al, al
|
||||||
|
jnz @f
|
||||||
|
lodsb
|
||||||
|
adc al, al
|
||||||
|
@@:
|
||||||
|
mov [edx], al
|
||||||
|
sbb eax, eax
|
||||||
|
and eax, [edx+8]
|
||||||
|
add eax, [edx+4]
|
||||||
|
pop edx
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
putimage_init2bpp:
|
||||||
|
add eax, ecx
|
||||||
|
push ecx
|
||||||
|
add ecx, 3
|
||||||
|
add eax, 3
|
||||||
|
shr ecx, 2
|
||||||
|
shr eax, 2
|
||||||
|
sub eax, ecx
|
||||||
|
pop ecx
|
||||||
|
ret
|
||||||
|
align 16
|
||||||
|
putimage_get2bpp:
|
||||||
|
push edx
|
||||||
|
mov edx, [esp+8]
|
||||||
|
mov al, [edx]
|
||||||
|
mov ah, al
|
||||||
|
shr al, 6
|
||||||
|
shl ah, 2
|
||||||
|
jnz .nonewbyte
|
||||||
|
lodsb
|
||||||
|
mov ah, al
|
||||||
|
shr al, 6
|
||||||
|
shl ah, 2
|
||||||
|
add ah, 1
|
||||||
|
.nonewbyte:
|
||||||
|
mov [edx], ah
|
||||||
|
mov edx, [edx+4]
|
||||||
|
movzx eax, al
|
||||||
|
mov eax, [edx+eax*4]
|
||||||
|
pop edx
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
putimage_init4bpp:
|
||||||
|
add eax, ecx
|
||||||
|
push ecx
|
||||||
|
add ecx, 1
|
||||||
|
add eax, 1
|
||||||
|
shr ecx, 1
|
||||||
|
shr eax, 1
|
||||||
|
sub eax, ecx
|
||||||
|
pop ecx
|
||||||
|
ret
|
||||||
|
align 16
|
||||||
|
putimage_get4bpp:
|
||||||
|
push edx
|
||||||
|
mov edx, [esp+8]
|
||||||
|
add byte [edx], 80h
|
||||||
|
jc @f
|
||||||
|
movzx eax, byte [edx+1]
|
||||||
|
mov edx, [edx+4]
|
||||||
|
and eax, 0x0F
|
||||||
|
mov eax, [edx+eax*4]
|
||||||
|
pop edx
|
||||||
|
ret 4
|
||||||
|
@@:
|
||||||
|
movzx eax, byte [esi]
|
||||||
|
add esi, 1
|
||||||
|
mov [edx+1], al
|
||||||
|
shr eax, 4
|
||||||
|
mov edx, [edx+4]
|
||||||
|
mov eax, [edx+eax*4]
|
||||||
|
pop edx
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
putimage_init32bpp:
|
||||||
|
shl eax, 2
|
||||||
|
ret
|
||||||
|
align 16
|
||||||
|
putimage_get32bpp:
|
||||||
|
lodsd
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
putimage_init15bpp:
|
||||||
|
putimage_init16bpp:
|
||||||
|
add eax, eax
|
||||||
|
ret
|
||||||
|
align 16
|
||||||
|
putimage_get15bpp:
|
||||||
|
; 0RRRRRGGGGGBBBBB -> 00000000RRRRR000GGGGG000BBBBB000
|
||||||
|
push ecx edx
|
||||||
|
movzx eax, word [esi]
|
||||||
|
add esi, 2
|
||||||
|
mov ecx, eax
|
||||||
|
mov edx, eax
|
||||||
|
and eax, 0x1F
|
||||||
|
and ecx, 0x1F shl 5
|
||||||
|
and edx, 0x1F shl 10
|
||||||
|
shl eax, 3
|
||||||
|
shl ecx, 6
|
||||||
|
shl edx, 9
|
||||||
|
or eax, ecx
|
||||||
|
or eax, edx
|
||||||
|
pop edx ecx
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
align 16
|
||||||
|
putimage_get16bpp:
|
||||||
|
; RRRRRGGGGGGBBBBB -> 00000000RRRRR000GGGGGG00BBBBB000
|
||||||
|
push ecx edx
|
||||||
|
movzx eax, word [esi]
|
||||||
|
add esi, 2
|
||||||
|
mov ecx, eax
|
||||||
|
mov edx, eax
|
||||||
|
and eax, 0x1F
|
||||||
|
and ecx, 0x3F shl 5
|
||||||
|
and edx, 0x1F shl 11
|
||||||
|
shl eax, 3
|
||||||
|
shl ecx, 5
|
||||||
|
shl edx, 8
|
||||||
|
or eax, ecx
|
||||||
|
or eax, edx
|
||||||
|
pop edx ecx
|
||||||
|
ret 4
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; ==================================================
|
; ==================================================
|
||||||
; eax x beginning
|
; eax x beginning
|
||||||
; ebx y beginning
|
; ebx y beginning
|
||||||
@ -3219,7 +3654,7 @@ __sys_drawbar:
|
|||||||
.forced:
|
.forced:
|
||||||
inc [mouse_pause]
|
inc [mouse_pause]
|
||||||
; dbv20:
|
; dbv20:
|
||||||
call _drawbar
|
call drawbar
|
||||||
dec [mouse_pause]
|
dec [mouse_pause]
|
||||||
jmp [draw_pointer]
|
jmp [draw_pointer]
|
||||||
|
|
||||||
@ -3965,11 +4400,7 @@ set_screen:
|
|||||||
stdcall kernel_free, [_WinMapAddress]
|
stdcall kernel_free, [_WinMapAddress]
|
||||||
|
|
||||||
mov eax, [_display.width]
|
mov eax, [_display.width]
|
||||||
shr eax, 2
|
mul [_display.height]
|
||||||
mov [_WinMapWidth], eax
|
|
||||||
mov eax, [_display.height]
|
|
||||||
shr eax, 1
|
|
||||||
mul [_WinMapWidth]
|
|
||||||
mov [_WinMapSize], eax
|
mov [_WinMapSize], eax
|
||||||
|
|
||||||
stdcall kernel_alloc, eax
|
stdcall kernel_alloc, eax
|
||||||
@ -4306,27 +4737,3 @@ uglobals_size = $ - endofcode
|
|||||||
diff16 "Zero-filled blk",0,endofcode
|
diff16 "Zero-filled blk",0,endofcode
|
||||||
diff16 "End of kernel ",0,$
|
diff16 "End of kernel ",0,$
|
||||||
|
|
||||||
;Кургинян - математик, и основные свои выводы делает на основе теории катастроф (есть такая вполне себе прикладная область математики) с элементами вариационного и факторного анализа. В принципе, он мог бы изложить суть в 3-4 сухих формулах, но только понять их могли (и захотели) бы человек 200-300...
|
|
||||||
|
|
||||||
;Вот и приходится ему излагать то же самое, но гораздо длиннее и доходчивее. Лично я не поленился и прочитал цикл "Кризис и другие" в архиве "Завтра" за 2009 год.
|
|
||||||
|
|
||||||
|
|
||||||
;Вот очень краткая выжимка его основных идей (с моей колокольни, конечно):
|
|
||||||
|
|
||||||
;1) Планета перенаселена, ресурсов на всех не хватит, период либеральненкой глобализации должен смениться эрой жесткого рационирования при тотальном контроле всего.
|
|
||||||
|
|
||||||
;2) У грядущего тоталитарного общества должна быть господствующая идеология, мобилизующая людей в суровой борьбе. Какой ей быть? для этого надо ответить на два основных вопроса: а) можно ли сделать человека лучше, сильнее, умнее? и б) можно ли сделать общество лучше, справедливее, свободнее?
|
|
||||||
|
|
||||||
;3) существует 4 возможных ответа на эти 2 вопроса: (а+б+) исторический модерн, он же коммунизм; (а+б-) антиисторический модерн, или фашизм; (а-б+) религиозный фундаментализм, или Контрмодерн; и наконец (а-б-) циничный антигуманизм, он же Постмодерн.
|
|
||||||
|
|
||||||
;4) крушение коммунистического проекта в XX веке было тщательно спланированной катастрофой с целью поворота человечества с модернистского пути развития на постмодернистский путь распада. Кургинян здесь имеет в виду катастрофу в математическом смысле, т.е. не какое-то печальное событие, а процесс, приводящий к такому событию. Я не хочу пересказывать здесь все положения теории катастроф - важно только понимать, что такой процесс вовсе не обязательно должен приводить к фатальному исходу - выход из катастрофы всегда можно найти, вплоть до самого последнего момента!
|
|
||||||
|
|
||||||
;5) катиться по этому катастрофическому пути легко, но найти выход из катастрофы с каждым шагом все сложнее. Чтобы избежать фатального конца, одной энергии мало - требуется изрядная сила воли.
|
|
||||||
|
|
||||||
;6) здесь Кургинян подключает другой математический аппарат - теорию игр. И показывает, как шулера - магистры сложной коалиционно-антагонистической игры умеют целенаправленно и эффективно лишать противников воли и смыслов для поиска выхода из катастрофы.
|
|
||||||
|
|
||||||
;7) конечно, человеческое общество - сложнейшая система с непредсказуемым откликом на актиные действия каждого из игроков. Даже опытнейший шулер может здесь сделать неверные ходы. Но в распоряжении мастеров игры имеется еще один мощный аппарат - факторный анализ, позволяющий эффективно корректировать промахи и лучше предсказывть поведение сложных систем.
|
|
||||||
|
|
||||||
;8) и тем не менее, выход есть! Для начала, надо реально осознать свою позицию в игре и навязать свою, активную игру (каждый новый активный игрок усложняет партнерам анализ игры). Это сложно (проще быть болваном), и это требует Воли и воссоздания Смыслов.
|
|
||||||
|
|
||||||
;9) даже самая активная игра будет простым барахтаньем, если не ставится конечная цель. Такая цель есть. Точнее - была: проект (а+б+). Если ее восстановить, мы не просто вернемся к активной игре - мы можем сформировать мощную коалицию антипостмодернистов.
|
|
||||||
|
@ -224,7 +224,8 @@ include "sound/playnote.inc" ; player Note for Speaker PC
|
|||||||
|
|
||||||
; display
|
; display
|
||||||
|
|
||||||
include "video/graph32.inc" ; 32bpp graphics
|
;include "video/graph32.inc" ; 32bpp graphics
|
||||||
|
include "video/vesa20.inc" ; older graphics engine
|
||||||
include "video/cursors.inc" ; cursors functions
|
include "video/cursors.inc" ; cursors functions
|
||||||
|
|
||||||
; Network Interface & TCPIP Stack
|
; Network Interface & TCPIP Stack
|
||||||
|
Loading…
Reference in New Issue
Block a user