Subversion Repositories Kolibri OS

Rev

Rev 164 | Rev 170 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 164 Rev 168
1
drw0    equ  10010010b      ; data read/write dpl0
1
drw0    equ  10010010b      ; data read/write dpl0
2
drw3    equ  11110010b      ; data read/write dpl3
2
drw3    equ  11110010b      ; data read/write dpl3
3
cpl0    equ  10011010b      ; code read dpl0
3
cpl0    equ  10011010b      ; code read dpl0
4
cpl3    equ  11111010b      ; code read dpl3
4
cpl3    equ  11111010b      ; code read dpl3
5
 
5
 
6
D32     equ  01000000b      ; 32bit segment
6
D32     equ  01000000b      ; 32bit segment
7
G32    equ   10000000b      ; page gran
7
G32    equ   10000000b      ; page gran
8
 
8
 
9
 
9
 
10
;;;;;;;;;;;;cpu_caps flags;;;;;;;;;;;;;;;;
10
;;;;;;;;;;;;cpu_caps flags;;;;;;;;;;;;;;;;
11
 
11
 
12
CPU_386        equ 3
12
CPU_386        equ 3
13
CPU_486        equ 4
13
CPU_486        equ 4
14
CPU_PENTIUM    equ 5
14
CPU_PENTIUM    equ 5
15
CPU_P6         equ 6
15
CPU_P6         equ 6
16
CPU_PENTIUM4   equ 0x0F
16
CPU_PENTIUM4   equ 0x0F
17
 
17
 
18
CAPS_FPU       equ    00 ;on-chip x87 floating point unit
18
CAPS_FPU       equ    00 ;on-chip x87 floating point unit
19
CAPS_VME       equ    01 ;virtual-mode enhancements
19
CAPS_VME       equ    01 ;virtual-mode enhancements
20
CAPS_DE        equ    02 ;debugging extensions
20
CAPS_DE        equ    02 ;debugging extensions
21
CAPS_PSE       equ    03 ;page-size extensions
21
CAPS_PSE       equ    03 ;page-size extensions
22
CAPS_TSC       equ    04 ;time stamp counter
22
CAPS_TSC       equ    04 ;time stamp counter
23
CAPS_MSR       equ    05 ;model-specific registers
23
CAPS_MSR       equ    05 ;model-specific registers
24
CAPS_PAE       equ    06 ;physical-address extensions
24
CAPS_PAE       equ    06 ;physical-address extensions
25
CAPS_MCE       equ    07 ;machine check exception
25
CAPS_MCE       equ    07 ;machine check exception
26
CAPS_CX8       equ    08 ;CMPXCHG8B instruction
26
CAPS_CX8       equ    08 ;CMPXCHG8B instruction
27
CAPS_APIC      equ    09 ;on-chip advanced programmable
27
CAPS_APIC      equ    09 ;on-chip advanced programmable
28
                         ; interrupt controller
28
                         ; interrupt controller
29
;                     10 ;unused
29
;                     10 ;unused
30
CAPS_SEP       equ    11 ;SYSENTER and SYSEXIT instructions
30
CAPS_SEP       equ    11 ;SYSENTER and SYSEXIT instructions
31
CAPS_MTRR      equ    12 ;memory-type range registers
31
CAPS_MTRR      equ    12 ;memory-type range registers
32
CAPS_PGE       equ    13 ;page global extension
32
CAPS_PGE       equ    13 ;page global extension
33
CAPS_MCA       equ    14 ;machine check architecture
33
CAPS_MCA       equ    14 ;machine check architecture
34
CAPS_CMOV      equ    15 ;conditional move instructions
34
CAPS_CMOV      equ    15 ;conditional move instructions
35
CAPS_PAT       equ    16 ;page attribute table
35
CAPS_PAT       equ    16 ;page attribute table
36
 
36
 
37
CAPS_PSE36     equ    17 ;page-size extensions
37
CAPS_PSE36     equ    17 ;page-size extensions
38
CAPS_PSN       equ    18 ;processor serial number
38
CAPS_PSN       equ    18 ;processor serial number
39
CAPS_CLFLUSH   equ    19 ;CLFUSH instruction
39
CAPS_CLFLUSH   equ    19 ;CLFUSH instruction
40
 
40
 
41
CAPS_DS        equ    21 ;debug store
41
CAPS_DS        equ    21 ;debug store
42
CAPS_ACPI      equ    22 ;thermal monitor and software
42
CAPS_ACPI      equ    22 ;thermal monitor and software
43
                         ;controlled clock supported
43
                         ;controlled clock supported
44
CAPS_MMX       equ    23 ;MMX instructions
44
CAPS_MMX       equ    23 ;MMX instructions
45
CAPS_FXSR      equ    24 ;FXSAVE and FXRSTOR instructions
45
CAPS_FXSR      equ    24 ;FXSAVE and FXRSTOR instructions
46
CAPS_SSE       equ    25 ;SSE instructions
46
CAPS_SSE       equ    25 ;SSE instructions
47
CAPS_SSE2      equ    26 ;SSE2 instructions
47
CAPS_SSE2      equ    26 ;SSE2 instructions
48
CAPS_SS        equ    27 ;self-snoop
48
CAPS_SS        equ    27 ;self-snoop
49
CAPS_HTT       equ    28 ;hyper-threading technology
49
CAPS_HTT       equ    28 ;hyper-threading technology
50
CAPS_TM        equ    29 ;thermal monitor supported
50
CAPS_TM        equ    29 ;thermal monitor supported
51
CAPS_IA64      equ    30 ;IA64 capabilities
51
CAPS_IA64      equ    30 ;IA64 capabilities
52
CAPS_PBE       equ    31 ;pending break enable
52
CAPS_PBE       equ    31 ;pending break enable
53
 
53
 
54
;ecx
54
;ecx
55
CAPS_SSE3      equ    32 ;SSE3 instructions
55
CAPS_SSE3      equ    32 ;SSE3 instructions
56
;                     33
56
;                     33
57
;                     34
57
;                     34
58
CAPS_MONITOR   equ    35 ;MONITOR/MWAIT instructions
58
CAPS_MONITOR   equ    35 ;MONITOR/MWAIT instructions
59
CAPS_DS_CPL    equ    36 ;
59
CAPS_DS_CPL    equ    36 ;
60
CAPS_VMX       equ    37 ;virtual mode extensions
60
CAPS_VMX       equ    37 ;virtual mode extensions
61
;                     38 ;
61
;                     38 ;
62
CAPS_EST       equ    39 ;enhansed speed step
62
CAPS_EST       equ    39 ;enhansed speed step
63
CAPS_TM2       equ    40 ;thermal monitor2 supported
63
CAPS_TM2       equ    40 ;thermal monitor2 supported
64
;                     41
64
;                     41
65
CAPS_CID       equ    42 ;
65
CAPS_CID       equ    42 ;
66
;                     43
66
;                     43
67
;                     44
67
;                     44
68
CAPS_CX16      equ    45 ;CMPXCHG16B instruction
68
CAPS_CX16      equ    45 ;CMPXCHG16B instruction
69
CAPS_xTPR      equ    46 ;
69
CAPS_xTPR      equ    46 ;
70
;
70
;
71
;reserved
71
;reserved
72
;
72
;
73
;ext edx /ecx
73
;ext edx /ecx
74
CAPS_SYSCAL    equ    64 ;
74
CAPS_SYSCAL    equ    64 ;
75
CAPS_XD        equ    65 ;execution disable
75
CAPS_XD        equ    65 ;execution disable
76
CAPS_FFXSR     equ    66 ;
76
CAPS_FFXSR     equ    66 ;
77
CAPS_RDTSCP    equ    67 ;
77
CAPS_RDTSCP    equ    67 ;
78
CAPS_X64       equ    68 ;
78
CAPS_X64       equ    68 ;
79
CAPS_3DNOW     equ    69 ;
79
CAPS_3DNOW     equ    69 ;
80
CAPS_3DNOWEXT  equ    70 ;
80
CAPS_3DNOWEXT  equ    70 ;
81
CAPS_LAHF      equ    71 ;
81
CAPS_LAHF      equ    71 ;
82
CAPS_CMP_LEG   equ    72 ;
82
CAPS_CMP_LEG   equ    72 ;
83
CAPS_SVM       equ    73 ;secure virual machine
83
CAPS_SVM       equ    73 ;secure virual machine
84
CAPS_ALTMOVCR8 equ    74 ;
84
CAPS_ALTMOVCR8 equ    74 ;
85
 
85
 
86
 
86
 
87
CR4_VME        equ    0x0001
87
CR0_PE         equ    0x00000001   ;protected mode
-
 
88
CR0_MP         equ    0x00000002   ;monitor fpu
-
 
89
CR0_EM         equ    0x00000004   ;fpu emulation
-
 
90
CR0_TS         equ    0x00000008   ;task switch
-
 
91
CR0_ET         equ    0x00000010   ;extension type hardcoded to 1
-
 
92
CR0_NE         equ    0x00000020   ;numeric error
-
 
93
CR0_WP         equ    0x00010000   ;write protect
-
 
94
CR0_AM         equ    0x00040000   ;alignment check
-
 
95
CR0_NW         equ    0x20000000   ;not write-through
-
 
96
CR0_CD         equ    0x40000000   ;cache disable
-
 
97
CR0_PG         equ    0x80000000   ;paging
-
 
98
 
-
 
99
 
-
 
100
CR4_VME        equ    0x0001
88
CR4_PVI        equ    0x0002
101
CR4_PVI        equ    0x0002
89
CR4_TSD        equ    0x0004
102
CR4_TSD        equ    0x0004
90
CR4_DE         equ    0x0008
103
CR4_DE         equ    0x0008
91
CR4_PSE        equ    0x0010
104
CR4_PSE        equ    0x0010
92
CR4_PAE        equ    0x0020
105
CR4_PAE        equ    0x0020
93
CR4_MCE        equ    0x0040
106
CR4_MCE        equ    0x0040
94
CR4_PGE        equ    0x0080
107
CR4_PGE        equ    0x0080
95
CR4_PCE        equ    0x0100
108
CR4_PCE        equ    0x0100
96
CR4_OSFXSR     equ    0x0200
109
CR4_OSFXSR     equ    0x0200
97
CR4_OSXMMEXPT  equ    0x0400
110
CR4_OSXMMEXPT  equ    0x0400
98
 
111
 
99
 
112
SSE_IE         equ    0x0001
-
 
113
SSE_DE         equ    0x0002
-
 
114
SSE_ZE         equ    0x0004
-
 
115
SSE_OE         equ    0x0008
-
 
116
SSE_UE         equ    0x0010
-
 
117
SSE_PE         equ    0x0020
-
 
118
SSE_DAZ        equ    0x0040
-
 
119
SSE_IM         equ    0x0080
-
 
120
SSE_DM         equ    0x0100
-
 
121
SSE_ZM         equ    0x0200
-
 
122
SSE_OM         equ    0x0400
-
 
123
SSE_UM         equ    0x0800
-
 
124
SSE_PM         equ    0x1000
-
 
125
SSE_FZ         equ    0x8000
-
 
126
 
-
 
127
SSE_INIT equ (SSE_IM+SSE_DM+SSE_ZM+SSE_OM+SSE_UM+SSE_PM)
100
 
128
 
101
OS_BASE             equ 0;  0x80400000
129
OS_BASE             equ 0;  0x80400000
102
 
130
 
103
window_data         equ OS_BASE+0x0000000
131
window_data         equ OS_BASE+0x0000000
104
 
132
 
105
CURRENT_TASK        equ OS_BASE+0x0003000
133
CURRENT_TASK        equ OS_BASE+0x0003000
106
TASK_COUNT          equ OS_BASE+0x0003004
134
TASK_COUNT          equ OS_BASE+0x0003004
107
TASK_BASE           equ OS_BASE+0x0003010
135
TASK_BASE           equ OS_BASE+0x0003010
108
TASK_DATA           equ OS_BASE+0x0003020
136
TASK_DATA           equ OS_BASE+0x0003020
109
TASK_EVENT          equ OS_BASE+0x0003020
137
TASK_EVENT          equ OS_BASE+0x0003020
110
 
138
 
111
save_syscall_data   equ OS_BASE+0x0005000
139
save_syscall_data   equ OS_BASE+0x0005000
112
 
140
 
113
;mouseunder          equ OS_BASE+0x0006900
141
;mouseunder          equ OS_BASE+0x0006900
114
FLOPPY_BUFF         equ OS_BASE+0x0008000
142
FLOPPY_BUFF         equ OS_BASE+0x0008000
115
ACTIVE_PROC_STACK   equ OS_BASE+0x000A400
143
ACTIVE_PROC_STACK   equ OS_BASE+0x000A400
116
idts                equ OS_BASE+0x000B100
144
idts                equ OS_BASE+0x000B100
117
WIN_STACK           equ OS_BASE+0x000C000
145
WIN_STACK           equ OS_BASE+0x000C000
118
WIN_POS             equ OS_BASE+0x000C400
146
WIN_POS             equ OS_BASE+0x000C400
119
FDD_DATA            equ OS_BASE+0x000D000
147
FDD_DATA            equ OS_BASE+0x000D000
120
 
148
 
121
ENABLE_TASKSWITCH   equ OS_BASE+0x000E000
149
ENABLE_TASKSWITCH   equ OS_BASE+0x000E000
122
PUTPIXEL            equ OS_BASE+0x000E020
150
PUTPIXEL            equ OS_BASE+0x000E020
123
GETPIXEL            equ OS_BASE+0x000E024
151
GETPIXEL            equ OS_BASE+0x000E024
124
BANK_SWITCH         equ OS_BASE+0x000E030
152
BANK_SWITCH         equ OS_BASE+0x000E030
125
 
153
 
126
MOUSE_PICTURE       equ OS_BASE+0x000F200
154
MOUSE_PICTURE       equ OS_BASE+0x000F200
127
MOUSE_VISIBLE       equ OS_BASE+0x000F204
155
MOUSE_VISIBLE       equ OS_BASE+0x000F204
128
XY_TEMP             equ OS_BASE+0x000F300
156
XY_TEMP             equ OS_BASE+0x000F300
129
KEY_COUNT           equ OS_BASE+0x000F400
157
KEY_COUNT           equ OS_BASE+0x000F400
130
KEY_BUFF            equ OS_BASE+0x000F401
158
KEY_BUFF            equ OS_BASE+0x000F401
131
 
159
 
132
BTN_COUNT           equ OS_BASE+0x000F500
160
BTN_COUNT           equ OS_BASE+0x000F500
133
BTN_BUFF            equ OS_BASE+0x000F501
161
BTN_BUFF            equ OS_BASE+0x000F501
134
 
162
 
135
TSC                 equ OS_BASE+0x000F600
163
TSC                 equ OS_BASE+0x000F600
136
MOUSE_PORT          equ OS_BASE+0x000F604
164
MOUSE_PORT          equ OS_BASE+0x000F604
137
 
165
 
138
PS2_CHUNK           equ OS_BASE+0x000FB00
166
PS2_CHUNK           equ OS_BASE+0x000FB00
139
MOUSE_X             equ OS_BASE+0x000FB0A
167
MOUSE_X             equ OS_BASE+0x000FB0A
140
MOUSE_Y             equ OS_BASE+0x000FB0C
168
MOUSE_Y             equ OS_BASE+0x000FB0C
141
 
169
 
142
MOUSE_COLOR_MEM     equ OS_BASE+0x000FB10
170
MOUSE_COLOR_MEM     equ OS_BASE+0x000FB10
143
COLOR_TEMP          equ OS_BASE+0x000FB30
171
COLOR_TEMP          equ OS_BASE+0x000FB30
144
BTN_DOWN            equ OS_BASE+0x000FB40
172
BTN_DOWN            equ OS_BASE+0x000FB40
145
MOUSE_DOWN          equ OS_BASE+0x000FB44
173
MOUSE_DOWN          equ OS_BASE+0x000FB44
146
X_UNDER             equ OS_BASE+0x000FB4A
174
X_UNDER             equ OS_BASE+0x000FB4A
147
Y_UNDER             equ OS_BASE+0x000FB4C
175
Y_UNDER             equ OS_BASE+0x000FB4C
148
;ScreenBPP           equ OS_BASE+0x000FBF1
176
;ScreenBPP           equ OS_BASE+0x000FBF1
149
MOUSE_BUFF_COUNT    equ OS_BASE+0x000FCFF
177
MOUSE_BUFF_COUNT    equ OS_BASE+0x000FCFF
150
HD_CACHE_ENT        equ OS_BASE+0x000FE10
178
HD_CACHE_ENT        equ OS_BASE+0x000FE10
151
LFBAddress          equ OS_BASE+0x000FE80
179
LFBAddress          equ OS_BASE+0x000FE80
152
MEM_AMOUNT          equ OS_BASE+0x000FE8C
180
MEM_AMOUNT          equ OS_BASE+0x000FE8C
153
LFBSize             equ OS_BASE+0x02f9050
181
LFBSize             equ OS_BASE+0x02f9050
154
 
182
 
155
SCR_X_SIZE          equ OS_BASE+0x000FE00
183
SCR_X_SIZE          equ OS_BASE+0x000FE00
156
SCR_Y_SIZE          equ OS_BASE+0x000FE04
184
SCR_Y_SIZE          equ OS_BASE+0x000FE04
157
SCR_BYTES_PER_LINE  equ OS_BASE+0x000FE08
185
SCR_BYTES_PER_LINE  equ OS_BASE+0x000FE08
158
SCR_MODE            equ OS_BASE+0x000FE0C
186
SCR_MODE            equ OS_BASE+0x000FE0C
159
 
187
 
160
BTN_ADDR            equ OS_BASE+0x000FE88
188
BTN_ADDR            equ OS_BASE+0x000FE88
161
SYS_SHUTDOWN        equ OS_BASE+0x000FF00
189
SYS_SHUTDOWN        equ OS_BASE+0x000FF00
162
TASK_ACTIVATE       equ OS_BASE+0x000FF01
190
TASK_ACTIVATE       equ OS_BASE+0x000FF01
163
 
191
 
164
REDRAW_BACKGROUND   equ OS_BASE+0x000FFF0
192
REDRAW_BACKGROUND   equ OS_BASE+0x000FFF0
165
BANK_RW             equ OS_BASE+0x000FFF2
193
BANK_RW             equ OS_BASE+0x000FFF2
166
MOUSE_BACKGROUND    equ OS_BASE+0x000FFF4
194
MOUSE_BACKGROUND    equ OS_BASE+0x000FFF4
167
DONT_DRAW_MOUSE     equ OS_BASE+0x000FFF5
195
DONT_DRAW_MOUSE     equ OS_BASE+0x000FFF5
168
DONT_SWITCH         equ OS_BASE+0x000FFFF
196
DONT_SWITCH         equ OS_BASE+0x000FFFF
169
 
197
 
170
STACK_TOP           equ OS_BASE+0x003EC00
198
STACK_TOP           equ OS_BASE+0x003EC00
171
 
199
 
172
FONT_II             equ OS_BASE+0x003EC00
200
FONT_II             equ OS_BASE+0x003EC00
173
FONT_I              equ OS_BASE+0x003F600
201
FONT_I              equ OS_BASE+0x003F600
174
DISK_DATA           equ OS_BASE+0x0040000
202
DISK_DATA           equ OS_BASE+0x0040000
175
PROC_BASE           equ OS_BASE+0x0080000
203
PROC_BASE           equ OS_BASE+0x0080000
176
TMP_BUFF            equ OS_BASE+0x0090000
204
TMP_BUFF            equ OS_BASE+0x0090000
177
 
205
 
178
VGABasePtr          equ OS_BASE+0x00A0000
206
VGABasePtr          equ OS_BASE+0x00A0000
179
 
207
 
180
RAMDISK             equ OS_BASE+0x0100000
208
RAMDISK             equ OS_BASE+0x0100000
181
RAMDISK_FAT         equ OS_BASE+0x0280000
209
RAMDISK_FAT         equ OS_BASE+0x0280000
182
FLOPPY_FAT          equ OS_BASE+0x0282000
210
FLOPPY_FAT          equ OS_BASE+0x0282000
183
SB16_Status         equ OS_BASE+0x02B0000
211
SB16_Status         equ OS_BASE+0x02B0000
184
BUTTON_INFO         equ OS_BASE+0x02C0000
212
BUTTON_INFO         equ OS_BASE+0x02C0000
185
RESERVED_PORTS      equ OS_BASE+0x02D0000
213
RESERVED_PORTS      equ OS_BASE+0x02D0000
186
IRQ_SAVE            equ OS_BASE+0x02E0000
214
IRQ_SAVE            equ OS_BASE+0x02E0000
187
SYS_VAR             equ OS_BASE+0x02f0000
215
SYS_VAR             equ OS_BASE+0x02f0000
188
IMG_BACKGROUND      equ OS_BASE+0x0300000
216
IMG_BACKGROUND      equ OS_BASE+0x0300000
189
WinMapAddress       equ OS_BASE+0x0460000
217
WinMapAddress       equ OS_BASE+0x0460000
190
display_data        equ OS_BASE+0x0460000
218
display_data        equ OS_BASE+0x0460000
191
HD_CACHE            equ OS_BASE+0x0600000
219
HD_CACHE            equ OS_BASE+0x0600000
192
stack_data_start    equ OS_BASE+0x0700000
220
stack_data_start    equ OS_BASE+0x0700000
193
eth_data_start      equ OS_BASE+0x0700000
221
eth_data_start      equ OS_BASE+0x0700000
194
stack_data          equ OS_BASE+0x0704000
222
stack_data          equ OS_BASE+0x0704000
195
stack_data_end      equ OS_BASE+0x071ffff
223
stack_data_end      equ OS_BASE+0x071ffff
196
VMODE_BASE          equ OS_BASE+0x0760000
224
VMODE_BASE          equ OS_BASE+0x0760000
197
resendQ             equ OS_BASE+0x0770000
225
resendQ             equ OS_BASE+0x0770000
198
 
226
 
199
;skin_data           equ OS_BASE+0x0778000
227
;skin_data           equ OS_BASE+0x0778000
200
 
228
 
201
draw_data           equ OS_BASE+0x0800000
229
draw_data           equ OS_BASE+0x0800000
202
sysint_stack_data   equ OS_BASE+0x0803000
230
sysint_stack_data   equ OS_BASE+0x0803000
203
 
231
 
204
tss_data            equ OS_BASE+0x0920000
232
tss_data            equ OS_BASE+0x0920000
205
 
233
 
206
;tmp_pg_dir          equ  OS_BASE+0x00050000
234
;tmp_pg_dir          equ  OS_BASE+0x00050000
207
;tmp_page_map        equ  0x00051000
235
;tmp_page_map        equ  0x00051000
208
;master_tab          equ  0x80200000
236
;master_tab          equ  0x80200000
209
 
237
 
210
pages_tab            equ  0x60000000
238
pages_tab            equ  0x60000000
211
master_tab           equ  0x60180000
239
master_tab           equ  0x60180000
212
 
240
 
213
sys_pgdir            equ  OS_BASE+0x00050000
241
sys_pgdir            equ  OS_BASE+0x00050000
214
sys_master_tab       equ  OS_BASE+0x00051000
242
sys_master_tab       equ  OS_BASE+0x00051000
215
sys_pgmap            equ  OS_BASE+0x00052000
243
sys_pgmap            equ  OS_BASE+0x00052000
216
 
244
 
217
;lfb_start            equ  0x00800000
245
;lfb_start            equ  0x00800000
218
 
246
 
219
;new_app_pdir          equ OS_BASE+0x01000000
247
;new_app_pdir          equ OS_BASE+0x01000000
220
;new_app_master_table  equ OS_BASE+0x01001000
248
;new_app_master_table  equ OS_BASE+0x01001000
221
;new_app_ptable        equ OS_BASE+0x01002000
249
;new_app_ptable        equ OS_BASE+0x01002000
222
 
