VirtualBox

source: vbox/trunk/src/VBox/Devices/PC/BIOS/apm_pm.asm@ 75265

Last change on this file since 75265 was 74580, checked in by vboxsync, 6 years ago

BIOS: Build 32-bit APM only for 386+ BIOS.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.2 KB
Line 
1; $Id:
2;; @file
3; Protected-mode APM implementation.
4;
5
6;
7; Copyright (C) 2006-2017 Oracle Corporation
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17
18
19include commondefs.inc
20
21;; 16-bit protected mode APM entry point
22
23_TEXT segment public 'CODE'
24
25extern _apm_function:near ; implemented in C code
26
27
28public apm_pm16_entry
29
30SET_DEFAULT_CPU_286
31
32
33; APM function dispatch table
34apm_disp:
35 dw offset apmf_disconnect ; 04h
36 dw offset apmf_idle ; 05h
37 dw offset apmf_busy ; 06h
38 dw offset apmf_set_state ; 07h
39 dw offset apmf_enable ; 08h
40 dw offset apmf_restore ; 09h
41 dw offset apmf_get_status ; 0Ah
42 dw offset apmf_get_event ; 0Bh
43 dw offset apmf_pwr_state ; 0Ch
44 dw offset apmf_dev_pm ; 0Dh
45 dw offset apmf_version ; 0Eh
46 dw offset apmf_engage ; 0Fh
47 dw offset apmf_get_caps ; 10h
48apm_disp_end:
49
50;
51; APM worker routine. Function code in AL; it is assumed that AL >= 4.
52; Caller must preserve BP.
53;
54apm_worker proc near
55
56 sti ; TODO ?? necessary ??
57
58 push ax ; check if function is supported...
59 xor ah, ah
60 sub al, 4
61 mov bp, ax
62 shl bp, 1
63 cmp al, (apm_disp_end - apm_disp) / 2
64 pop ax
65 mov ah, 53h ; put back APM function
66 jae apmw_bad_func ; validate function range
67
68 jmp apm_disp[bp] ; and dispatch
69
70apmf_disconnect: ; function 04h
71 jmp apmw_success
72
73apmf_idle: ; function 05h
74 sti
75 hlt
76 jmp apmw_success
77
78apmf_busy: ; function 06h
79; jmp apmw_success
80
81apmf_set_state: ; function 07h
82; jmp apmw_success
83
84apmf_enable: ; function 08h
85 jmp apmw_success
86
87apmf_restore: ; function 09h
88; jmp apmw_success
89
90apmf_get_status: ; function 0Ah
91 jmp apmw_bad_func
92
93apmf_get_event: ; function 0Bh
94 mov ah, 80h
95 jmp apmw_failure
96
97apmf_pwr_state: ; function 0Ch
98
99apmf_dev_pm: ; function 0Dh
100 jmp apmw_bad_func
101
102apmf_version: ; function 0Eh
103 mov ax, 0102h
104 jmp apmw_success
105
106apmf_engage: ; function 0Fh
107 ; TODO do something?
108 jmp apmw_success
109
110apmf_get_caps: ; function 10h
111 mov bl, 0 ; no batteries
112 mov cx, 0 ; no special caps
113 jmp apmw_success
114
115apmw_success:
116 clc ; successful return
117 ret
118
119apmw_bad_func:
120 mov ah, 09h ; unrecognized device ID - generic
121
122apmw_failure:
123 stc ; error for unsupported functions
124 ret
125
126apm_worker endp
127
128
129;; 16-bit protected mode APM entry point
130
131;; According to the APM spec, only CS (16-bit code selector) is defined.
132;; The data selector can be derived from it.
133
134apm_pm16_entry:
135
136 mov ah, 2 ; mark as originating in 16-bit PM
137
138 ; fall through
139
140apm_pm16_entry_from_32:
141
142 push ds ; save registers
143 push bp
144
145 push cs
146 pop bp
147 add bp, 8 ; calculate data selector
148 mov ds, bp ; load data segment
149
150 call apm_worker ; call APM handler
151
152 pop bp
153 pop ds ; restore registers
154
155 retf ; return to caller - 16-bit return
156 ; even to 32-bit thunk!
157
158_TEXT ends
159
160
161if VBOX_BIOS_CPU ge 80386
162
163.386
164
165BIOS32 segment public 'CODE' use32
166
167public apm_pm32_entry
168
169;; 32-bit protected mode APM entry point and thunk
170
171;; According to the APM spec, only CS (32-bit) is defined. 16-bit code
172;; selector and the data selector can be derived from it.
173
174;; WARNING: To simplify matters, we use 16-bit far return to go from 32-bit
175;; code to 16-bit and back. As a consequence, the 32-bit APM code must lie
176;; below 64K boundary in the 32-bit APM code segment.
177
178apm_pm32_entry:
179
180 push ebp ; ebp is not used by APM
181
182 mov bp, cs ; return address for 16-bit code
183 push bp
184 mov ebp, apm_pm32_back
185 push bp ; Note: 16:16 address!
186
187 push cs
188 pop ebp
189 add ebp, 8 ; calculate 16-bit code selector
190 push bp ; push 16-bit code selector
191
192 mov ebp, apm_pm16_entry_from_32
193 push bp ; push 16-bit offset
194
195 mov ah, 3 ; mark as originating in 32-bit PM
196
197 db 66h ; force a 16-bit return
198 retf ; off to 16-bit code...
199
200apm_pm32_back: ; return here from 16-bit code
201
202 pop ebp ; restore scratch register
203 retf
204
205BIOS32 ends
206
207endif ; 32-bit code
208
209 end
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette