forked from KolibriOS/kolibrios
fixed
* Same little bugs * Source code formating * PCI version normalized 0210 -> 2.10 added * + 13 vendor (total now 1000!) * + 3 class type * Fast call source ready * Device IRQ detection optimized * ! size optimized (61025 -> 32501 see added) * easy to add new vendor & class names git-svn-id: svn://kolibrios.org@475 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
06a1a8f6a3
commit
0169b4ea01
File diff suppressed because it is too large
Load Diff
@ -1,3 +1,44 @@
|
|||||||
|
|
||||||
|
;~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-
|
||||||
|
macro iglobal {
|
||||||
|
IGlobals equ IGlobals,
|
||||||
|
macro __IGlobalBlock { }
|
||||||
|
|
||||||
|
macro uglobal {
|
||||||
|
UGlobals equ UGlobals,
|
||||||
|
macro __UGlobalBlock { }
|
||||||
|
|
||||||
|
endg fix } ; Use endg for ending iglobal and uglobal blocks.
|
||||||
|
|
||||||
|
|
||||||
|
macro IncludeIGlobals{
|
||||||
|
macro IGlobals dummy,[n] \{ __IGlobalBlock
|
||||||
|
purge __IGlobalBlock \}
|
||||||
|
match I, IGlobals \{ I \} }
|
||||||
|
|
||||||
|
macro IncludeUGlobals{
|
||||||
|
macro UGlobals dummy,[n] \{
|
||||||
|
\common
|
||||||
|
\local begin, size
|
||||||
|
begin = $
|
||||||
|
virtual at $
|
||||||
|
\forward
|
||||||
|
__UGlobalBlock
|
||||||
|
purge __UGlobalBlock
|
||||||
|
\common
|
||||||
|
size = $ - begin
|
||||||
|
end virtual
|
||||||
|
rb size
|
||||||
|
\}
|
||||||
|
match U, UGlobals \{ U \} }
|
||||||
|
|
||||||
|
uglobal
|
||||||
|
endg
|
||||||
|
|
||||||
|
iglobal
|
||||||
|
endg
|
||||||
|
|
||||||
|
;~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-
|
||||||
; new application structure
|
; new application structure
|
||||||
macro meos_app_start
|
macro meos_app_start
|
||||||
{
|
{
|
||||||
@ -30,6 +71,7 @@ CODE fix code
|
|||||||
macro data
|
macro data
|
||||||
{
|
{
|
||||||
__data:
|
__data:
|
||||||
|
IncludeIGlobals
|
||||||
}
|
}
|
||||||
DATA fix data
|
DATA fix data
|
||||||
|
|
||||||
@ -44,6 +86,7 @@ macro udata
|
|||||||
__end:
|
__end:
|
||||||
end if
|
end if
|
||||||
__udata:
|
__udata:
|
||||||
|
IncludeUGlobals
|
||||||
}
|
}
|
||||||
UDATA fix udata
|
UDATA fix udata
|
||||||
|
|
||||||
@ -72,6 +115,22 @@ struc mstr [sstring]
|
|||||||
dd -1
|
dd -1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; macro for defining multiline text data
|
||||||
|
struc mls [sstring] {
|
||||||
|
forward
|
||||||
|
local ssize
|
||||||
|
virtual at 0
|
||||||
|
db sstring ; mod
|
||||||
|
ssize = $
|
||||||
|
end virtual
|
||||||
|
db ssize
|
||||||
|
db sstring
|
||||||
|
common
|
||||||
|
|
||||||
|
db -1 ; mod
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; strings
|
; strings
|
||||||
macro sz name,[data] { ; from MFAR [mike.dld]
|
macro sz name,[data] { ; from MFAR [mike.dld]
|
||||||
@ -131,18 +190,46 @@ macro __mov reg,a,b { ; mike.dld
|
|||||||
end if
|
end if
|
||||||
}
|
}
|
||||||
|
|
||||||
macro mcall a,b,c,d,e,f { ; mike.dld
|
__CPU_type equ p5
|
||||||
|
SYSENTER_VAR equ 0
|
||||||
|
|
||||||
|
macro mcall a,b,c,d,e,f { ; mike.dld, updated by Ghost for Fast System Calls
|
||||||
|
local ..ret_point
|
||||||
__mov eax,a
|
__mov eax,a
|
||||||
__mov ebx,b
|
__mov ebx,b
|
||||||
__mov ecx,c
|
__mov ecx,c
|
||||||
__mov edx,d
|
__mov edx,d
|
||||||
__mov esi,e
|
__mov esi,e
|
||||||
__mov edi,f
|
__mov edi,f
|
||||||
|
|
||||||
|
if __CPU_type eq p5
|
||||||
int 0x40
|
int 0x40
|
||||||
|
else
|
||||||
|
if __CPU_type eq p6
|
||||||
|
push ebp
|
||||||
|
mov ebp, esp
|
||||||
|
push ..ret_point ; it may be 2 or 5 byte
|
||||||
|
sysenter
|
||||||
|
..ret_point:
|
||||||
|
pop edx
|
||||||
|
pop ecx
|
||||||
|
|
||||||
|
else
|
||||||
|
if __CPU_type eq k6
|
||||||
|
push ecx
|
||||||
|
syscall
|
||||||
|
pop ecx
|
||||||
|
else
|
||||||
|
display 'ERROR : unknown CPU type'
|
||||||
|
int 0x40
|
||||||
|
end if
|
||||||
|
end if
|
||||||
|
end if
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; optimize the code for size
|
; optimize the code for size
|
||||||
__regs fix <eax,ebx,ecx,edx,esi,edi,ebp,esp>
|
__regs fix <eax,ebx,ecx,edx,esi,edi,ebp,esp>
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user