Sync usage with man page.
[netbsd-mini2440.git] / sys / arch / i386 / stand / lib / bios_pci.S
blob68316d3bf2ee54b288505e6d018d615e8e26afcd
1 /*      $NetBSD: bios_pci.S,v 1.4.2.3 2004/09/21 13:17:10 skrll Exp $   */
3 /*
4  * Copyright (c) 1996
5  *      Matthias Drochner.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  *
27  */
29 /* minimal calls to PCI BIOS */
31 #include <machine/asm.h>
33 #define addr32  .byte 0x67
34 #define data32  .byte 0x66
36 #define PCI_FUNCTION_ID 0xb1
37 #define PCI_BIOS_PRESENT 0x01
38 #define FIND_PCI_DEVICE 0x02
39 #define READ_CONFIG_DWORD 0x0a
40 #define WRITE_CONFIG_DWORD 0x0d
42 /* int pcibios_present(int *signature)
43     return: AX from BIOS call, -1 on error
44     var param: EDX from BIOS call, must be signature "PCI "
46 ENTRY(pcibios_present)
47         pushl   %ebp
48         movl    %esp, %ebp
49         pushl   %ebx
50         pushl   %ecx
51         pushl   %edx
53         call    _C_LABEL(prot_to_real)  # enter real mode
54         .code16
56         movb    $PCI_FUNCTION_ID, %ah
57         movb    $PCI_BIOS_PRESENT, %al
58         int     $0x1a
60         jnc     ok1
61         movl    $-1, %ebx
62         jmp err1
64 ok1:
65         xorl    %ebx, %ebx
66         mov     %ax, %bx
67 err1:
68         calll   _C_LABEL(real_to_prot) # back to protected mode
69         .code32
71         movl    8(%ebp), %eax
72         movl    %edx, (%eax)
74         movl    %ebx, %eax              # return value in %eax
76         popl    %edx
77         popl    %ecx
78         popl    %ebx
79         popl    %ebp
80         ret
82 /* int pcibios_finddev(int vendor, int device, int index, int *busdevfcn)
83     return: AH from BIOS call, -1 on error
84     var param: BX from BIOS call, contains bus/device/function
86 ENTRY(pcibios_finddev)
87         pushl   %ebp
88         movl    %esp, %ebp
89         pushl   %ebx
90         pushl   %ecx
91         pushl   %edx
92         pushl   %esi
94         movl    8(%ebp), %edx
95         movl    12(%ebp), %ecx
96         movl    16(%ebp), %esi
98         call    _C_LABEL(prot_to_real)  # enter real mode
99         .code16
101         movb    $PCI_FUNCTION_ID, %ah
102         movb    $FIND_PCI_DEVICE, %al
103         int     $0x1a
105         jnc     ok2
106         movl    $-1, %edx
107         jmp err2
109 ok2:
110         movl    $0,%edx
111         movb    %ah, %dl
112 err2:
113         calll   _C_LABEL(real_to_prot) # back to protected mode
114         .code32
116         movl    20(%ebp), %eax
117         mov     %bx, (%eax)
119         movl    %edx, %eax              # return value in %eax
121         popl    %esi
122         popl    %edx
123         popl    %ecx
124         popl    %ebx
125         popl    %ebp
126         ret
128 /* int pcibios_cfgread(int busdevfcn, int offset, int *value)
129     return: AH from BIOS call, -1 on error
130     var param: ECX from BIOS call, contains value read
132 ENTRY(pcibios_cfgread)
133         pushl   %ebp
134         movl    %esp, %ebp
135         pushl   %ebx
136         pushl   %ecx
137         pushl   %edx
138         pushl   %edi
140         movl    8(%ebp), %ebx
141         movl    12(%ebp), %edi
143         call    _C_LABEL(prot_to_real)  # enter real mode
144         .code16
146         movb    $PCI_FUNCTION_ID, %ah
147         movb    $READ_CONFIG_DWORD, %al
148         int     $0x1a
150         jnc     ok3
151         movl    $-1, %edx
152         jmp err3
154 ok3:
155         movl    $0,%edx
156         movb    %ah, %dl
157 err3:
158         calll   _C_LABEL(real_to_prot) # back to protected mode
159         .code32
161         movl    16(%ebp), %eax
162         movl    %ecx, (%eax)
164         movl    %edx, %eax              # return value in %eax
166         popl    %edi
167         popl    %edx
168         popl    %ecx
169         popl    %ebx
170         popl    %ebp
171         ret
173 /* int pcibios_cfgwrite(int busdevfcn, int offset, int value)
174     return: AH from BIOS call, -1 on error
175     var param: ECX from BIOS call, contains value read
177 ENTRY(pcibios_cfgwrite)
178         pushl   %ebp
179         movl    %esp, %ebp
180         pushl   %ebx
181         pushl   %ecx
182         pushl   %edx
183         pushl   %edi
185         movl    8(%ebp), %ebx
186         movl    12(%ebp), %edi
187         movl    16(%ebp), %ecx
189         call    _C_LABEL(prot_to_real)  # enter real mode
190         .code16
192         movb    $PCI_FUNCTION_ID, %ah
193         movb    $WRITE_CONFIG_DWORD, %al
194         int     $0x1a
196         jnc     ok4
197         movl    $-1, %edx
198         jmp err4
200 ok4:
201         movl    $0,%edx
202         movb    %ah, %dl
203 err4:
204         calll   _C_LABEL(real_to_prot) # back to protected mode
205         .code32
207         movl    %edx, %eax              # return value in %eax
209         popl    %edi
210         popl    %edx
211         popl    %ecx
212         popl    %ebx
213         popl    %ebp
214         ret