250
 
223
new_app_base          equ  0x60400000
251
new_app_base          equ  0x60400000
224
 
252
 
225
twdw                  equ (CURRENT_TASK-window_data)
253
twdw                  equ (CURRENT_TASK-window_data)
226
 
254
 
227
std_application_base_address   equ new_app_base
255
std_application_base_address   equ new_app_base
228
 
256
 
229
PAGES_USED           equ 4
257
PAGES_USED           equ 4
230
 
258
 
231
PG_UNMAP             equ 0x000
259
PG_UNMAP             equ 0x000
232
PG_MAP               equ 0x001
260
PG_MAP               equ 0x001
233
PG_WRITE             equ 0x002
261
PG_WRITE             equ 0x002
234
PG_SW                equ 0x003
262
PG_SW                equ 0x003
235
PG_USER              equ 0x005
263
PG_USER              equ 0x005
236
PG_UW                equ 0x007
264
PG_UW                equ 0x007
237
PG_NOCACHE           equ 0x018
265
PG_NOCACHE           equ 0x018
238
PG_LARGE             equ 0x080
266
PG_LARGE             equ 0x080
239
PG_GLOBAL            equ 0x100
267
PG_GLOBAL            equ 0x100
240
 
268
 
241
;;;;;;;;;;;boot time variables
269
;;;;;;;;;;;boot time variables
242
 
270
 
243
;BOOT_BPP            equ 0x9000    ;byte   bits per pixel
271
;BOOT_BPP            equ 0x9000    ;byte   bits per pixel
244
BOOT_SCANLINE       equ 0x9001    ;word   scanline length
272
BOOT_SCANLINE       equ 0x9001    ;word   scanline length
245
BOOT_VESA_MODE      equ 0x9008    ;word   vesa video mode
273
BOOT_VESA_MODE      equ 0x9008    ;word   vesa video mode
246
;;BOOT_X_RES          equ 0x900A    ;word   X res
274
;;BOOT_X_RES          equ 0x900A    ;word   X res
247
;;BOOT_Y_RES          equ 0x900C    ;word   Y res
275
;;BOOT_Y_RES          equ 0x900C    ;word   Y res
248
;;BOOT_MOUSE_PORT     equ 0x9010    ;byte   mouse port  - not used
276
;;BOOT_MOUSE_PORT     equ 0x9010    ;byte   mouse port  - not used
249
BOOT_BANK_SW        equ 0x9014    ;dword  Vesa 1.2 pm bank switch
277
BOOT_BANK_SW        equ 0x9014    ;dword  Vesa 1.2 pm bank switch
250
BOOT_LFB            equ 0x9018    ;dword  Vesa 2.0 LFB address
278
BOOT_LFB            equ 0x9018    ;dword  Vesa 2.0 LFB address
251
BOOT_MTRR           equ 0x901C    ;byte   0 or 1 : enable MTRR graphics acceleration
279
BOOT_MTRR           equ 0x901C    ;byte   0 or 1 : enable MTRR graphics acceleration
252
BOOT_LOG            equ 0x901D    ;byte   not used anymore (0 or 1 : enable system log display)
280
BOOT_LOG            equ 0x901D    ;byte   not used anymore (0 or 1 : enable system log display)
253
BOOT_DIRECT_LFB     equ 0x901E    ;byte   0 or 1 : enable direct lfb write, paging disabled
281
BOOT_DIRECT_LFB     equ 0x901E    ;byte   0 or 1 : enable direct lfb write, paging disabled
254
BOOT_PCI_DATA       equ 0x9020    ;8bytes pci data
282
BOOT_PCI_DATA       equ 0x9020    ;8bytes pci data
255
BOOT_VRR            equ 0x9030    ;byte   VRR start enabled 1, 2-no
283
BOOT_VRR            equ 0x9030    ;byte   VRR start enabled 1, 2-no
256
BOOT_IDE_BASE_ADDR  equ 0x9031   ;word   IDEContrRegsBaseAddr
284
BOOT_IDE_BASE_ADDR  equ 0x9031   ;word   IDEContrRegsBaseAddr
257
BOOT_MEM_AMOUNT     equ 0x9034    ;dword  memory amount
285
BOOT_MEM_AMOUNT     equ 0x9034    ;dword  memory amount
258
 
286
 
259
TMP_FILE_NAME       equ     0
287
TMP_FILE_NAME       equ     0
260
TMP_CMD_LINE        equ  1024
288
TMP_CMD_LINE        equ  1024
261
TMP_ICON_OFFS       equ  1280
289
TMP_ICON_OFFS       equ  1280
262
 
290
 
263
 
291
 
