forked from KolibriOS/kolibrios
SYNC WITH MAIN TRUNC: kernel-A updated to $1687
git-svn-id: svn://kolibrios.org@1689 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
fb9f6b3fef
commit
500832c01d
@ -22,6 +22,10 @@ iglobal
|
|||||||
szReservePortArea db 'ReservePortArea',0
|
szReservePortArea db 'ReservePortArea',0
|
||||||
szBoot_Log db 'Boot_Log',0
|
szBoot_Log db 'Boot_Log',0
|
||||||
|
|
||||||
|
szMutexInit db 'MutexInit',0
|
||||||
|
szMutexLock db 'MutexLock',0
|
||||||
|
szMutexUnlock db 'MutexUnlock',0
|
||||||
|
|
||||||
szPciApi db 'PciApi', 0
|
szPciApi db 'PciApi', 0
|
||||||
szPciRead32 db 'PciRead32', 0
|
szPciRead32 db 'PciRead32', 0
|
||||||
szPciRead16 db 'PciRead16', 0
|
szPciRead16 db 'PciRead16', 0
|
||||||
@ -91,7 +95,11 @@ kernel_export:
|
|||||||
dd szReservePortArea , r_f_port_area
|
dd szReservePortArea , r_f_port_area
|
||||||
dd szBoot_Log , boot_log
|
dd szBoot_Log , boot_log
|
||||||
|
|
||||||
dd szPciApi , pci_api
|
dd szMutexInit , mutex_init ;gcc fastcall
|
||||||
|
dd szMutexLock , mutex_lock ;gcc fastcall
|
||||||
|
dd szMutexUnlock , mutex_unlock ;gcc fastcall
|
||||||
|
|
||||||
|
dd szPciApi , pci_api_drv
|
||||||
dd szPciRead32 , pci_read32
|
dd szPciRead32 , pci_read32
|
||||||
dd szPciRead16 , pci_read16
|
dd szPciRead16 , pci_read16
|
||||||
dd szPciRead8 , pci_read8
|
dd szPciRead8 , pci_read8
|
||||||
|
@ -635,7 +635,8 @@ proc kernel_free stdcall, base:dword
|
|||||||
pop esi ebx
|
pop esi ebx
|
||||||
ret
|
ret
|
||||||
.fail:
|
.fail:
|
||||||
and [heap_mutex], 0
|
xor eax, eax
|
||||||
|
mov [heap_mutex], eax
|
||||||
pop esi ebx
|
pop esi ebx
|
||||||
ret
|
ret
|
||||||
endp
|
endp
|
||||||
|
@ -1089,25 +1089,7 @@ sysfn_meminfo:
|
|||||||
.fail:
|
.fail:
|
||||||
or dword [esp+32], -1
|
or dword [esp+32], -1
|
||||||
ret
|
ret
|
||||||
iglobal
|
|
||||||
align 4
|
|
||||||
f68call:
|
|
||||||
dd f68.11 ; init_heap
|
|
||||||
dd f68.12 ; user_alloc
|
|
||||||
dd f68.13 ; user_free
|
|
||||||
dd f68.14 ; get_event_ex
|
|
||||||
dd f68.fail ;moved to f68.24
|
|
||||||
dd f68.16 ; get_service
|
|
||||||
dd f68.17 ; call_service
|
|
||||||
dd f68.fail ;moved to f68.25
|
|
||||||
dd f68.19 ; load_dll
|
|
||||||
dd f68.20 ; user_realloc
|
|
||||||
dd f68.21 ; load_driver
|
|
||||||
dd f68.22 ; shmem_open
|
|
||||||
dd f68.23 ; shmem_close
|
|
||||||
dd f68.24
|
|
||||||
dd f68.25
|
|
||||||
endg
|
|
||||||
align 4
|
align 4
|
||||||
f68:
|
f68:
|
||||||
cmp ebx,4
|
cmp ebx,4
|
||||||
@ -1227,6 +1209,24 @@ f68:
|
|||||||
mov [esp+32], eax
|
mov [esp+32], eax
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
f68call:
|
||||||
|
dd f68.11 ; init_heap
|
||||||
|
dd f68.12 ; user_alloc
|
||||||
|
dd f68.13 ; user_free
|
||||||
|
dd f68.14 ; get_event_ex
|
||||||
|
dd f68.fail ;moved to f68.24
|
||||||
|
dd f68.16 ; get_service
|
||||||
|
dd f68.17 ; call_service
|
||||||
|
dd f68.fail ;moved to f68.25
|
||||||
|
dd f68.19 ; load_dll
|
||||||
|
dd f68.20 ; user_realloc
|
||||||
|
dd f68.21 ; load_driver
|
||||||
|
dd f68.22 ; shmem_open
|
||||||
|
dd f68.23 ; shmem_close
|
||||||
|
dd f68.24
|
||||||
|
dd f68.25
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
proc load_pe_driver stdcall, file:dword
|
proc load_pe_driver stdcall, file:dword
|
||||||
|
|
||||||
|
@ -283,6 +283,12 @@ __exports:
|
|||||||
alloc_page, 'AllocPage', \ ; gcc ABI
|
alloc_page, 'AllocPage', \ ; gcc ABI
|
||||||
alloc_pages, 'AllocPages', \ ; stdcall
|
alloc_pages, 'AllocPages', \ ; stdcall
|
||||||
commit_pages, 'CommitPages', \ ; eax, ebx, ecx
|
commit_pages, 'CommitPages', \ ; eax, ebx, ecx
|
||||||
|
\
|
||||||
|
create_event, 'CreateEvent', \ ; ecx, esi
|
||||||
|
raise_event, 'RaiseEvent', \ ; eax, ebx, edx, esi
|
||||||
|
wait_event, 'WaitEvent', \ ; eax, ebx
|
||||||
|
get_event_ex, 'GetEvent', \ ; edi
|
||||||
|
\
|
||||||
create_kernel_object, 'CreateObject', \
|
create_kernel_object, 'CreateObject', \
|
||||||
create_ring_buffer, 'CreateRingBuffer', \ ; stdcall
|
create_ring_buffer, 'CreateRingBuffer', \ ; stdcall
|
||||||
destroy_kernel_object, 'DestroyObject', \
|
destroy_kernel_object, 'DestroyObject', \
|
||||||
@ -300,7 +306,7 @@ __exports:
|
|||||||
\
|
\
|
||||||
get_display, 'GetDisplay', \
|
get_display, 'GetDisplay', \
|
||||||
set_screen, 'SetScreen', \
|
set_screen, 'SetScreen', \
|
||||||
pci_api, 'PciApi', \
|
pci_api_drv, 'PciApi', \
|
||||||
pci_read8, 'PciRead8', \ ; stdcall
|
pci_read8, 'PciRead8', \ ; stdcall
|
||||||
pci_read16, 'PciRead16', \ ; stdcall
|
pci_read16, 'PciRead16', \ ; stdcall
|
||||||
pci_read32, 'PciRead32', \ ; stdcall
|
pci_read32, 'PciRead32', \ ; stdcall
|
||||||
@ -315,6 +321,7 @@ __exports:
|
|||||||
user_free, 'UserFree', \ ; stdcall
|
user_free, 'UserFree', \ ; stdcall
|
||||||
unmap_pages, 'UnmapPages', \ ; eax, ecx
|
unmap_pages, 'UnmapPages', \ ; eax, ecx
|
||||||
sys_msg_board_str, 'SysMsgBoardStr', \
|
sys_msg_board_str, 'SysMsgBoardStr', \
|
||||||
|
get_timer_ticks, 'GetTimerTicks', \
|
||||||
delay_hs, 'Delay', \ ; ebx
|
delay_hs, 'Delay', \ ; ebx
|
||||||
set_mouse_data, 'SetMouseData'
|
set_mouse_data, 'SetMouseData'
|
||||||
|
|
||||||
|
@ -347,6 +347,7 @@ Returned value:
|
|||||||
* bit 0 (mask 1): window is maximized
|
* bit 0 (mask 1): window is maximized
|
||||||
* bit 1 (mask 2): window is minimized to panel
|
* bit 1 (mask 2): window is minimized to panel
|
||||||
* bit 2 (mask 4): window is rolled up
|
* bit 2 (mask 4): window is rolled up
|
||||||
|
* +71 = +0x47: dword: event mask
|
||||||
Remarks:
|
Remarks:
|
||||||
* Slots are numbered starting from 1.
|
* Slots are numbered starting from 1.
|
||||||
* Returned value is not a total number of threads, because there
|
* Returned value is not a total number of threads, because there
|
||||||
@ -844,12 +845,12 @@ Returned value:
|
|||||||
* function does not return value
|
* function does not return value
|
||||||
Structure of the buffer:
|
Structure of the buffer:
|
||||||
db a,b,c,d for version a.b.c.d
|
db a,b,c,d for version a.b.c.d
|
||||||
db UID_xxx: one of UID_NONE=0, UID_MENUET=1, UID_KOLIBRI=2
|
db 0
|
||||||
dd REV - kernel SVN revision number
|
dd REV - kernel SVN revision number
|
||||||
For Kolibri 0.7.1.0 kernel:
|
For Kolibri 0.7.7.0 kernel:
|
||||||
db 0,7,0,0
|
db 0,7,7,0
|
||||||
db 2
|
db 2
|
||||||
dd 638
|
dd 1657
|
||||||
|
|
||||||
======================================================================
|
======================================================================
|
||||||
======= Function 18, subfunction 14 - wait for screen retrace. =======
|
======= Function 18, subfunction 14 - wait for screen retrace. =======
|
||||||
@ -1658,56 +1659,8 @@ Returned value:
|
|||||||
Remarks:
|
Remarks:
|
||||||
* If the buffer is too small to hold all data, only first (edx-1)
|
* If the buffer is too small to hold all data, only first (edx-1)
|
||||||
bytes are copied and than terminating 0 is inserted.
|
bytes are copied and than terminating 0 is inserted.
|
||||||
|
* By default, current folder for the thread is "/rd/1".
|
||||||
======================================================================
|
* At process/thread creation the current folder will be inherited
|
||||||
=============== Function 32 - delete file from ramdisk. ==============
|
|
||||||
======================================================================
|
|
||||||
Parameters:
|
|
||||||
* eax = 32 - function number
|
|
||||||
* ebx = pointer to the filename
|
|
||||||
Returned value:
|
|
||||||
* eax = 0 - success; otherwise file system error code
|
|
||||||
Remarks:
|
|
||||||
* This function is obsolete; function 58 allows to fulfill
|
|
||||||
the same operations with the extended possibilities.
|
|
||||||
* The current implementation returns only values 0(success) and
|
|
||||||
5(file not found).
|
|
||||||
* The filename must be either in the format 8+3 characters
|
|
||||||
(first 8 characters - name itself, last 3 - extension,
|
|
||||||
the short names and extensions are supplemented with spaces),
|
|
||||||
or in the format 8.3 characters "FILE.EXT"/"FILE.EX "
|
|
||||||
(name no more than 8 characters, dot, extension 3 characters
|
|
||||||
supplemented if necessary by spaces).
|
|
||||||
The filename must be written with capital letters. The terminating
|
|
||||||
character with code 0 is not necessary (not ASCIIZ-string).
|
|
||||||
* This function does not support folders on the ramdisk.
|
|
||||||
|
|
||||||
======================================================================
|
|
||||||
================ Function 33 - write file to ramdisk. ================
|
|
||||||
======================================================================
|
|
||||||
Parameters:
|
|
||||||
* eax = 33 - function number
|
|
||||||
* ebx = pointer to the filename
|
|
||||||
* ecx = pointer to data for writing
|
|
||||||
* edx = number of bytes for writing
|
|
||||||
* should be set esi=0
|
|
||||||
Returned value:
|
|
||||||
* eax = 0 - success, otherwise file system error code
|
|
||||||
Remarks:
|
|
||||||
* This function is obsolete; function 70 allows to fulfil
|
|
||||||
the same operations with extended possibilities.
|
|
||||||
* If esi contains non-zero value and selected file already exists,
|
|
||||||
one more file with the same name will be created.
|
|
||||||
* Otherwise file will be overwritten.
|
|
||||||
* The filename must be either in the format 8+3 characters
|
|
||||||
(first 8 characters - name itself, last 3 - extension,
|
|
||||||
the short names and extensions are supplemented with spaces),
|
|
||||||
or in the format 8.3 characters "FILE.EXT"/"FILE.EX "
|
|
||||||
(name no more than 8 characters, dot, extension 3 characters
|
|
||||||
supplemented if necessary by spaces).
|
|
||||||
The filename must be written with capital letters. The terminating
|
|
||||||
character with code 0 is not necessary (not ASCIIZ-string).
|
|
||||||
* This function does not support folders on the ramdisk.
|
|
||||||
|
|
||||||
======================================================================
|
======================================================================
|
||||||
======= Function 35 - read the color of a pixel on the screen. =======
|
======= Function 35 - read the color of a pixel on the screen. =======
|
||||||
@ -3421,7 +3374,6 @@ Remarks:
|
|||||||
======================================================================
|
======================================================================
|
||||||
The input mode influences results of reading keys by function 2.
|
The input mode influences results of reading keys by function 2.
|
||||||
When a program loads, ASCII input mode is set for it.
|
When a program loads, ASCII input mode is set for it.
|
||||||
If subfunction is not support then eax=-1.
|
|
||||||
|
|
||||||
-------------- Subfunction 1 - set keyboard input mode. --------------
|
-------------- Subfunction 1 - set keyboard input mode. --------------
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -3773,6 +3725,58 @@ Remarks:
|
|||||||
* If ecx=0, the function frees memory block at edx and returns 0.
|
* If ecx=0, the function frees memory block at edx and returns 0.
|
||||||
* The contents of the block are unchanged up to the shorter of
|
* The contents of the block are unchanged up to the shorter of
|
||||||
the new and old sizes.
|
the new and old sizes.
|
||||||
|
======================================================================
|
||||||
|
======== Function 68, subfunction 22 - open named memory area. =======
|
||||||
|
======================================================================
|
||||||
|
Parameters:
|
||||||
|
* eax = 68 - function number
|
||||||
|
* ebx = 22 - subfunction number
|
||||||
|
* ecx = area name. Maximum of 31 characters with terminating zero
|
||||||
|
* edx = area size in bytes for SHM_CREATE and SHM_OPEN_ALWAYS
|
||||||
|
* esi = flags for open and access:
|
||||||
|
* SHM_OPEN = 0x00 - open existing memory area. If an area
|
||||||
|
with such name does not exist, the function
|
||||||
|
will return error code 5.
|
||||||
|
* SHM_OPEN_ALWAYS = 0x04 - open existing or create new
|
||||||
|
memory area.
|
||||||
|
* SHM_CREATE = 0x08 - create new memory area. If an area
|
||||||
|
with such name already exists, the function
|
||||||
|
will return error code 10.
|
||||||
|
* SHM_READ = 0x00 - only read access
|
||||||
|
* SHM_WRITE = 0x01 - read and write access
|
||||||
|
Returned value:
|
||||||
|
* eax = pointer to memory area, 0 if error has occured
|
||||||
|
* if new area is created (SHM_CREATE or SHM_OPEN_ALWAYS):
|
||||||
|
edx = 0 - success, otherwise - error code
|
||||||
|
* if existing area is opened (SHM_OPEN or SHM_OPEN_ALWAYS):
|
||||||
|
edx = error code (if eax=0) or area size in bytes
|
||||||
|
Error codes:
|
||||||
|
* E_NOTFOUND = 5
|
||||||
|
* E_ACCESS = 10
|
||||||
|
* E_NOMEM = 30
|
||||||
|
* E_PARAM = 33
|
||||||
|
Remarks:
|
||||||
|
* Before this call one must initialize process heap by call to
|
||||||
|
subfunction 11.
|
||||||
|
* If a new area is created, access flags set maximal rights
|
||||||
|
for other processes. An attempt from other process to open
|
||||||
|
with denied rights will fail with error code E_ACCESS.
|
||||||
|
* The process which has created an area always has write access.
|
||||||
|
|
||||||
|
======================================================================
|
||||||
|
======= Function 68, subfunction 23 - close named memory area. =======
|
||||||
|
======================================================================
|
||||||
|
Parameters:
|
||||||
|
* eax = 68 - function number
|
||||||
|
* ebx = 23 - subfunction number
|
||||||
|
* ecx = area name. Maximum of 31 characters with terminating zero
|
||||||
|
Returned value:
|
||||||
|
* eax destroyed
|
||||||
|
Remarks:
|
||||||
|
* A memory area is physically freed (with deleting all data and
|
||||||
|
freeing physical memory), when all threads which have opened
|
||||||
|
this area will close it.
|
||||||
|
* When thread is terminating, all opened by it areas are closed.
|
||||||
|
|
||||||
======================================================================
|
======================================================================
|
||||||
====== Function 68, subfunction 24 - set new exceptions handler ======
|
====== Function 68, subfunction 24 - set new exceptions handler ======
|
||||||
@ -3813,6 +3817,7 @@ Parameters:
|
|||||||
* edx = value of activity (0/1)
|
* edx = value of activity (0/1)
|
||||||
Returned value:
|
Returned value:
|
||||||
* eax = value of old activity for this signal (0/1)
|
* eax = value of old activity for this signal (0/1)
|
||||||
|
* eax = -1 - invalid signal number
|
||||||
Remarks:
|
Remarks:
|
||||||
* In current implementation, it is changed only exception mask for
|
* In current implementation, it is changed only exception mask for
|
||||||
user exception handler, wich was previously set by subfunction 24.
|
user exception handler, wich was previously set by subfunction 24.
|
||||||
@ -4111,6 +4116,10 @@ Examples:
|
|||||||
* '/hd0/2/menuet/pics/tanzania.bmp',0
|
* '/hd0/2/menuet/pics/tanzania.bmp',0
|
||||||
* '/hd0/1/Program files/NameOfProgram/SomeFile.SomeExtension',0
|
* '/hd0/1/Program files/NameOfProgram/SomeFile.SomeExtension',0
|
||||||
* '/sys/MySuperApp.ini',0
|
* '/sys/MySuperApp.ini',0
|
||||||
|
Also function supports relative names. If the path begins not
|
||||||
|
with '/', it is considered relative to a current folder. To get or
|
||||||
|
set a current folder, use the function 30.
|
||||||
|
|
||||||
Available subfunctions:
|
Available subfunctions:
|
||||||
* subfunction 0 - read file
|
* subfunction 0 - read file
|
||||||
* subfunction 1 - read folder
|
* subfunction 1 - read folder
|
||||||
|
@ -173,7 +173,6 @@ patch_AD:
|
|||||||
ret
|
ret
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
align 16
|
align 16
|
||||||
ac_unknown db 'unknown manufacturer',13,10,0
|
ac_unknown db 'unknown manufacturer',13,10,0
|
||||||
ac_Realtek db 'Realtek Semiconductor',13,10,0
|
ac_Realtek db 'Realtek Semiconductor',13,10,0
|
||||||
@ -181,6 +180,9 @@ ac_Analog db 'Analog Devices',13,10,0
|
|||||||
ac_CMedia db 'C-Media Electronics',13,10,0
|
ac_CMedia db 'C-Media Electronics',13,10,0
|
||||||
ac_Cirrus db 'Cirrus Logic',13,10,0
|
ac_Cirrus db 'Cirrus Logic',13,10,0
|
||||||
ac_Wolfson db 'Wolfson Microelectronics',13,10,0
|
ac_Wolfson db 'Wolfson Microelectronics',13,10,0
|
||||||
|
ac_VIA db 'VIA Technologies',13,10,0
|
||||||
|
ac_SigmaTel db 'SigmaTel',13,10,0
|
||||||
|
ac_eMicro db 'eMicro',13,10,0
|
||||||
|
|
||||||
chip_unknown db 'unknown codec id ', 0
|
chip_unknown db 'unknown codec id ', 0
|
||||||
|
|
||||||
@ -189,6 +191,9 @@ CHIP_REALTEK equ 0x414C4700
|
|||||||
CHIP_CMEDIA equ 0x434D4900
|
CHIP_CMEDIA equ 0x434D4900
|
||||||
CHIP_CIRRUS equ 0x43525900
|
CHIP_CIRRUS equ 0x43525900
|
||||||
CHIP_WOLFSON equ 0x574D4C00
|
CHIP_WOLFSON equ 0x574D4C00
|
||||||
|
CHIP_VIA equ 0x56494100
|
||||||
|
CHIP_SIGMATEL equ 0x83847600
|
||||||
|
CHIP_EMICRO equ 0x454D4300
|
||||||
|
|
||||||
align 16
|
align 16
|
||||||
codecs dd CHIP_ANALOG, ac_Analog, chips_Analog
|
codecs dd CHIP_ANALOG, ac_Analog, chips_Analog
|
||||||
@ -196,6 +201,9 @@ codecs dd CHIP_ANALOG, ac_Analog, chips_Analog
|
|||||||
dd CHIP_REALTEK,ac_Realtek, chips_Realtek
|
dd CHIP_REALTEK,ac_Realtek, chips_Realtek
|
||||||
dd CHIP_CIRRUS, ac_Cirrus, chips_Cirrus
|
dd CHIP_CIRRUS, ac_Cirrus, chips_Cirrus
|
||||||
dd CHIP_WOLFSON,ac_Wolfson, chips_Wolfson
|
dd CHIP_WOLFSON,ac_Wolfson, chips_Wolfson
|
||||||
|
dd CHIP_VIA, ac_VIA, chips_VIA
|
||||||
|
dd CHIP_SIGMATEL, ac_SigmaTel, chips_SigmaTel
|
||||||
|
dd CHIP_EMICRO, ac_eMicro, chips_eMicro
|
||||||
dd 0
|
dd 0
|
||||||
|
|
||||||
align 16
|
align 16
|
||||||
@ -207,6 +215,8 @@ chips_Analog dd 0x03, chip_AD1819
|
|||||||
dd 0x62, chip_AD1887
|
dd 0x62, chip_AD1887
|
||||||
dd 0x63, chip_AD1886A
|
dd 0x63, chip_AD1886A
|
||||||
dd 0x70, chip_AD1980
|
dd 0x70, chip_AD1980
|
||||||
|
dd 0x72, chip_AD1981A
|
||||||
|
dd 0x74, chip_AD1981B
|
||||||
dd 0x75, chip_AD1985
|
dd 0x75, chip_AD1985
|
||||||
dd 0xFF
|
dd 0xFF
|
||||||
|
|
||||||
@ -243,8 +253,17 @@ chips_Cirrus dd 0x00, chip_CS4297
|
|||||||
dd 0xFF
|
dd 0xFF
|
||||||
|
|
||||||
chips_Wolfson dd 0x00, chip_WM9700
|
chips_Wolfson dd 0x00, chip_WM9700
|
||||||
dd 0x03, chip_WM9703
|
dd 0x03, chip_WM9703
|
||||||
dd 0x04, chip_WM9704
|
dd 0x04, chip_WM9704
|
||||||
|
dd 0xFF
|
||||||
|
|
||||||
|
chips_VIA dd 0x61, chip_VIA1612A
|
||||||
|
dd 0xFF
|
||||||
|
|
||||||
|
chips_SigmaTel dd 0x58, chip_STAC9758
|
||||||
|
dd 0xFF
|
||||||
|
|
||||||
|
chips_eMicro dd 0x28, chip_EM28028
|
||||||
dd 0xFF
|
dd 0xFF
|
||||||
|
|
||||||
align 16
|
align 16
|
||||||
@ -258,6 +277,8 @@ chip_AD1886 db 'AD1886 ',0dh,0ah,00h
|
|||||||
chip_AD1886A db 'AD1886A',0dh,0ah,00h
|
chip_AD1886A db 'AD1886A',0dh,0ah,00h
|
||||||
chip_AD1887 db 'AD1887 ',0dh,0ah,00h
|
chip_AD1887 db 'AD1887 ',0dh,0ah,00h
|
||||||
chip_AD1980 db 'AD1980 ',0dh,0ah,00h
|
chip_AD1980 db 'AD1980 ',0dh,0ah,00h
|
||||||
|
chip_AD1981A db 'AD1981A',0dh,0ah,00h
|
||||||
|
chip_AD1981B db 'AD1981B',0dh,0ah,00h
|
||||||
chip_AD1985 db 'AD1985 ',0dh,0ah,00h
|
chip_AD1985 db 'AD1985 ',0dh,0ah,00h
|
||||||
|
|
||||||
;Realtek
|
;Realtek
|
||||||
@ -290,6 +311,16 @@ chip_CS4291 db 'CS4291',13,10,0
|
|||||||
chip_CS4202 db 'CS4202',13,10,0
|
chip_CS4202 db 'CS4202',13,10,0
|
||||||
|
|
||||||
;Wolfson
|
;Wolfson
|
||||||
chip_WM9700 db 'WM9704',13,10,0
|
chip_WM9700 db 'WM9704',13,10,0
|
||||||
chip_WM9703 db 'WM9703/9704',13,10,0
|
chip_WM9703 db 'WM9703/9704',13,10,0
|
||||||
chip_WM9704 db 'WM9704 (quad)',13,10,0
|
chip_WM9704 db 'WM9704 (quad)',13,10,0
|
||||||
|
|
||||||
|
;VIA
|
||||||
|
chip_VIA1612A db 'VIA1612A',13,10,0
|
||||||
|
|
||||||
|
;SigmaTel
|
||||||
|
chip_STAC9758 db 'STAC9758,59',13,10,0
|
||||||
|
|
||||||
|
;eMicro
|
||||||
|
chip_EM28028 db 'EM28028',13,10,0
|
||||||
|
|
||||||
|
1166
kernel/branches/Kolibri-A/trunk/drivers/emu10k1x.asm
Normal file
1166
kernel/branches/Kolibri-A/trunk/drivers/emu10k1x.asm
Normal file
File diff suppressed because it is too large
Load Diff
@ -26,6 +26,10 @@ kernel_export \
|
|||||||
FpuRestore,\
|
FpuRestore,\
|
||||||
ReservePortArea,\
|
ReservePortArea,\
|
||||||
Boot_Log,\
|
Boot_Log,\
|
||||||
|
\
|
||||||
|
MutexInit,\
|
||||||
|
MutexLock,\
|
||||||
|
MutexUnlock,\
|
||||||
\
|
\
|
||||||
PciApi,\
|
PciApi,\
|
||||||
PciRead32,\
|
PciRead32,\
|
||||||
|
@ -159,31 +159,44 @@ inp_size equ IOCTL.inp_size
|
|||||||
output equ IOCTL.output
|
output equ IOCTL.output
|
||||||
out_size equ IOCTL.out_size
|
out_size equ IOCTL.out_size
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
|
|
||||||
|
srv_calls dd service_proc.srv_getversion ; 0
|
||||||
|
dd service_proc.snd_create_buff ; 1
|
||||||
|
dd service_proc.snd_destroy_buff ; 2
|
||||||
|
dd service_proc.snd_setformat ; 3
|
||||||
|
dd service_proc.snd_getformat ; 4
|
||||||
|
dd service_proc.snd_reset ; 5
|
||||||
|
dd service_proc.snd_setpos ; 6
|
||||||
|
dd service_proc.snd_getpos ; 7
|
||||||
|
dd service_proc.snd_setbuff ; 8
|
||||||
|
dd service_proc.snd_out ; 9
|
||||||
|
dd service_proc.snd_play ; 10
|
||||||
|
dd service_proc.snd_stop ; 11
|
||||||
|
dd service_proc.snd_setvolume ; 12
|
||||||
|
dd service_proc.snd_getvolume ; 13
|
||||||
|
dd service_proc.snd_setpan ; 14
|
||||||
|
dd service_proc.snd_getpan ; 15
|
||||||
|
dd service_proc.snd_getbuffsize ; 16
|
||||||
|
dd service_proc.snd_getfreespace ; 17
|
||||||
|
dd service_proc.snd_settimebase ; 18
|
||||||
|
dd service_proc.snd_gettimestamp ; 19
|
||||||
|
srv_calls_end:
|
||||||
|
|
||||||
proc service_proc stdcall, ioctl:dword
|
proc service_proc stdcall, ioctl:dword
|
||||||
|
|
||||||
mov edi, [ioctl]
|
mov edi, [ioctl]
|
||||||
mov eax, [edi+io_code]
|
mov eax, [edi+io_code]
|
||||||
|
|
||||||
cmp eax, SRV_GETVERSION
|
cmp eax, (srv_calls_end-srv_calls)/4
|
||||||
jne @F
|
ja .fail
|
||||||
mov eax, [edi+output]
|
|
||||||
cmp [edi+out_size], 4
|
|
||||||
jne .fail
|
|
||||||
mov eax, [eax]
|
|
||||||
mov [eax], dword API_VERSION
|
|
||||||
xor eax, eax
|
|
||||||
ret
|
|
||||||
@@:
|
|
||||||
cmp eax, SND_CREATE_BUFF
|
cmp eax, SND_CREATE_BUFF
|
||||||
jne @F
|
ja @F
|
||||||
mov ebx, [edi+input]
|
|
||||||
stdcall CreateBuffer,[ebx],[ebx+4]
|
jmp [srv_calls+eax*4]
|
||||||
mov edi, [ioctl]
|
|
||||||
mov ecx, [edi+output]
|
|
||||||
mov ecx, [ecx]
|
|
||||||
mov [ecx], ebx
|
|
||||||
ret
|
|
||||||
@@:
|
@@:
|
||||||
mov ebx, [edi+input]
|
mov ebx, [edi+input]
|
||||||
mov edx, [ebx]
|
mov edx, [ebx]
|
||||||
@ -191,114 +204,132 @@ proc service_proc stdcall, ioctl:dword
|
|||||||
cmp [edx+STREAM.magic], 'WAVE'
|
cmp [edx+STREAM.magic], 'WAVE'
|
||||||
jne .fail
|
jne .fail
|
||||||
|
|
||||||
cmp [edx+STREAM.size], STREAM_SIZE
|
cmp [edx+STREAM.size], STREAM.sizeof
|
||||||
jne .fail
|
jne .fail
|
||||||
|
|
||||||
cmp eax, SND_DESTROY_BUFF
|
jmp [srv_calls+eax*4]
|
||||||
jne @F
|
.fail:
|
||||||
mov eax, edx
|
mov eax, -1
|
||||||
call DestroyBuffer ;edx= stream
|
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_SETFORMAT
|
|
||||||
jne @F
|
|
||||||
stdcall SetFormat,edx,[ebx+4]
|
|
||||||
ret
|
|
||||||
@@:
|
|
||||||
cmp eax, SND_GETFORMAT
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.srv_getversion:
|
||||||
|
mov eax, [edi+output]
|
||||||
|
cmp [edi+out_size], 4
|
||||||
|
jne .fail
|
||||||
|
mov eax, [eax]
|
||||||
|
mov [eax], dword API_VERSION
|
||||||
|
xor eax, eax
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_create_buff:
|
||||||
|
mov ebx, [edi+input]
|
||||||
|
stdcall CreateBuffer,[ebx],[ebx+4]
|
||||||
|
mov edi, [ioctl]
|
||||||
|
mov ecx, [edi+output]
|
||||||
|
mov ecx, [ecx]
|
||||||
|
mov [ecx], ebx
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_destroy_buff:
|
||||||
|
mov eax, edx
|
||||||
|
call DestroyBuffer
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_setformat:
|
||||||
|
stdcall SetFormat, edx,[ebx+4]
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_getformat:
|
||||||
movzx eax, word [edx+STREAM.format]
|
movzx eax, word [edx+STREAM.format]
|
||||||
mov ecx, [edi+output]
|
mov ecx, [edi+output]
|
||||||
mov ecx, [ecx]
|
mov ecx, [ecx]
|
||||||
mov [ecx], eax
|
mov [ecx], eax
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_RESET
|
align 4
|
||||||
jne @F
|
.snd_reset:
|
||||||
stdcall ResetBuffer,edx,[ebx+4]
|
stdcall ResetBuffer,edx,[ebx+4]
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_SETPOS
|
align 4
|
||||||
jne @F
|
.snd_setpos:
|
||||||
stdcall SetBufferPos,edx,[ebx+4]
|
stdcall SetBufferPos,edx,[ebx+4]
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_GETPOS
|
align 4
|
||||||
jne @F
|
.snd_getpos:
|
||||||
stdcall GetBufferPos, edx
|
stdcall GetBufferPos, edx
|
||||||
mov edi, [ioctl]
|
mov edi, [ioctl]
|
||||||
mov ecx, [edi+output]
|
mov ecx, [edi+output]
|
||||||
mov ecx, [ecx]
|
mov ecx, [ecx]
|
||||||
mov [ecx], ebx
|
mov [ecx], ebx
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_SETBUFF
|
align 4
|
||||||
jne @F
|
.snd_setbuff:
|
||||||
mov eax, [ebx+4]
|
mov eax, [ebx+4]
|
||||||
stdcall set_buffer, edx,eax,[ebx+8],[ebx+12]
|
stdcall set_buffer, edx,eax,[ebx+8],[ebx+12]
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_SETVOLUME
|
align 4
|
||||||
jne @F
|
.snd_out:
|
||||||
|
mov eax, [ebx+4]
|
||||||
|
stdcall wave_out, edx,eax,[ebx+8]
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_play:
|
||||||
|
stdcall play_buffer, edx,[ebx+4]
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_stop:
|
||||||
|
stdcall stop_buffer, edx
|
||||||
|
ret
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_setvolume:
|
||||||
stdcall SetBufferVol,edx,[ebx+4],[ebx+8]
|
stdcall SetBufferVol,edx,[ebx+4],[ebx+8]
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_GETVOLUME
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_getvolume:
|
||||||
mov eax, [edi+output]
|
mov eax, [edi+output]
|
||||||
mov ecx, [eax]
|
mov ecx, [eax]
|
||||||
mov eax, [eax+4]
|
mov eax, [eax+4]
|
||||||
stdcall GetBufferVol,edx,ecx,eax
|
stdcall GetBufferVol,edx,ecx,eax
|
||||||
ret
|
ret
|
||||||
@@:
|
align 4
|
||||||
cmp eax, SND_SETPAN
|
.snd_setpan:
|
||||||
jne @F
|
|
||||||
stdcall SetBufferPan,edx,[ebx+4]
|
stdcall SetBufferPan,edx,[ebx+4]
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_GETPAN
|
align 4
|
||||||
jne @F
|
.snd_getpan:
|
||||||
mov eax, [edx+STREAM.pan]
|
mov eax, [edx+STREAM.pan]
|
||||||
mov ebx, [edi+output]
|
mov ebx, [edi+output]
|
||||||
mov ebx, [ebx]
|
mov ebx, [ebx]
|
||||||
mov [ebx], eax
|
mov [ebx], eax
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_OUT
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
mov eax, [ebx+4]
|
align 4
|
||||||
stdcall wave_out, edx,eax,[ebx+8]
|
.snd_getbuffsize:
|
||||||
ret
|
|
||||||
@@:
|
|
||||||
cmp eax, SND_PLAY
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
stdcall play_buffer, edx,[ebx+4]
|
|
||||||
ret
|
|
||||||
@@:
|
|
||||||
cmp eax, SND_STOP
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
stdcall stop_buffer, edx
|
|
||||||
ret
|
|
||||||
@@:
|
|
||||||
cmp eax, SND_GETBUFFSIZE
|
|
||||||
jne @F
|
|
||||||
mov eax, [edx+STREAM.in_size]
|
mov eax, [edx+STREAM.in_size]
|
||||||
mov ecx, [edi+output]
|
mov ecx, [edi+output]
|
||||||
mov ecx, [ecx]
|
mov ecx, [ecx]
|
||||||
mov [ecx], eax
|
mov [ecx], eax
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
cmp eax, SND_GETFREESPACE
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
|
align 4
|
||||||
|
.snd_getfreespace:
|
||||||
test [edx+STREAM.format], PCM_OUT
|
test [edx+STREAM.format], PCM_OUT
|
||||||
jz .fail
|
jz .fail
|
||||||
|
|
||||||
@ -307,12 +338,38 @@ proc service_proc stdcall, ioctl:dword
|
|||||||
mov [ecx], ebx
|
mov [ecx], ebx
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
@@:
|
align 4
|
||||||
.fail:
|
.snd_settimebase:
|
||||||
or eax, -1
|
cmp [edi+inp_size], 8
|
||||||
|
jne .fail
|
||||||
|
|
||||||
|
mov edi, [edi+input]
|
||||||
|
mov eax, [edi]
|
||||||
|
mov ebx, [edi+4]
|
||||||
|
mov dword [edx+STREAM.time_base], eax
|
||||||
|
mov dword [edx+STREAM.time_base+4], ebx
|
||||||
|
xor eax, eax
|
||||||
|
ret
|
||||||
|
|
||||||
|
.snd_gettimestamp:
|
||||||
|
cmp [edi+out_size], 8
|
||||||
|
jne .fail
|
||||||
|
|
||||||
|
mov edi, [edi+output]
|
||||||
|
|
||||||
|
push 48
|
||||||
|
emms
|
||||||
|
fild qword [edx+STREAM.time_stamp]
|
||||||
|
fidiv dword [esp]
|
||||||
|
fadd qword [edx+STREAM.time_base]
|
||||||
|
fstp qword [edi]
|
||||||
|
add esp, 4
|
||||||
|
|
||||||
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
endp
|
endp
|
||||||
|
|
||||||
|
|
||||||
restore handle
|
restore handle
|
||||||
restore io_code
|
restore io_code
|
||||||
restore input
|
restore input
|
||||||
@ -352,7 +409,7 @@ proc CreateBuffer stdcall, format:dword, size:dword
|
|||||||
|
|
||||||
call GetPid
|
call GetPid
|
||||||
mov ebx, eax
|
mov ebx, eax
|
||||||
mov eax, STREAM_SIZE
|
mov eax, STREAM.sizeof
|
||||||
|
|
||||||
call CreateObject
|
call CreateObject
|
||||||
test eax, eax
|
test eax, eax
|
||||||
@ -412,7 +469,6 @@ proc CreateBuffer stdcall, format:dword, size:dword
|
|||||||
mov [edi+STREAM.in_base], eax
|
mov [edi+STREAM.in_base], eax
|
||||||
mov [edi+STREAM.in_size], ecx
|
mov [edi+STREAM.in_size], ecx
|
||||||
add eax, 128
|
add eax, 128
|
||||||
; sub ecx, 128
|
|
||||||
mov [edi+STREAM.in_wp], eax
|
mov [edi+STREAM.in_wp], eax
|
||||||
mov [edi+STREAM.in_rp], eax
|
mov [edi+STREAM.in_rp], eax
|
||||||
mov [edi+STREAM.in_count], 0
|
mov [edi+STREAM.in_count], 0
|
||||||
@ -443,13 +499,21 @@ proc CreateBuffer stdcall, format:dword, size:dword
|
|||||||
stdcall AllocKernelSpace, dword 128*1024
|
stdcall AllocKernelSpace, dword 128*1024
|
||||||
|
|
||||||
mov edi, [str]
|
mov edi, [str]
|
||||||
|
xor ebx, ebx
|
||||||
|
|
||||||
mov [edi+STREAM.out_base], eax
|
mov [edi+STREAM.out_base], eax
|
||||||
mov [edi+STREAM.out_wp], eax
|
mov [edi+STREAM.out_wp], eax
|
||||||
mov [edi+STREAM.out_rp], eax
|
mov [edi+STREAM.out_rp], eax
|
||||||
mov [edi+STREAM.out_count], 0
|
mov [edi+STREAM.out_count], ebx
|
||||||
add eax, 64*1024
|
add eax, 64*1024
|
||||||
mov [edi+STREAM.out_top], eax
|
mov [edi+STREAM.out_top], eax
|
||||||
|
|
||||||
|
mov dword [edi+STREAM.time_base], ebx
|
||||||
|
mov dword [edi+STREAM.time_base+4], ebx
|
||||||
|
|
||||||
|
mov dword [edi+STREAM.time_stamp], ebx
|
||||||
|
mov dword [edi+STREAM.time_stamp+4], ebx
|
||||||
|
|
||||||
stdcall AllocPages, dword 64/4
|
stdcall AllocPages, dword 64/4
|
||||||
mov edi, [str]
|
mov edi, [str]
|
||||||
mov ebx, [edi+STREAM.out_base]
|
mov ebx, [edi+STREAM.out_base]
|
||||||
@ -488,7 +552,7 @@ proc CreateBuffer stdcall, format:dword, size:dword
|
|||||||
|
|
||||||
mov [ebx+STREAM.magic], 'WAVE'
|
mov [ebx+STREAM.magic], 'WAVE'
|
||||||
mov [ebx+STREAM.destroy], DestroyBuffer.destroy
|
mov [ebx+STREAM.destroy], DestroyBuffer.destroy
|
||||||
mov [ebx+STREAM.size], STREAM_SIZE
|
mov [ebx+STREAM.size], STREAM.sizeof
|
||||||
mov [ebx+STREAM.flags], SND_STOP
|
mov [ebx+STREAM.flags], SND_STOP
|
||||||
|
|
||||||
pushf
|
pushf
|
||||||
@ -1039,7 +1103,7 @@ do_mix_list:
|
|||||||
cmp [ebx+STREAM.magic], 'WAVE'
|
cmp [ebx+STREAM.magic], 'WAVE'
|
||||||
jne .next
|
jne .next
|
||||||
|
|
||||||
cmp [ebx+STREAM.size], STREAM_SIZE
|
cmp [ebx+STREAM.size], STREAM.sizeof
|
||||||
jne .next
|
jne .next
|
||||||
|
|
||||||
cmp [ebx+STREAM.flags], SND_PLAY;
|
cmp [ebx+STREAM.flags], SND_PLAY;
|
||||||
@ -1108,7 +1172,7 @@ prepare_playlist:
|
|||||||
cmp [edi+STREAM.magic], 'WAVE'
|
cmp [edi+STREAM.magic], 'WAVE'
|
||||||
jne .next
|
jne .next
|
||||||
|
|
||||||
cmp [edi+STREAM.size], STREAM_SIZE
|
cmp [edi+STREAM.size], STREAM.sizeof
|
||||||
jne .next
|
jne .next
|
||||||
|
|
||||||
cmp [edi+STREAM.flags], SND_PLAY;
|
cmp [edi+STREAM.flags], SND_PLAY;
|
||||||
|
@ -91,6 +91,8 @@ SND_SETPAN equ 14
|
|||||||
SND_GETPAN equ 15
|
SND_GETPAN equ 15
|
||||||
SND_GETBUFFSIZE equ 16
|
SND_GETBUFFSIZE equ 16
|
||||||
SND_GETFREESPACE equ 17
|
SND_GETFREESPACE equ 17
|
||||||
|
SND_SETTIMEBASE equ 18
|
||||||
|
SND_GETTIMESTAMP equ 19
|
||||||
|
|
||||||
struc STREAM
|
struc STREAM
|
||||||
{
|
{
|
||||||
@ -113,6 +115,22 @@ struc STREAM
|
|||||||
.out_count dd ?
|
.out_count dd ?
|
||||||
.out_top dd ? ;16*4
|
.out_top dd ? ;16*4
|
||||||
|
|
||||||
|
.in_base dd ?
|
||||||
|
.in_size dd ?
|
||||||
|
.in_wp dd ?
|
||||||
|
.in_rp dd ?
|
||||||
|
.in_count dd ?
|
||||||
|
.in_free dd ?
|
||||||
|
.in_top dd ?
|
||||||
|
|
||||||
|
align 8
|
||||||
|
|
||||||
|
.time_base dq ?
|
||||||
|
.time_stamp dq ?
|
||||||
|
|
||||||
|
.notify_event dd ?
|
||||||
|
.notify_id dd ?
|
||||||
|
|
||||||
.r_size dd ?
|
.r_size dd ?
|
||||||
.r_dt dd ?
|
.r_dt dd ?
|
||||||
.r_silence dd ?
|
.r_silence dd ?
|
||||||
@ -125,19 +143,9 @@ struc STREAM
|
|||||||
.l_amp_f dd ? ;float point left
|
.l_amp_f dd ? ;float point left
|
||||||
.r_amp_f dd ? ;float point right
|
.r_amp_f dd ? ;float point right
|
||||||
|
|
||||||
.in_base dd ?
|
.sizeof:
|
||||||
.in_size dd ?
|
|
||||||
.in_wp dd ?
|
|
||||||
.in_rp dd ?
|
|
||||||
.in_count dd ?
|
|
||||||
.in_free dd ?
|
|
||||||
.in_top dd ?
|
|
||||||
|
|
||||||
.notify_event dd ?
|
|
||||||
.notify_id dd ?
|
|
||||||
}
|
}
|
||||||
|
|
||||||
STREAM_SIZE equ 36*4
|
|
||||||
FD_OFFSET equ 24
|
FD_OFFSET equ 24
|
||||||
|
|
||||||
virtual at 0
|
virtual at 0
|
||||||
|
@ -87,7 +87,7 @@ end if
|
|||||||
endp
|
endp
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
proc update_stream
|
proc update_streams
|
||||||
locals
|
locals
|
||||||
stream_index dd ?
|
stream_index dd ?
|
||||||
event rd 6
|
event rd 6
|
||||||
@ -98,6 +98,9 @@ proc update_stream
|
|||||||
mov edx, [stream_index]
|
mov edx, [stream_index]
|
||||||
mov esi, [play_list+edx*4]
|
mov esi, [play_list+edx*4]
|
||||||
|
|
||||||
|
add dword [esi+STREAM.time_stamp], 4096
|
||||||
|
adc dword [esi+STREAM.time_stamp+4], 0
|
||||||
|
|
||||||
mov eax, [esi+STREAM.out_rp]
|
mov eax, [esi+STREAM.out_rp]
|
||||||
cmp eax, [esi+STREAM.out_top]
|
cmp eax, [esi+STREAM.out_top]
|
||||||
jb @f
|
jb @f
|
||||||
|
1281
kernel/branches/Kolibri-A/trunk/drivers/vt823(x).asm
Normal file
1281
kernel/branches/Kolibri-A/trunk/drivers/vt823(x).asm
Normal file
File diff suppressed because it is too large
Load Diff
@ -795,7 +795,7 @@ biosdisk_enum_root:
|
|||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
.big:
|
.big:
|
||||||
push ecx
|
push ecx edx
|
||||||
push -'0'
|
push -'0'
|
||||||
mov ecx, 10
|
mov ecx, 10
|
||||||
@@:
|
@@:
|
||||||
@ -810,7 +810,7 @@ biosdisk_enum_root:
|
|||||||
add al, '0'
|
add al, '0'
|
||||||
stosb
|
stosb
|
||||||
jnz @b
|
jnz @b
|
||||||
pop ecx
|
pop edx ecx
|
||||||
pop eax
|
pop eax
|
||||||
inc eax
|
inc eax
|
||||||
ret
|
ret
|
||||||
|
@ -7,6 +7,13 @@
|
|||||||
|
|
||||||
$Revision$
|
$Revision$
|
||||||
|
|
||||||
|
WINDOW_MOVE_AND_RESIZE_FLAGS = \
|
||||||
|
mouse.WINDOW_RESIZE_N_FLAG + \
|
||||||
|
mouse.WINDOW_RESIZE_W_FLAG + \
|
||||||
|
mouse.WINDOW_RESIZE_S_FLAG + \
|
||||||
|
mouse.WINDOW_RESIZE_E_FLAG + \
|
||||||
|
mouse.WINDOW_MOVE_FLAG
|
||||||
|
|
||||||
uglobal
|
uglobal
|
||||||
align 4
|
align 4
|
||||||
event_start dd ?
|
event_start dd ?
|
||||||
@ -445,7 +452,7 @@ get_event_for_app: ;; used from f10,f11,f23
|
|||||||
xor eax,eax
|
xor eax,eax
|
||||||
ret
|
ret
|
||||||
.IRQ:
|
.IRQ:
|
||||||
;TODO: ñäåëàòü òàê æå, êàê è äëÿ FlagAutoReset (BgrRedraw,Mouse,IPC,Stack,Debug)
|
;TODO: same thing as done for FlagAutoReset (BgrRedraw,Mouse,IPC,Stack,Debug)
|
||||||
mov edx,[irq_owner+eax*4-64] ; eax==16+irq
|
mov edx,[irq_owner+eax*4-64] ; eax==16+irq
|
||||||
cmp edx,[edi+TASKDATA.pid]
|
cmp edx,[edi+TASKDATA.pid]
|
||||||
jne .loop
|
jne .loop
|
||||||
@ -460,8 +467,9 @@ get_event_for_app: ;; used from f10,f11,f23
|
|||||||
push eax
|
push eax
|
||||||
; If the window is captured and moved by the user, then no mouse events!!!
|
; If the window is captured and moved by the user, then no mouse events!!!
|
||||||
mov al, [mouse.active_sys_window.action]
|
mov al, [mouse.active_sys_window.action]
|
||||||
test al, mouse.WINDOW_MOVE_FLAG
|
and al, WINDOW_MOVE_AND_RESIZE_FLAGS
|
||||||
pop eax
|
test al, al
|
||||||
|
pop eax
|
||||||
jnz .loop
|
jnz .loop
|
||||||
@@:
|
@@:
|
||||||
btr [ebx+APPDATA.event_mask],eax
|
btr [ebx+APPDATA.event_mask],eax
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
;; ;;
|
;; ;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
$Revision: -1 $
|
$Revision: 1532$
|
||||||
|
|
||||||
include 'mousepointer.inc'
|
include 'mousepointer.inc'
|
||||||
|
|
||||||
|
@ -319,6 +319,9 @@ syscall_move_window: ;///// system function 67 ////////////////////////////////
|
|||||||
shl edi, 5
|
shl edi, 5
|
||||||
add edi, window_data
|
add edi, window_data
|
||||||
|
|
||||||
|
test [edi + WDATA.fl_wdrawn], 1
|
||||||
|
jz .exit
|
||||||
|
|
||||||
test [edi + WDATA.fl_wstate], WSTATE_MAXIMIZED
|
test [edi + WDATA.fl_wstate], WSTATE_MAXIMIZED
|
||||||
jnz .exit
|
jnz .exit
|
||||||
|
|
||||||
@ -392,6 +395,7 @@ set_window_defaults: ;/////////////////////////////////////////////////////////
|
|||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
;? <description>
|
;? <description>
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
|
mov byte [window_data + 0x20 + WDATA.cl_titlebar + 3], 1 ; desktop is not movable
|
||||||
push eax ecx
|
push eax ecx
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
mov ecx, WIN_STACK
|
mov ecx, WIN_STACK
|
||||||
@ -1036,10 +1040,10 @@ sys_window_maximize_handler: ;/////////////////////////////////////////////////
|
|||||||
add edi, window_data
|
add edi, window_data
|
||||||
|
|
||||||
; can window change its height?
|
; can window change its height?
|
||||||
|
; only types 2 and 3 can be resized
|
||||||
mov dl, [edi + WDATA.fl_wstyle]
|
mov dl, [edi + WDATA.fl_wstyle]
|
||||||
and dl, 0x0f
|
test dl, 2
|
||||||
cmp dl, 0x04
|
jz .exit
|
||||||
je .exit
|
|
||||||
|
|
||||||
; toggle normal/maximized window state
|
; toggle normal/maximized window state
|
||||||
mov bl, [edi + WDATA.fl_wstate]
|
mov bl, [edi + WDATA.fl_wstate]
|
||||||
@ -1222,30 +1226,33 @@ window._.invalidate_screen: ;//////////////////////////////////////////////////
|
|||||||
push eax ebx
|
push eax ebx
|
||||||
|
|
||||||
; TODO: do we really need `draw_limits`?
|
; TODO: do we really need `draw_limits`?
|
||||||
|
; Yes, they are used by background drawing code.
|
||||||
mov ecx, [eax + BOX.left]
|
mov ecx, [eax + BOX.left]
|
||||||
mov edx, [ebx + BOX.left]
|
mov edx, [ebx + BOX.left]
|
||||||
cmp ecx, edx
|
cmp ecx, edx
|
||||||
jle @f
|
jle @f
|
||||||
xchg ecx, edx
|
mov ecx, edx
|
||||||
@@: mov [draw_limits.left], ecx
|
@@: mov [draw_limits.left], ecx
|
||||||
mov ecx, [eax + BOX.width]
|
mov ecx, [eax + BOX.left]
|
||||||
cmp ecx, [ebx + BOX.width]
|
add ecx, [eax + BOX.width]
|
||||||
|
add edx, [ebx + BOX.width]
|
||||||
|
cmp ecx, edx
|
||||||
jae @f
|
jae @f
|
||||||
mov ecx, [ebx + BOX.width]
|
mov ecx, edx
|
||||||
@@: add ecx, edx
|
@@: mov [draw_limits.right], ecx
|
||||||
mov [draw_limits.right], ecx
|
|
||||||
mov ecx, [eax + BOX.top]
|
mov ecx, [eax + BOX.top]
|
||||||
mov edx, [ebx + BOX.top]
|
mov edx, [ebx + BOX.top]
|
||||||
cmp ecx, edx
|
cmp ecx, edx
|
||||||
jle @f
|
jle @f
|
||||||
xchg ecx, edx
|
mov ecx, edx
|
||||||
@@: mov [draw_limits.top], ecx
|
@@: mov [draw_limits.top], ecx
|
||||||
mov ecx, [eax + BOX.height]
|
mov ecx, [eax + BOX.top]
|
||||||
cmp ecx, [ebx + BOX.height]
|
add ecx, [eax + BOX.height]
|
||||||
|
add edx, [ebx + BOX.height]
|
||||||
|
cmp ecx, edx
|
||||||
jae @f
|
jae @f
|
||||||
mov ecx, [ebx + BOX.height]
|
mov ecx, edx
|
||||||
@@: add ecx, edx
|
@@: mov [draw_limits.bottom], ecx
|
||||||
mov [draw_limits.bottom], ecx
|
|
||||||
|
|
||||||
; recalculate screen buffer at old position
|
; recalculate screen buffer at old position
|
||||||
push ebx
|
push ebx
|
||||||
@ -1433,6 +1440,7 @@ window._.sys_set_window: ;/////////////////////////////////////////////////////
|
|||||||
; was it already defined before?
|
; was it already defined before?
|
||||||
test [edi + WDATA.fl_wdrawn], 1
|
test [edi + WDATA.fl_wdrawn], 1
|
||||||
jnz .set_client_box
|
jnz .set_client_box
|
||||||
|
or [edi + WDATA.fl_wdrawn], 1
|
||||||
|
|
||||||
; NOTE: commented out since doesn't provide necessary functionality
|
; NOTE: commented out since doesn't provide necessary functionality
|
||||||
; anyway, to be reworked
|
; anyway, to be reworked
|
||||||
|
@ -177,6 +177,7 @@ irq1:
|
|||||||
mov eax,VKEY_SCRLOCK
|
mov eax,VKEY_SCRLOCK
|
||||||
jmp .no_key.xor
|
jmp .no_key.xor
|
||||||
@@:
|
@@:
|
||||||
|
xor ebx, ebx
|
||||||
test ch,ch
|
test ch,ch
|
||||||
js .writekey
|
js .writekey
|
||||||
movzx eax,ch ; plain key
|
movzx eax,ch ; plain key
|
||||||
@ -200,7 +201,6 @@ irq1:
|
|||||||
jz @f
|
jz @f
|
||||||
mov bl,[keymap_alt+eax]
|
mov bl,[keymap_alt+eax]
|
||||||
@@:
|
@@:
|
||||||
mov bh, 0
|
|
||||||
jmp .writekey
|
jmp .writekey
|
||||||
.modifier:
|
.modifier:
|
||||||
test ch, ch
|
test ch, ch
|
||||||
|
@ -553,6 +553,13 @@ v20ga32:
|
|||||||
mov al, 0x3F
|
mov al, 0x3F
|
||||||
out 0xA1, al
|
out 0xA1, al
|
||||||
|
|
||||||
|
; Enable interrupts in IDE controller
|
||||||
|
mov al, 0
|
||||||
|
mov dx, 0x3F6
|
||||||
|
out dx, al
|
||||||
|
mov dl, 0x76
|
||||||
|
out dx, al
|
||||||
|
|
||||||
;!!!!!!!!!!!!!!!!!!!!!!!!!!
|
;!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
include 'detect/disks.inc'
|
include 'detect/disks.inc'
|
||||||
;!!!!!!!!!!!!!!!!!!!!!!!!!!
|
;!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
@ -2048,10 +2055,13 @@ sysfn_mouse_acceleration: ; 18.19 = set/get mouse features
|
|||||||
; cmp ecx,4 ; set mouse pointer position
|
; cmp ecx,4 ; set mouse pointer position
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .set_mouse_button
|
jnz .set_mouse_button
|
||||||
mov [MOUSE_Y],dx ;y
|
cmp dx, word[Screen_Max_Y]
|
||||||
ror edx,16
|
ja .end
|
||||||
mov [MOUSE_X],dx ;x
|
|
||||||
rol edx,16
|
rol edx,16
|
||||||
|
cmp dx, word[Screen_Max_X]
|
||||||
|
ja .end
|
||||||
|
mov [MOUSE_X], edx
|
||||||
ret
|
ret
|
||||||
.set_mouse_button:
|
.set_mouse_button:
|
||||||
; cmp ecx,5 ; set mouse button features
|
; cmp ecx,5 ; set mouse button features
|
||||||
@ -2124,15 +2134,11 @@ endg
|
|||||||
iglobal
|
iglobal
|
||||||
version_inf:
|
version_inf:
|
||||||
db 0,7,7,0 ; version 0.7.7.0
|
db 0,7,7,0 ; version 0.7.7.0
|
||||||
db UID_KOLIBRI
|
db 0 ;reserved
|
||||||
dd __REV__
|
dd __REV__
|
||||||
version_end:
|
version_end:
|
||||||
endg
|
endg
|
||||||
|
|
||||||
UID_NONE=0
|
|
||||||
UID_MENUETOS=1 ;official
|
|
||||||
UID_KOLIBRI=2 ;russian
|
|
||||||
|
|
||||||
sys_cachetodiskette:
|
sys_cachetodiskette:
|
||||||
cmp ebx, 1
|
cmp ebx, 1
|
||||||
jne .no_floppy_a_save
|
jne .no_floppy_a_save
|
||||||
@ -2588,6 +2594,10 @@ sys_cpuusage:
|
|||||||
mov al, [ecx+window_data+WDATA.fl_wstate]
|
mov al, [ecx+window_data+WDATA.fl_wstate]
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
|
; Event mask (+71)
|
||||||
|
mov EAX, dword [ECX+CURRENT_TASK+TASKDATA.event_mask]
|
||||||
|
stosd
|
||||||
|
|
||||||
pop esi
|
pop esi
|
||||||
pop edi
|
pop edi
|
||||||
|
|
||||||
@ -2720,11 +2730,6 @@ sys_redrawstat:
|
|||||||
mov eax, [Screen_Max_Y]
|
mov eax, [Screen_Max_Y]
|
||||||
mov [edx + RECT.bottom], eax
|
mov [edx + RECT.bottom], eax
|
||||||
|
|
||||||
mov edi, [TASK_BASE]
|
|
||||||
or [edi - twdw + WDATA.fl_wdrawn], 1 ; no new position & buttons from app
|
|
||||||
call sys_window_mouse
|
|
||||||
ret
|
|
||||||
|
|
||||||
srl1:
|
srl1:
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user