forked from KolibriOS/kolibrios
Converted unfinished cardbus and AGP drivers to PE, moved to drivers/unfinished
git-svn-id: svn://kolibrios.org@5066 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
5c90aa59dc
commit
24547ca793
@ -10,39 +10,94 @@
|
|||||||
|
|
||||||
struct PCI_header
|
struct PCI_header
|
||||||
|
|
||||||
vendor_id dw ?
|
vendor_id dw ? ; 0x00
|
||||||
device_id dw ?
|
device_id dw ? ; 0x02
|
||||||
command dw ?
|
command dw ? ; 0x04
|
||||||
status dw ?
|
status dw ? ; 0x06
|
||||||
revision_id db ?
|
revision_id db ? ; 0x08
|
||||||
prog_if db ?
|
prog_if db ? ; 0x09
|
||||||
subclass db ?
|
subclass db ? ; 0x0A
|
||||||
class_code db ?
|
class_code db ? ; 0x0B
|
||||||
cache_line_size db ?
|
cache_line_size db ? ; 0x0C
|
||||||
latency_timer db ?
|
latency_timer db ? ; 0x0D
|
||||||
header_type db ?
|
header_type db ? ; 0x0E
|
||||||
bist db ?
|
bist db ? ; 0x0F
|
||||||
|
|
||||||
ends
|
ends
|
||||||
|
|
||||||
struct PCI_header00 PCI_header
|
struct PCI_header00 PCI_header
|
||||||
|
|
||||||
base_addr_0 dd ?
|
base_addr_0 dd ? ; 0x10
|
||||||
base_addr_1 dd ?
|
base_addr_1 dd ? ; 0x14
|
||||||
base_addr_2 dd ?
|
base_addr_2 dd ? ; 0x18
|
||||||
base_addr_3 dd ?
|
base_addr_3 dd ? ; 0x1C
|
||||||
base_addr_4 dd ?
|
base_addr_4 dd ? ; 0x20
|
||||||
base_addr_5 dd ?
|
base_addr_5 dd ? ; 0x24
|
||||||
cardbus_cis_ptr dd ?
|
cardbus_cis_ptr dd ? ; 0x28
|
||||||
subsys_vendor dw ?
|
subsys_vendor dw ? ; 0x2C
|
||||||
subsys_id dw ?
|
subsys_id dw ? ; 0x2E
|
||||||
exp_rom_addr dd ?
|
exp_rom_addr dd ? ; 0x30
|
||||||
cap_ptr db ?
|
cap_ptr db ? ; 0x34
|
||||||
reserved rb 7
|
rb 7 ; reserved
|
||||||
interrupt_line db ?
|
interrupt_line db ? ; 0x3C
|
||||||
interrupt_pin db ?
|
interrupt_pin db ? ; 0x3D
|
||||||
min_grant db ?
|
min_grant db ? ; 0x3E
|
||||||
max_latency db ?
|
max_latency db ? ; 0x3F
|
||||||
|
|
||||||
|
ends
|
||||||
|
|
||||||
|
struct PCI_header01 PCI_header
|
||||||
|
|
||||||
|
base_addr_0 dd ? ; 0x10
|
||||||
|
base_addr_1 dd ? ; 0x14
|
||||||
|
prim_bus_nr db ? ; 0x18
|
||||||
|
sec_bus_nr db ? ; 0x19
|
||||||
|
sub_bus_nr db ? ; 0x1A
|
||||||
|
sec_lat_tmr db ? ; 0x1B
|
||||||
|
io_base db ? ; 0x1C
|
||||||
|
io_limit db ? ; 0x1D
|
||||||
|
sec_status dw ? ; 0x1E
|
||||||
|
mem_base dw ? ; 0x20
|
||||||
|
mem_limit dw ? ; 0x22
|
||||||
|
pref_mem_base dw ? ; 0x24
|
||||||
|
pref_mem_limit dw ? ; 0x26
|
||||||
|
pref_base_up dd ? ; 0x28
|
||||||
|
pref_limit_up dd ? ; 0x2C
|
||||||
|
io_base_up dw ? ; 0x30
|
||||||
|
io_limit_up dw ? ; 0x32
|
||||||
|
cap_ptr db ? ; 0x34
|
||||||
|
rb 3 ; reserved
|
||||||
|
exp_rom_addr dd ? ; 0x38
|
||||||
|
interrupt_line db ? ; 0x3C
|
||||||
|
interrupt_pin db ? ; 0x3E
|
||||||
|
bridge_ctrl dw ? ; 0x3F
|
||||||
|
|
||||||
|
ends
|
||||||
|
|
||||||
|
struct PCI_header02 PCI_header
|
||||||
|
|
||||||
|
base_addr dd ? ; 0x10
|
||||||
|
cap_list_offs db ? ; 0x14
|
||||||
|
rb 1 ; reserved
|
||||||
|
sec_stat dw ? ; 0x16
|
||||||
|
pci_bus_nr db ? ; 0x18
|
||||||
|
cardbus_bus_nr db ? ; 0x19
|
||||||
|
sub_bus_nr db ? ; 0x1A
|
||||||
|
cardbus_lat_tmr db ? ; 0x1B
|
||||||
|
mbar_0 dd ? ; 0x1C
|
||||||
|
mlimit_0 dd ? ; 0x20
|
||||||
|
mbar_1 dd ? ; 0x24
|
||||||
|
mlimit_1 dd ? ; 0x28
|
||||||
|
iobar_0 dd ? ; 0x2C
|
||||||
|
iolimit_0 dd ? ; 0x30
|
||||||
|
iobar_1 dd ? ; 0x34
|
||||||
|
iolimit_1 dd ? ; 0x38
|
||||||
|
interrupt_line db ? ; 0x3C
|
||||||
|
interrupt_pin db ? ; 0x3D
|
||||||
|
bridge_ctrl dw ? ; 0x3E
|
||||||
|
subs_did dw ? ; 0x40
|
||||||
|
subs_vid dw ? ; 0x42
|
||||||
|
legacy_bar dd ? ; 0x44
|
||||||
|
|
||||||
ends
|
ends
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;; ;;
|
;; ;;
|
||||||
;; Copyright (C) KolibriOS team 2004-2012. All rights reserved. ;;
|
;; Copyright (C) KolibriOS team 2004-2014. All rights reserved. ;;
|
||||||
;; Distributed under terms of the GNU General Public License ;;
|
;; Distributed under terms of the GNU General Public License ;;
|
||||||
;; ;;
|
;; ;;
|
||||||
;; simple AGP driver for KolibriOS ;;
|
;; simple AGP driver for KolibriOS ;;
|
||||||
@ -13,99 +13,78 @@
|
|||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
|
|
||||||
format MS COFF
|
format PE DLL native
|
||||||
|
entry START
|
||||||
|
|
||||||
DEBUG equ 1
|
CURRENT_API = 0x0200
|
||||||
FAST_WRITE equ 0 ; may cause problems with some motherboards
|
COMPATIBLE_API = 0x0100
|
||||||
|
API_VERSION = (COMPATIBLE_API shl 16) + CURRENT_API
|
||||||
|
|
||||||
include 'proc32.inc'
|
FAST_WRITE = 0 ; may cause problems with some motherboards
|
||||||
include 'imports.inc'
|
|
||||||
|
|
||||||
struc IOCTL
|
section '.flat' readable writable executable
|
||||||
{ .handle dd ?
|
|
||||||
.io_code dd ?
|
|
||||||
.input dd ?
|
|
||||||
.inp_size dd ?
|
|
||||||
.output dd ?
|
|
||||||
.out_size dd ?
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual at 0
|
include '../proc32.inc'
|
||||||
IOCTL IOCTL
|
include '../struct.inc'
|
||||||
end virtual
|
include '../macros.inc'
|
||||||
|
include '../pci_pe.inc'
|
||||||
|
|
||||||
public START
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
public service_proc
|
;; ;;
|
||||||
public version
|
;; proc START ;;
|
||||||
|
;; ;;
|
||||||
|
;; (standard driver proc) ;;
|
||||||
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
DRV_ENTRY equ 1
|
proc START c, reason:dword, cmdline:dword
|
||||||
DRV_EXIT equ -1
|
|
||||||
|
|
||||||
SRV_GETVERSION equ 0
|
cmp [reason], DRV_ENTRY
|
||||||
SRV_DETECT equ 1
|
jne .fail
|
||||||
|
|
||||||
API_VERSION equ 1
|
|
||||||
|
|
||||||
section '.flat' code readable align 16
|
|
||||||
|
|
||||||
proc START stdcall, state:dword
|
|
||||||
|
|
||||||
cmp [state], 1
|
|
||||||
jne .exit
|
|
||||||
.entry:
|
|
||||||
|
|
||||||
if DEBUG
|
|
||||||
mov esi, msgInit
|
mov esi, msgInit
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
end if
|
invoke RegService, my_service, service_proc
|
||||||
|
|
||||||
|
call detect
|
||||||
|
|
||||||
stdcall RegService, my_service, service_proc
|
|
||||||
ret
|
ret
|
||||||
.fail:
|
|
||||||
.exit:
|
.fail:
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
|
|
||||||
endp
|
endp
|
||||||
|
|
||||||
handle equ IOCTL.handle
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
io_code equ IOCTL.io_code
|
;; ;;
|
||||||
input equ IOCTL.input
|
;; proc SERVICE_PROC ;;
|
||||||
inp_size equ IOCTL.inp_size
|
;; ;;
|
||||||
output equ IOCTL.output
|
;; (standard driver proc) ;;
|
||||||
out_size equ IOCTL.out_size
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
align 4
|
|
||||||
proc service_proc stdcall, ioctl:dword
|
proc service_proc stdcall, ioctl:dword
|
||||||
|
|
||||||
mov ebx, [ioctl]
|
mov edx, [ioctl]
|
||||||
mov eax, [ebx+io_code]
|
mov eax, [edx + IOCTL.io_code]
|
||||||
cmp eax, SRV_GETVERSION
|
|
||||||
jne @F
|
|
||||||
|
|
||||||
mov eax, [ebx+output]
|
;------------------------------------------------------
|
||||||
cmp [ebx+out_size], 4
|
|
||||||
|
cmp eax, 0 ;SRV_GETVERSION
|
||||||
jne .fail
|
jne .fail
|
||||||
|
|
||||||
|
cmp [edx + IOCTL.out_size], 4
|
||||||
|
jb .fail
|
||||||
|
mov eax, [edx + IOCTL.output]
|
||||||
mov [eax], dword API_VERSION
|
mov [eax], dword API_VERSION
|
||||||
|
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
@@:
|
|
||||||
mov ebx, [ioctl]
|
.fail:
|
||||||
mov eax, [ebx+io_code]
|
|
||||||
cmp eax, SRV_DETECT
|
|
||||||
jne @F
|
|
||||||
call detect
|
|
||||||
@@:
|
|
||||||
.fail:
|
|
||||||
or eax, -1
|
or eax, -1
|
||||||
ret
|
ret
|
||||||
endp
|
|
||||||
|
|
||||||
restore handle
|
endp
|
||||||
restore io_code
|
|
||||||
restore input
|
|
||||||
restore inp_size
|
|
||||||
restore output
|
|
||||||
restore out_size
|
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
proc detect
|
proc detect
|
||||||
@ -114,12 +93,12 @@ proc detect
|
|||||||
endl
|
endl
|
||||||
|
|
||||||
mov esi, msgSearch
|
mov esi, msgSearch
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
|
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
mov [bus], eax
|
mov [bus], eax
|
||||||
inc eax
|
inc eax
|
||||||
call PciApi ; get last bus
|
invoke PciApi ; get last bus
|
||||||
cmp eax, -1
|
cmp eax, -1
|
||||||
je .error
|
je .error
|
||||||
mov [last_bus], eax
|
mov [last_bus], eax
|
||||||
@ -127,14 +106,11 @@ proc detect
|
|||||||
.next_bus:
|
.next_bus:
|
||||||
and [devfn], 0
|
and [devfn], 0
|
||||||
.next_dev:
|
.next_dev:
|
||||||
stdcall PciRead16, [bus], [devfn], dword 0x0a ; read class/subclass
|
invoke PciRead16, [bus], [devfn], PCI_header.subclass ; subclass/vendor
|
||||||
|
|
||||||
cmp ax, 0x0300 ; display controller - vga compatable controller
|
cmp ax, 0x0300 ; display controller - vga compatable controller
|
||||||
je .found
|
je .found
|
||||||
|
|
||||||
cmp ax, 0x0302 ; display controller - 3d controller
|
cmp ax, 0x0302 ; display controller - 3d controller
|
||||||
je .found
|
je .found
|
||||||
|
|
||||||
cmp ax, 0x0380 ; display controller - other display controller
|
cmp ax, 0x0380 ; display controller - other display controller
|
||||||
je .found
|
je .found
|
||||||
|
|
||||||
@ -150,14 +126,14 @@ proc detect
|
|||||||
|
|
||||||
.error:
|
.error:
|
||||||
mov esi, msgFail
|
mov esi, msgFail
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
|
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
inc eax
|
inc eax
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.found:
|
.found:
|
||||||
stdcall PciRead8, [bus], [devfn], dword 0x06 ; read prog IF
|
invoke PciRead8, [bus], [devfn], PCI_header00.prog_if
|
||||||
test al, 1 shl 4 ; got capabilities list?
|
test al, 1 shl 4 ; got capabilities list?
|
||||||
jnz .got_capabilities_list
|
jnz .got_capabilities_list
|
||||||
|
|
||||||
@ -167,12 +143,12 @@ proc detect
|
|||||||
jmp .next
|
jmp .next
|
||||||
|
|
||||||
.got_capabilities_list:
|
.got_capabilities_list:
|
||||||
stdcall PciRead8, [bus], [devfn], dword 0x34 ; read capabilities offset
|
invoke PciRead8, [bus], [devfn], PCI_header00.cap_ptr
|
||||||
and eax, 11111100b ; always dword aligned
|
and eax, 11111100b ; always dword aligned
|
||||||
mov edi, eax
|
mov edi, eax
|
||||||
|
|
||||||
.read_capability:
|
.read_capability:
|
||||||
stdcall PciRead32, [bus], [devfn], edi ; read capability
|
invoke PciRead32, [bus], [devfn], edi ; read capability
|
||||||
cmp al, 0x02 ; AGP
|
cmp al, 0x02 ; AGP
|
||||||
je .got_agp
|
je .got_agp
|
||||||
movzx edi, ah ; pointer to next capability
|
movzx edi, ah ; pointer to next capability
|
||||||
@ -191,47 +167,45 @@ proc detect
|
|||||||
|
|
||||||
.agp_2:
|
.agp_2:
|
||||||
mov esi, msgAGP2
|
mov esi, msgAGP2
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
|
|
||||||
stdcall PciRead32, [bus], [devfn], edi ; read AGP status
|
invoke PciRead32, [bus], [devfn], edi ; read AGP status
|
||||||
.agp_2_:
|
.agp_2_:
|
||||||
test al, 100b
|
test al, 100b
|
||||||
jnz .100b
|
jnz .100b
|
||||||
|
|
||||||
test al, 10b
|
test al, 10b
|
||||||
jnz .010b
|
jnz .010b
|
||||||
|
|
||||||
test al, 1b
|
test al, 1b
|
||||||
jz .error
|
jz .error
|
||||||
|
|
||||||
.001b:
|
.001b:
|
||||||
mov [cmd], 001b
|
mov [cmd], 001b
|
||||||
mov esi, msg1
|
mov esi, msg1
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
jmp .agp_go
|
jmp .agp_go
|
||||||
|
|
||||||
.010b:
|
.010b:
|
||||||
mov [cmd], 010b
|
mov [cmd], 010b
|
||||||
mov esi, msg2
|
mov esi, msg2
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
jmp .agp_go
|
jmp .agp_go
|
||||||
|
|
||||||
.100b:
|
.100b:
|
||||||
mov [cmd], 100b
|
mov [cmd], 100b
|
||||||
mov esi, msg4
|
mov esi, msg4
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
jmp .agp_go
|
jmp .agp_go
|
||||||
|
|
||||||
.agp_2m:
|
.agp_2m:
|
||||||
mov esi, msgAGP2m
|
mov esi, msgAGP2m
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
jmp .agp_2_
|
jmp .agp_2_
|
||||||
|
|
||||||
.agp_3:
|
.agp_3:
|
||||||
mov esi, msgAGP3
|
mov esi, msgAGP3
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
|
|
||||||
stdcall PciRead32, [bus], [devfn], edi ; read AGP status
|
invoke PciRead32, [bus], [devfn], edi ; read AGP status
|
||||||
test al, 1 shl 3
|
test al, 1 shl 3
|
||||||
jz .agp_2m
|
jz .agp_2m
|
||||||
|
|
||||||
@ -239,13 +213,13 @@ proc detect
|
|||||||
jnz .8x
|
jnz .8x
|
||||||
mov [cmd], 01b
|
mov [cmd], 01b
|
||||||
mov esi, msg4
|
mov esi, msg4
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
jmp .agp_go
|
jmp .agp_go
|
||||||
|
|
||||||
.8x:
|
.8x:
|
||||||
mov [cmd], 10b
|
mov [cmd], 10b
|
||||||
mov esi, msg8
|
mov esi, msg8
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
|
|
||||||
.agp_go:
|
.agp_go:
|
||||||
|
|
||||||
@ -254,7 +228,7 @@ if FAST_WRITE
|
|||||||
jz @f
|
jz @f
|
||||||
or [cmd], 1 shl 4
|
or [cmd], 1 shl 4
|
||||||
mov esi, msgfast
|
mov esi, msgfast
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
@@:
|
@@:
|
||||||
end if
|
end if
|
||||||
|
|
||||||
@ -262,26 +236,28 @@ end if
|
|||||||
jz @f
|
jz @f
|
||||||
or [cmd], 1 shl 9
|
or [cmd], 1 shl 9
|
||||||
mov esi, msgside
|
mov esi, msgside
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
@@:
|
@@:
|
||||||
|
|
||||||
add edi, 4
|
add edi, 4
|
||||||
mov eax, [cmd]
|
mov eax, [cmd]
|
||||||
or eax, 1 shl 8 ; enable AGP
|
or eax, 1 shl 8 ; enable AGP
|
||||||
stdcall PciWrite32, [bus], [devfn], edi, eax ; write AGP cmd
|
invoke PciWrite32, [bus], [devfn], edi, eax ; write AGP cmd
|
||||||
|
|
||||||
mov esi, msgOK
|
mov esi, msgOK
|
||||||
call SysMsgBoardStr
|
invoke SysMsgBoardStr
|
||||||
|
|
||||||
ret
|
ret
|
||||||
|
|
||||||
endp
|
endp
|
||||||
|
|
||||||
|
|
||||||
; initialized data
|
; End of code
|
||||||
|
|
||||||
align 4
|
data fixups
|
||||||
version dd (5 shl 16) or (API_VERSION and 0xFFFF)
|
end data
|
||||||
|
|
||||||
|
include '../peimport.inc'
|
||||||
|
|
||||||
my_service db 'AGP', 0 ; max 16 chars include zero
|
my_service db 'AGP', 0 ; max 16 chars include zero
|
||||||
|
|
||||||
@ -299,8 +275,6 @@ msg1 db '1x speed', 13, 10, 0
|
|||||||
msgfast db 'Fast Write', 13, 10, 0
|
msgfast db 'Fast Write', 13, 10, 0
|
||||||
msgside db 'Side band addressing', 13, 10, 0
|
msgside db 'Side band addressing', 13, 10, 0
|
||||||
|
|
||||||
section '.data' data readable writable align 16
|
|
||||||
|
|
||||||
; uninitialized data
|
; uninitialized data
|
||||||
|
|
||||||
revision db ?
|
revision db ?
|
@ -17,31 +17,26 @@
|
|||||||
; WARNING: Cards must be inserted before the driver starts, and shouldn't be removed.
|
; WARNING: Cards must be inserted before the driver starts, and shouldn't be removed.
|
||||||
; This module doesn't handle insertions and removals.
|
; This module doesn't handle insertions and removals.
|
||||||
|
|
||||||
format MS COFF
|
format PE DLL native
|
||||||
|
entry START
|
||||||
|
|
||||||
API_VERSION = 0x01000100
|
CURRENT_API = 0x0200
|
||||||
DRIVER_VERSION = 5
|
COMPATIBLE_API = 0x0100
|
||||||
|
API_VERSION = (COMPATIBLE_API shl 16) + CURRENT_API
|
||||||
|
|
||||||
CARDBUS_IO = 0xFC00
|
CARDBUS_IO = 0xFC00
|
||||||
|
|
||||||
DEBUG = 1
|
|
||||||
__DEBUG__ = 1
|
__DEBUG__ = 1
|
||||||
__DEBUG_LEVEL__ = 1
|
__DEBUG_LEVEL__ = 1
|
||||||
|
|
||||||
|
section '.flat' readable writable executable
|
||||||
|
|
||||||
|
include '../proc32.inc'
|
||||||
include '../struct.inc'
|
include '../struct.inc'
|
||||||
include '../macros.inc'
|
include '../macros.inc'
|
||||||
include '../proc32.inc'
|
include '../pci_pe.inc'
|
||||||
include '../imports.inc'
|
|
||||||
include '../pci.inc'
|
|
||||||
include '../fdo.inc'
|
include '../fdo.inc'
|
||||||
|
|
||||||
public START
|
|
||||||
public service_proc
|
|
||||||
public version
|
|
||||||
|
|
||||||
section '.flat' code readable align 16
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;; ;;
|
;; ;;
|
||||||
;; proc START ;;
|
;; proc START ;;
|
||||||
@ -49,23 +44,19 @@ section '.flat' code readable align 16
|
|||||||
;; (standard driver proc) ;;
|
;; (standard driver proc) ;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
align 4
|
proc START c, reason:dword, cmdline:dword
|
||||||
proc START stdcall, state:dword
|
|
||||||
|
|
||||||
cmp [state], 1
|
cmp [reason], DRV_ENTRY
|
||||||
jne .exit
|
jne .fail
|
||||||
|
|
||||||
.entry:
|
|
||||||
|
|
||||||
DEBUGF 1, "Loading cardbus driver\n"
|
DEBUGF 1, "Loading cardbus driver\n"
|
||||||
stdcall RegService, my_service, service_proc
|
invoke RegService, my_service, service_proc
|
||||||
|
|
||||||
call detect
|
call detect
|
||||||
|
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.fail:
|
.fail:
|
||||||
.exit:
|
|
||||||
xor eax, eax
|
xor eax, eax
|
||||||
ret
|
ret
|
||||||
|
|
||||||
@ -80,7 +71,6 @@ endp
|
|||||||
;; (standard driver proc) ;;
|
;; (standard driver proc) ;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
align 4
|
|
||||||
proc service_proc stdcall, ioctl:dword
|
proc service_proc stdcall, ioctl:dword
|
||||||
|
|
||||||
mov edx, [ioctl]
|
mov edx, [ioctl]
|
||||||
@ -120,7 +110,7 @@ proc detect
|
|||||||
xor eax, eax
|
xor eax, eax
|
||||||
mov [bus], eax
|
mov [bus], eax
|
||||||
inc eax
|
inc eax
|
||||||
call PciApi
|
invoke PciApi
|
||||||
cmp eax, -1
|
cmp eax, -1
|
||||||
je .err
|
je .err
|
||||||
mov [last_bus], eax
|
mov [last_bus], eax
|
||||||
@ -131,13 +121,13 @@ proc detect
|
|||||||
.next_bus:
|
.next_bus:
|
||||||
and [devfn], 0
|
and [devfn], 0
|
||||||
.next_dev:
|
.next_dev:
|
||||||
stdcall PciRead32, [bus], [devfn], PCI_VENDOR_ID
|
invoke PciRead32, [bus], [devfn], PCI_header02.vendor_id
|
||||||
test eax, eax
|
test eax, eax
|
||||||
jz .next
|
jz .next
|
||||||
cmp eax, -1
|
cmp eax, -1
|
||||||
je .next
|
je .next
|
||||||
|
|
||||||
stdcall PciRead16, [bus], [devfn], 0x0a ; class & subclass
|
invoke PciRead16, [bus], [devfn], 0x0a ; class & subclass
|
||||||
cmp ax, 0x0607
|
cmp ax, 0x0607
|
||||||
je .found
|
je .found
|
||||||
|
|
||||||
@ -159,15 +149,14 @@ proc detect
|
|||||||
.found:
|
.found:
|
||||||
DEBUGF 1, "Found cardbus bridge: bus=0x%x, dev=0x%x\n", [bus], [devfn]
|
DEBUGF 1, "Found cardbus bridge: bus=0x%x, dev=0x%x\n", [bus], [devfn]
|
||||||
|
|
||||||
stdcall PciRead8, [bus], [devfn], 0x0e ; get header type
|
invoke PciRead8, [bus], [devfn], PCI_header.header_type
|
||||||
DEBUGF 1, "Header type=0x%x\n", eax:2
|
DEBUGF 1, "Header type=0x%x\n", eax:2
|
||||||
|
cmp al, 2
|
||||||
test al, al
|
jne .next
|
||||||
jz .next
|
|
||||||
|
|
||||||
; Write PCI and cardbus numbers
|
; Write PCI and cardbus numbers
|
||||||
|
|
||||||
stdcall PciRead32, [bus], [devfn], 0x18 ; PCcard latency settings + Card bus number, PCI bus number
|
invoke PciRead32, [bus], [devfn], PCI_header02.pci_bus_nr ; PCcard latency settings + Card bus number, PCI bus number
|
||||||
and eax, 0xff000000 ; Keep original latency setting, clear the rest
|
and eax, 0xff000000 ; Keep original latency setting, clear the rest
|
||||||
mov al, byte[bus]
|
mov al, byte[bus]
|
||||||
mov ah, byte[card_bus]
|
mov ah, byte[card_bus]
|
||||||
@ -175,31 +164,31 @@ proc detect
|
|||||||
shl ebx, 16
|
shl ebx, 16
|
||||||
or eax, ebx
|
or eax, ebx
|
||||||
DEBUGF 1, "Latency, bus,.. 0x%x\n", eax
|
DEBUGF 1, "Latency, bus,.. 0x%x\n", eax
|
||||||
stdcall PciWrite32, [bus], [devfn], 0x18, eax
|
invoke PciWrite32, [bus], [devfn], PCI_header02.pci_bus_nr, eax
|
||||||
|
|
||||||
; set ExCA legacy mode base
|
; set ExCA legacy mode base
|
||||||
|
|
||||||
stdcall PciWrite32, [bus], [devfn], 0x44, 1
|
invoke PciWrite32, [bus], [devfn], 0x44, 1
|
||||||
|
|
||||||
; Enable power
|
; Enable power
|
||||||
|
|
||||||
stdcall PciRead8, [bus], [devfn], 0x14 ; get capabilities offset
|
invoke PciRead8, [bus], [devfn], 0x14 ; get capabilities offset
|
||||||
movzx eax, al ; (A0 for TI bridges)
|
movzx eax, al ; (A0 for TI bridges)
|
||||||
DEBUGF 1, "Capabilities offset=0x%x\n", eax:2
|
DEBUGF 1, "Capabilities offset=0x%x\n", eax:2
|
||||||
add al, 4 ; Power management control/status
|
add al, 4 ; Power management control/status
|
||||||
stdcall PciWrite16, [bus], [devfn], eax, 0x0100 ; Enable PME signaling, power state=D0
|
invoke PciWrite16, [bus], [devfn], eax, 0x0100 ; Enable PME signaling, power state=D0
|
||||||
|
|
||||||
; Enable Bus master, io space, memory space
|
; Enable Bus master, io space, memory space
|
||||||
|
|
||||||
stdcall PciWrite16, [bus], [devfn], PCI_REG_COMMAND, 0x0007
|
invoke PciWrite16, [bus], [devfn], PCI_header02.command, 0x0007
|
||||||
|
|
||||||
; Write CardBus Socket/ExCA base address
|
; Write CardBus Socket/ExCA base address
|
||||||
|
|
||||||
mov eax, 0x7f000000
|
mov eax, 0x7f000000
|
||||||
push eax
|
push eax
|
||||||
stdcall PciWrite32, [bus], [devfn], 0x10, eax ; base is 4 Kbyte aligned
|
invoke PciWrite32, [bus], [devfn], PCI_header02.base_addr, eax ; base is 4 Kbyte aligned
|
||||||
pop ebx
|
pop ebx
|
||||||
stdcall MapIoMem, ebx, 4096, 0x1b
|
invoke MapIoMem, ebx, 4096, 0x1b
|
||||||
mov ecx, eax
|
mov ecx, eax
|
||||||
|
|
||||||
; Check if a card is present in the socket
|
; Check if a card is present in the socket
|
||||||
@ -212,7 +201,7 @@ proc detect
|
|||||||
|
|
||||||
; No card found... set PCI command back to 0
|
; No card found... set PCI command back to 0
|
||||||
|
|
||||||
stdcall PciWrite16, [bus], [devfn], PCI_REG_COMMAND, 0 ; To avoid conflicts with other sockets
|
invoke PciWrite16, [bus], [devfn], PCI_header02.command, 0 ; To avoid conflicts with other sockets
|
||||||
DEBUGF 1, "Cardbus KO\n"
|
DEBUGF 1, "Cardbus KO\n"
|
||||||
jmp .next
|
jmp .next
|
||||||
|
|
||||||
@ -222,7 +211,7 @@ proc detect
|
|||||||
mov dword[ecx + 0x10], 0x33 ; Request 3.3V for Vcc and Vpp (Control register)
|
mov dword[ecx + 0x10], 0x33 ; Request 3.3V for Vcc and Vpp (Control register)
|
||||||
;push ecx
|
;push ecx
|
||||||
;mov esi, 10
|
;mov esi, 10
|
||||||
;call Sleep
|
;invoke Sleep
|
||||||
;pop ecx
|
;pop ecx
|
||||||
;mov byte[ecx + 0x803], 0x40 ; stop reset
|
;mov byte[ecx + 0x803], 0x40 ; stop reset
|
||||||
mov dword[ecx + 0xC], 0x4000 ; force Card CV test (Force register) ;;; WHY???
|
mov dword[ecx + 0xC], 0x4000 ; force Card CV test (Force register) ;;; WHY???
|
||||||
@ -245,23 +234,23 @@ irp regvalue, 0x7efff000, 0x7effffff, 0x7effe000, 0x7effe000, CARDBUS_IO,
|
|||||||
common
|
common
|
||||||
reg = 0x1C
|
reg = 0x1C
|
||||||
forward
|
forward
|
||||||
stdcall PciWrite32, [bus], [devfn], reg, regvalue
|
invoke PciWrite32, [bus], [devfn], reg, regvalue
|
||||||
DEBUGF 1, "Writing 0x%x to 0x%x\n", regvalue, reg
|
DEBUGF 1, "Writing 0x%x to 0x%x\n", regvalue, reg
|
||||||
reg = reg + 4
|
reg = reg + 4
|
||||||
}
|
}
|
||||||
|
|
||||||
stdcall PciWrite8, [bus], [devfn], 0x3c, 0xc ; IRQ line
|
invoke PciWrite8, [bus], [devfn], PCI_header02.interrupt_line, 0xc ; IRQ line
|
||||||
|
|
||||||
stdcall PciRead16, [bus], [devfn], 0x3e ; Bridge control
|
invoke PciRead16, [bus], [devfn], PCI_header02.bridge_ctrl ; Bridge control
|
||||||
or ax, 0x0700 ; Enable write posting, both memory windows prefetchable
|
or ax, 0x0700 ; Enable write posting, both memory windows prefetchable
|
||||||
stdcall PciWrite16, [bus], [devfn], 0x3e, eax
|
invoke PciWrite16, [bus], [devfn], PCI_header02.bridge_ctrl, eax
|
||||||
DEBUGF 1, "Write posting enabled\n"
|
DEBUGF 1, "Write posting enabled\n"
|
||||||
|
|
||||||
|
|
||||||
DEBUGF 1, "Bridge PCI registers:\n"
|
DEBUGF 1, "Bridge PCI registers:\n"
|
||||||
rept 17 reg
|
rept 17 reg
|
||||||
{
|
{
|
||||||
stdcall PciRead32, [bus], [devfn], 4*(reg-1)
|
invoke PciRead32, [bus], [devfn], 4*(reg-1)
|
||||||
DEBUGF 1, "0x%x\n", eax
|
DEBUGF 1, "0x%x\n", eax
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -271,11 +260,11 @@ rept 17 reg
|
|||||||
mov ecx, 100
|
mov ecx, 100
|
||||||
.waitactive:
|
.waitactive:
|
||||||
push ecx
|
push ecx
|
||||||
stdcall PciRead32, [card_bus], 0, PCI_VENDOR_ID ; Check if the card is awake yet
|
invoke PciRead32, [card_bus], 0, PCI_header02.vendor_id ; Check if the card is awake yet
|
||||||
inc eax
|
inc eax
|
||||||
jnz .got_it
|
jnz .got_it
|
||||||
mov esi, 2
|
mov esi, 2
|
||||||
call Sleep
|
invoke Sleep
|
||||||
pop ecx
|
pop ecx
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .waitactive
|
jnz .waitactive
|
||||||
@ -288,9 +277,9 @@ rept 17 reg
|
|||||||
pop eax
|
pop eax
|
||||||
DEBUGF 1, "Card is enabled!\n"
|
DEBUGF 1, "Card is enabled!\n"
|
||||||
|
|
||||||
stdcall PciWrite32, [card_bus], 0, PCI_BASE_ADDRESS_0, CARDBUS_IO ; Supposing it's IO space that is needed
|
invoke PciWrite32, [card_bus], 0, PCI_header02.base_addr, CARDBUS_IO ; Supposing it's IO space that is needed
|
||||||
stdcall PciWrite8, [card_bus], 0, PCI_REG_IRQ, 0xC ; FIXME
|
invoke PciWrite8, [card_bus], 0, PCI_header02.interrupt_line, 0xC ; FIXME
|
||||||
stdcall PciWrite16, [card_bus], 0, PCI_REG_COMMAND, PCI_BIT_PIO or PCI_BIT_MMIO
|
invoke PciWrite16, [card_bus], 0, PCI_header02.command, PCI_CMD_PIO or PCI_CMD_MMIO
|
||||||
|
|
||||||
DEBUGF 1, "done\n"
|
DEBUGF 1, "done\n"
|
||||||
|
|
||||||
@ -302,18 +291,16 @@ rept 17 reg
|
|||||||
|
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
endp
|
endp
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; End of code
|
; End of code
|
||||||
|
|
||||||
section '.data' data readable writable align 16
|
data fixups
|
||||||
|
end data
|
||||||
|
|
||||||
|
include '../peimport.inc'
|
||||||
|
|
||||||
version dd (DRIVER_VERSION shl 16) or (API_VERSION and 0xFFFF)
|
|
||||||
my_service db 'CARDBUS',0 ; max 16 chars include zero
|
my_service db 'CARDBUS',0 ; max 16 chars include zero
|
||||||
|
|
||||||
include_debug_strings ; All data wich FDO uses will be included here
|
include_debug_strings ; All data wich FDO uses will be included here
|
Loading…
Reference in New Issue
Block a user