264
EVENT_REDRAW       equ 0x00000001
292
EVENT_REDRAW       equ 0x00000001
265
EVENT_KEY          equ 0x00000002
293
EVENT_KEY          equ 0x00000002
266
EVENT_BUTTON       equ 0x00000004
294
EVENT_BUTTON       equ 0x00000004
267
EVENT_BACKGROUND   equ 0x00000010
295
EVENT_BACKGROUND   equ 0x00000010
268
EVENT_MOUSE        equ 0x00000020
296
EVENT_MOUSE        equ 0x00000020
269
EVENT_IPC          equ 0x00000040
297
EVENT_IPC          equ 0x00000040
270
EVENT_NETWORK      equ 0x00000080
298
EVENT_NETWORK      equ 0x00000080
271
EVENT_DEBUG        equ 0x00000100
299
EVENT_DEBUG        equ 0x00000100
272
EVENT_NOTIFY       equ 0x00000200
300
EVENT_NOTIFY       equ 0x00000200
273
 
301
 
274
EV_INTR            equ 1
302
EV_INTR            equ 1
275
 
303
 
276
struc SYS_VARS
304
struc SYS_VARS
277
{ .bpp            dd ?
305
{ .bpp            dd ?
278
  .scanline       dd ?
306
  .scanline       dd ?
279
  .vesa_mode      dd ?
307
  .vesa_mode      dd ?
280
  .x_res          dd ?
308
  .x_res          dd ?
281
  .y_res          dd ?
309
  .y_res          dd ?
282
  .cpu_caps       dd ?
310
  .cpu_caps       dd ?
283
                  dd ?
311
                  dd ?
284
                  dd ?
312
                  dd ?
285
                  dd ?
313
                  dd ?
286
}
314
}
287
 
315
 
288
 
316
 
289
struc BOOT_DATA
317
struc BOOT_DATA
290
{ .bpp            dd ?
318
{ .bpp            dd ?
291
  .scanline       dd ?
319
  .scanline       dd ?
292
  .vesa_mode      dd ?
320
  .vesa_mode      dd ?
293
  .x_res          dd ?
321
  .x_res          dd ?
294
  .y_res          dd ?
322
  .y_res          dd ?
295
  .mouse_port     dd ?
323
  .mouse_port     dd ?
296
  .bank_switch    dd ?
324
  .bank_switch    dd ?
297
  .lfb            dd ?
325
  .lfb            dd ?
298
  .vesa_mem       dd ?
326
  .vesa_mem       dd ?
299
  .log            dd ?
327
  .log            dd ?
300
  .direct_lfb     dd ?
328
  .direct_lfb     dd ?
301
  .pci_data       dd ?
329
  .pci_data       dd ?
302
;                  dd ?
330
;                  dd ?
303
  .vrr            dd ?
331
  .vrr            dd ?
304
  .ide_base       dd ?
332
  .ide_base       dd ?
305
  .mem_amount     dd ?
333
  .mem_amount     dd ?
306
  .pages_count    dd ?
334
  .pages_count    dd ?
307
  .pagemap_size   dd ?
335
  .pagemap_size   dd ?
308
  .kernel_max     dd ?
336
  .kernel_max     dd ?
309
  .kernel_pages   dd ?
337
  .kernel_pages   dd ?
310
  .kernel_tables  dd ?
338
  .kernel_tables  dd ?
311
 
339
 
312
  .cpu_vendor     dd ?
340
  .cpu_vendor     dd ?
313
                  dd ?
341
                  dd ?
314
                  dd ?
342
                  dd ?
315
  .cpu_sign       dd ?
343
  .cpu_sign       dd ?
316
  .cpu_info       dd ?
344
  .cpu_info       dd ?
317
  .cpu_caps       dd ?
345
  .cpu_caps       dd ?
318
                  dd ?
346
                  dd ?
319
                  dd ?
347
                  dd ?
320
}
348
}
321
 
349
 
322
virtual at 0
350
virtual at 0
323
  BOOT_DATA BOOT_DATA
351
  BOOT_DATA BOOT_DATA
324
end virtual
352
end virtual
325
 
353
 
326
struc PG_DATA
354
struc PG_DATA
327
{ .mem_amount        dd ?
355
{ .mem_amount        dd ?
328
  .vesa_mem          dd ?
356
  .vesa_mem          dd ?
329
  .pages_count       dd ?
357
  .pages_count       dd ?
330
  .pages_free        dd ?
358
  .pages_free        dd ?
331
  .pages_faults      dd ?
359
  .pages_faults      dd ?
332
  .pagemap_size      dd ?
360
  .pagemap_size      dd ?
333
  .kernel_max        dd ?
361
  .kernel_max        dd ?
334
  .kernel_pages      dd ?
362
  .kernel_pages      dd ?
335
  .kernel_tables     dd ?
363
  .kernel_tables     dd ?
336
  .sys_page_dir      dd ?
364
  .sys_page_dir      dd ?
337
  .pg_mutex          dd ?
365
  .pg_mutex          dd ?
338
  .tmp_task_mutex    dd ?
366
  .tmp_task_mutex    dd ?
339
}
367
}
340
 
368
 
