2006-09-07 18:14:53 +04:00
|
|
|
format ELF
|
2006-09-23 18:00:36 +04:00
|
|
|
include "public_stdcall.inc"
|
2006-09-07 18:14:53 +04:00
|
|
|
section '.text' executable
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_get_pci_version,0
|
2006-09-07 18:14:53 +04:00
|
|
|
mov edx,ebx
|
|
|
|
mov eax,62
|
|
|
|
xor ebx,ebx
|
|
|
|
int 0x40
|
|
|
|
movzx eax,ax
|
|
|
|
mov ebx,edx
|
|
|
|
ret
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_get_last_pci_bus,0
|
2006-09-07 18:14:53 +04:00
|
|
|
mov edx,ebx
|
|
|
|
mov eax,62
|
|
|
|
xor ebx,ebx
|
|
|
|
inc ebx
|
|
|
|
int 0x40
|
|
|
|
movzx eax,al
|
|
|
|
mov ebx,edx
|
|
|
|
ret
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_get_pci_access_mechanism,0
|
2006-09-07 18:14:53 +04:00
|
|
|
mov edx,ebx
|
|
|
|
mov eax,62
|
|
|
|
mov ebx,2
|
|
|
|
int 0x40
|
|
|
|
movzx eax,al
|
|
|
|
mov ebx,edx
|
|
|
|
ret
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_pci_read_config_byte,16
|
2006-09-07 18:14:53 +04:00
|
|
|
;arg1 - bus
|
|
|
|
;arg2 - dev
|
|
|
|
;arg3 - fn
|
|
|
|
;arg4 - reg
|
|
|
|
mov edx,ebx
|
|
|
|
mov eax,62
|
|
|
|
mov bl,4
|
|
|
|
mov bh,[esp+4]
|
|
|
|
mov ch,[esp+8]
|
|
|
|
shl ch,3
|
|
|
|
add ch,[esp+12]
|
|
|
|
mov cl,[esp+16]
|
|
|
|
int 0x40
|
|
|
|
mov ebx,edx
|
|
|
|
ret 16
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_pci_read_config_word,16
|
2006-09-07 18:14:53 +04:00
|
|
|
;arg1 - bus
|
|
|
|
;arg2 - dev
|
|
|
|
;arg3 - fn
|
|
|
|
;arg4 - reg
|
|
|
|
mov edx,ebx
|
|
|
|
mov eax,62
|
|
|
|
mov bl,5
|
|
|
|
mov bh,[esp+4]
|
|
|
|
mov ch,[esp+8]
|
|
|
|
shl ch,3
|
|
|
|
add ch,[esp+12]
|
|
|
|
mov cl,[esp+16]
|
|
|
|
int 0x40
|
|
|
|
mov ebx,edx
|
|
|
|
ret 16
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_pci_read_config_dword,16
|
2006-09-07 18:14:53 +04:00
|
|
|
;arg1 - bus
|
|
|
|
;arg2 - dev
|
|
|
|
;arg3 - fn
|
|
|
|
;arg4 - reg
|
|
|
|
mov edx,ebx
|
|
|
|
mov eax,62
|
|
|
|
mov bl,6
|
|
|
|
mov bh,[esp+4]
|
|
|
|
mov ch,[esp+8]
|
|
|
|
shl ch,3
|
|
|
|
add ch,[esp+12]
|
|
|
|
mov cl,[esp+16]
|
|
|
|
int 0x40
|
|
|
|
mov ebx,edx
|
|
|
|
ret 16
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_pci_write_config_byte,20
|
2006-09-07 18:14:53 +04:00
|
|
|
;arg1 - bus
|
|
|
|
;arg2 - dev
|
|
|
|
;arg3 - fn
|
|
|
|
;arg4 - reg
|
|
|
|
;arg5 - value
|
|
|
|
push ebx
|
|
|
|
mov eax,62
|
|
|
|
mov bl,8
|
|
|
|
mov bh,[esp+8]
|
|
|
|
mov ch,[esp+12]
|
|
|
|
shl ch,3
|
|
|
|
mov ch,[esp+16]
|
|
|
|
mov cl,[esp+20]
|
|
|
|
movzx edx,byte [esp+24]
|
|
|
|
int 0x40
|
|
|
|
pop ebx
|
|
|
|
ret 20
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_pci_write_config_word,20
|
2006-09-07 18:14:53 +04:00
|
|
|
;arg1 - bus
|
|
|
|
;arg2 - dev
|
|
|
|
;arg3 - fn
|
|
|
|
;arg4 - reg
|
|
|
|
;arg5 - value
|
|
|
|
push ebx
|
|
|
|
mov eax,62
|
|
|
|
mov bl,9
|
|
|
|
mov bh,[esp+8]
|
|
|
|
mov ch,[esp+12]
|
|
|
|
shl ch,3
|
|
|
|
mov ch,[esp+16]
|
|
|
|
mov cl,[esp+20]
|
|
|
|
movzx edx,word [esp+24]
|
|
|
|
int 0x40
|
|
|
|
pop ebx
|
|
|
|
ret 20
|
|
|
|
|
2007-10-15 13:42:17 +04:00
|
|
|
public_stdcall _ksys_pci_write_config_dword,20
|
2006-09-07 18:14:53 +04:00
|
|
|
;arg1 - bus
|
|
|
|
;arg2 - dev
|
|
|
|
;arg3 - fn
|
|
|
|
;arg4 - reg
|
|
|
|
;arg5 - value
|
|
|
|
push ebx
|
|
|
|
mov eax,62
|
|
|
|
mov bl,10
|
|
|
|
mov bh,[esp+8]
|
|
|
|
mov ch,[esp+12]
|
|
|
|
shl ch,3
|
|
|
|
mov ch,[esp+16]
|
|
|
|
mov cl,[esp+20]
|
|
|
|
mov edx,[esp+24]
|
|
|
|
int 0x40
|
|
|
|
pop ebx
|
|
|
|
ret 20
|