341
struc LIB
369
struc LIB
342
{ .lib_name          rb 16
370
{ .lib_name          rb 16
343
  .lib_base          dd ?
371
  .lib_base          dd ?
344
  .lib_start         dd ?
372
  .lib_start         dd ?
345
  .export            dd ?
373
  .export            dd ?
346
  .import            dd ?
374
  .import            dd ?
347
}
375
}
348
 
376
 
349
struc SRV
377
struc SRV
350
{ .srv_name          rb 16
378
{ .srv_name          rb 16
351
  .magic             dd ?
379
  .magic             dd ?
352
  .size              dd ?
380
  .size              dd ?
353
  .lib               dd ?
381
  .lib               dd ?
354
  .srv_proc          dd ?
382
  .srv_proc          dd ?
355
}
383
}
356
 
384
 
357
struc COFF_HEADER
385
struc COFF_HEADER
358
{  .machine          dw ?
386
{  .machine          dw ?
359
   .nSections        dw ?
387
   .nSections        dw ?
360
   .DataTime         dd ?
388
   .DataTime         dd ?
361
   .pSymTable        dd ?
389
   .pSymTable        dd ?
362
   .nSymbols         dd ?
390
   .nSymbols         dd ?
363
   .optHeader        dw ?
391
   .optHeader        dw ?
364
   .flags            dw ?
392
   .flags            dw ?
365
};
393
};
366
 
394
 
367
 
395
 
368
struc COFF_SECTION
396
struc COFF_SECTION
369
{  .Name             rb 8
397
{  .Name             rb 8
370
   .VirtualSize      dd ?
398
   .VirtualSize      dd ?
371
   .VirtualAddress   dd ?
399
   .VirtualAddress   dd ?
372
   .SizeOfRawData    dd ?
400
   .SizeOfRawData    dd ?
373
   .PtrRawData       dd ?
401
   .PtrRawData       dd ?
374
   .PtrReloc         dd ?
402
   .PtrReloc         dd ?
375
   .PtrLinenumbers   dd ?
403
   .PtrLinenumbers   dd ?
376
   .NumReloc         dw ?
404
   .NumReloc         dw ?
377
   .NumLinenum       dw ?
405
   .NumLinenum       dw ?
378
   .Characteristics  dd ?
406
   .Characteristics  dd ?
379
}
407
}
380
 
408
 
381
struc COFF_RELOC
409
struc COFF_RELOC
382
{  .VirtualAddress   dd ?
410
{  .VirtualAddress   dd ?
383
   .SymIndex         dd ?
411
   .SymIndex         dd ?
384
   .Type             dw ?
412
   .Type             dw ?
385
}
413
}
386
 
414
 
387
struc COFF_SYM
415
struc COFF_SYM
388
{  .Name             rb 8
416
{  .Name             rb 8
389
   .Value            dd ?
417
   .Value            dd ?
390
   .SectionNumber    dw ?
418
   .SectionNumber    dw ?
391
   .Type             dw ?
419
   .Type             dw ?
392
   .StorageClass     db ?
420
   .StorageClass     db ?
393
   .NumAuxSymbols    db ?
421
   .NumAuxSymbols    db ?
394
}
422
}
395
 
423
 
396
struc IOCTL
424
struc IOCTL
397
{  .handle           dd ?
425
{  .handle           dd ?
398
   .io_code          dd ?
426
   .io_code          dd ?
399
   .input            dd ?
427
   .input            dd ?
400
   .inp_size         dd ?
428
   .inp_size         dd ?
401
   .output           dd ?
429
   .output           dd ?
402
   .out_size         dd ?
430
   .out_size         dd ?
403
}
431
}
404
 
432
 
405
virtual at 0
433
virtual at 0
406
  IOCTL IOCTL
434
  IOCTL IOCTL
407
end virtual
435
end virtual
408
 
436
 
409
 
437
 
410
SRV_SIZE equ 32
438
SRV_SIZE equ 32
411
 
439
 
412
virtual at 0
440
virtual at 0
413
  LIB LIB
441
  LIB LIB
414
end virtual
442
end virtual
415
 
443
 
416
virtual at 0
444
virtual at 0
417
  SRV SRV
445
  SRV SRV
418
end virtual
446
end virtual
419
 
447
 
420
virtual at 0
448
virtual at 0
421
  CFS COFF_SECTION
449
  CFS COFF_SECTION
422
end virtual
450
end virtual
423
 
451
 
424
virtual at 0
452
virtual at 0
425
  CRELOC COFF_RELOC
453
  CRELOC COFF_RELOC
426
end virtual
454
end virtual
427
 
455
 
428
virtual at 0
456
virtual at 0
429
  CSYM COFF_SYM
457
  CSYM COFF_SYM
430
end virtual
458
end virtual
431
 
459
 
432
virtual at 0
460
virtual at 0
433
  CFH COFF_HEADER
461
  CFH COFF_HEADER
434
end virtual
462
end virtual