source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS_Configurator_v2/Src/Menupages/IdeControllerMenu.asm@ 629

Last change on this file since 629 was 625, checked in by Krister Nordvall, 19 months ago

Changes:

  • Added a configuration option to let the BIOS store RamVars to an UMB when Full operating mode is enabled. This is primarily for XT class machines with RAM in the UMA (which apparently is a common thing these days).
  • Added two new builds specifically for IBM PS/2 machines. This is for support of the new McIDE adapter from the guys at zzxio.com. Note that the additional hardware specific code (under the USE_PS2 define) is for the PS/2 machines themselves and not for the McIDE adapters, so any controller in an IBM PS/2 machine can be used with the USE_PS2 define.
  • Moved pColorTheme out of the range of ROMVARS being copied over when doing "Load old settings from EEPROM" in XTIDECFG. This fixed a serious bug from r592 where loading a BIOS from file and then loading the old settings from ROM would corrupt 7 bytes of code somewhere in the loaded BIOS.
  • Optimizations (speed and size) to the library. Browsing the menus in XTIDECFG should now feel a little less sluggish.
  • Hopefully fixed a problem with the PostCommitHook script where it sometimes wouldn't find the CommitInProgress file. I say hopefully because testing this is a nightmare.
File size: 26.7 KB
RevLine 
[57]1; Project name : XTIDE Universal BIOS Configurator v2
2; Description : "IDE Controller" menu structs and functions.
3
[376]4;
[399]5; XTIDE Universal BIOS and Associated Tools
[625]6; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2023 by XTIDE Universal BIOS Team.
[376]7;
8; This program is free software; you can redistribute it and/or modify
9; it under the terms of the GNU General Public License as published by
10; the Free Software Foundation; either version 2 of the License, or
11; (at your option) any later version.
[399]12;
[376]13; This program is distributed in the hope that it will be useful,
14; but WITHOUT ANY WARRANTY; without even the implied warranty of
15; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
[399]16; GNU General Public License for more details.
[376]17; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
[399]18;
[376]19
[57]20; Section containing initialized data
21SECTION .data
22
23ALIGN WORD_ALIGN
24g_MenupageForIdeControllerMenu:
25istruc MENUPAGE
26 at MENUPAGE.fnEnter, dw IdeControllerMenu_EnterMenuOrModifyItemVisibility
[59]27 at MENUPAGE.fnBack, dw ConfigurationMenu_EnterMenuOrModifyItemVisibility
[546]28 at MENUPAGE.wMenuitems, dw 11
[57]29iend
30
31g_MenuitemIdeControllerBackToConfigurationMenu:
32istruc MENUITEM
33 at MENUITEM.fnActivate, dw ConfigurationMenu_EnterMenuOrModifyItemVisibility
34 at MENUITEM.szName, dw g_szItemBackToCfgMenu
35 at MENUITEM.szQuickInfo, dw g_szNfoIdeBackToCfgMenu
36 at MENUITEM.szHelp, dw g_szNfoIdeBackToCfgMenu
37 at MENUITEM.bFlags, db FLG_MENUITEM_VISIBLE
38 at MENUITEM.bType, db TYPE_MENUITEM_PAGEBACK
39iend
40
41g_MenuitemIdeControllerMasterDrive:
42istruc MENUITEM
43 at MENUITEM.fnActivate, dw MasterDrive
44 at MENUITEM.szName, dw g_szItemIdeMaster
45 at MENUITEM.szQuickInfo, dw g_szNfoIdeMaster
46 at MENUITEM.szHelp, dw g_szNfoIdeMaster
47 at MENUITEM.bFlags, db FLG_MENUITEM_VISIBLE
48 at MENUITEM.bType, db TYPE_MENUITEM_PAGENEXT
49iend
50
51g_MenuitemIdeControllerSlaveDrive:
52istruc MENUITEM
53 at MENUITEM.fnActivate, dw SlaveDrive
54 at MENUITEM.szName, dw g_szItemIdeSlave
55 at MENUITEM.szQuickInfo, dw g_szNfoIdeSlave
56 at MENUITEM.szHelp, dw g_szNfoIdeSlave
57 at MENUITEM.bFlags, db FLG_MENUITEM_VISIBLE
58 at MENUITEM.bType, db TYPE_MENUITEM_PAGENEXT
59iend
60
[153]61g_MenuitemIdeControllerDevice:
[57]62istruc MENUITEM
[108]63 at MENUITEM.fnActivate, dw Menuitem_ActivateMultichoiceSelectionForMenuitemInDSSI
[233]64 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteLookupValueStringToBufferInESDIfromRawItemInDSSI
[153]65 at MENUITEM.szName, dw g_szItemIdeDevice
66 at MENUITEM.szQuickInfo, dw g_szNfoIdeDevice
67 at MENUITEM.szHelp, dw g_szNfoIdeDevice
[199]68 at MENUITEM.bFlags, db FLG_MENUITEM_VISIBLE | FLG_MENUITEM_BYTEVALUE | FLG_MENUITEM_MODIFY_MENU
[108]69 at MENUITEM.bType, db TYPE_MENUITEM_MULTICHOICE
[57]70 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
[153]71 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgDevice
72 at MENUITEM.itemValue + ITEM_VALUE.szMultichoice, dw g_szMultichoiceCfgDevice
73 at MENUITEM.itemValue + ITEM_VALUE.rgwChoiceToValueLookup, dw g_rgwChoiceToValueLookupForDevice
74 at MENUITEM.itemValue + ITEM_VALUE.rgszValueToStringLookup, dw g_rgszValueToStringLookupForDevice
[199]75 at MENUITEM.itemValue + ITEM_VALUE.fnValueWriter, dw IdeControllerMenu_WriteDevice
[57]76iend
77
78g_MenuitemIdeControllerCommandBlockAddress:
79istruc MENUITEM
80 at MENUITEM.fnActivate, dw Menuitem_ActivateHexInputForMenuitemInDSSI
81 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteHexValueStringToBufferInESDIfromItemInDSSI
82 at MENUITEM.szName, dw g_szItemIdeCmdPort
83 at MENUITEM.szQuickInfo, dw g_szNfoIdeCmdPort
84 at MENUITEM.szHelp, dw g_szHelpIdeCmdPort
[502]85 at MENUITEM.bFlags, db FLG_MENUITEM_VISIBLE
[57]86 at MENUITEM.bType, db TYPE_MENUITEM_HEX
87 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
88 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgIdeCmdPort
89 at MENUITEM.itemValue + ITEM_VALUE.wMinValue, dw 0
90 at MENUITEM.itemValue + ITEM_VALUE.wMaxValue, dw -1
91iend
92
93g_MenuitemIdeControllerControlBlockAddress:
94istruc MENUITEM
95 at MENUITEM.fnActivate, dw Menuitem_ActivateHexInputForMenuitemInDSSI
96 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteHexValueStringToBufferInESDIfromItemInDSSI
97 at MENUITEM.szName, dw g_szItemIdeCtrlPort
98 at MENUITEM.szQuickInfo, dw g_szNfoIdeCtrlPort
99 at MENUITEM.szHelp, dw g_szHelpIdeCtrlPort
[483]100 at MENUITEM.bFlags, db NULL
[57]101 at MENUITEM.bType, db TYPE_MENUITEM_HEX
102 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
103 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgIdeCtrlPort
104 at MENUITEM.itemValue + ITEM_VALUE.wMinValue, dw 0
105 at MENUITEM.itemValue + ITEM_VALUE.wMaxValue, dw -1
106iend
107
[199]108g_MenuitemIdeControllerSerialCOM:
109istruc MENUITEM
110 at MENUITEM.fnActivate, dw Menuitem_ActivateMultichoiceSelectionForMenuitemInDSSI
[233]111 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteLookupValueStringToBufferInESDIfromRawItemInDSSI
[199]112 at MENUITEM.szName, dw g_szItemSerialCOM
113 at MENUITEM.szQuickInfo, dw g_szNfoIdeSerialCOM
114 at MENUITEM.szHelp, dw g_szHelpIdeSerialCOM
[233]115 at MENUITEM.bFlags, db FLG_MENUITEM_MODIFY_MENU | FLG_MENUITEM_BYTEVALUE | FLG_MENUITEM_CHOICESTRINGS
[242]116 at MENUITEM.bType, db TYPE_MENUITEM_MULTICHOICE
[199]117 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
118 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgDevice
119 at MENUITEM.itemValue + ITEM_VALUE.szMultichoice, dw g_szSerialCOMChoice
[233]120 at MENUITEM.itemValue + ITEM_VALUE.rgwChoiceToValueLookup, dw g_rgbChoiceToValueLookupForCOM
121 at MENUITEM.itemValue + ITEM_VALUE.rgszChoiceToStringLookup, dw g_rgszChoiceToStringLookupForCOM
[199]122 at MENUITEM.itemValue + ITEM_VALUE.fnValueWriter, dw IdeControllerMenu_SerialWriteCOM
123iend
124
125g_MenuitemIdeControllerSerialPort:
126istruc MENUITEM
127 at MENUITEM.fnActivate, dw Menuitem_ActivateHexInputForMenuitemInDSSI
128 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteHexValueStringToBufferInESDIfromItemInDSSI
129 at MENUITEM.szName, dw g_szItemSerialPort
130 at MENUITEM.szQuickInfo, dw g_szNfoIdeSerialPort
131 at MENUITEM.szHelp, dw g_szHelpIdeSerialPort
[233]132 at MENUITEM.bFlags, db FLG_MENUITEM_MODIFY_MENU | FLG_MENUITEM_BYTEVALUE
[199]133 at MENUITEM.bType, db TYPE_MENUITEM_HEX
134 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
135 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgIdeCmdPort
[233]136 at MENUITEM.itemValue + ITEM_VALUE.wMinValue, dw 8h
[592]137 at MENUITEM.itemValue + ITEM_VALUE.wMaxValue, dw 3F8h
[199]138 at MENUITEM.itemValue + ITEM_VALUE.fnValueReader, dw IdeControllerMenu_SerialReadPort
139 at MENUITEM.itemValue + ITEM_VALUE.fnValueWriter, dw IdeControllerMenu_SerialWritePort
[242]140iend
[199]141
[242]142g_MenuitemIdeControllerSerialBaud:
[199]143istruc MENUITEM
144 at MENUITEM.fnActivate, dw Menuitem_ActivateMultichoiceSelectionForMenuitemInDSSI
[233]145 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteLookupValueStringToBufferInESDIfromRawItemInDSSI
[199]146 at MENUITEM.szName, dw g_szItemSerialBaud
147 at MENUITEM.szQuickInfo, dw g_szNfoIdeSerialBaud
148 at MENUITEM.szHelp, dw g_szHelpIdeSerialBaud
[233]149 at MENUITEM.bFlags, db FLG_MENUITEM_BYTEVALUE | FLG_MENUITEM_CHOICESTRINGS
[199]150 at MENUITEM.bType, db TYPE_MENUITEM_MULTICHOICE
151 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
152 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgDevice
153 at MENUITEM.itemValue + ITEM_VALUE.szMultichoice, dw g_szSerialBaudChoice
[233]154 at MENUITEM.itemValue + ITEM_VALUE.rgwChoiceToValueLookup, dw g_rgbChoiceToValueLookupForBaud
155 at MENUITEM.itemValue + ITEM_VALUE.rgszChoiceToStringLookup, dw g_rgszChoiceToStringLookupForBaud
[199]156iend
[242]157
[57]158g_MenuitemIdeControllerEnableInterrupt:
159istruc MENUITEM
[108]160 at MENUITEM.fnActivate, dw Menuitem_ActivateMultichoiceSelectionForMenuitemInDSSI
[59]161 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteLookupValueStringToBufferInESDIfromShiftedItemInDSSI
[57]162 at MENUITEM.szName, dw g_szItemIdeEnIRQ
163 at MENUITEM.szQuickInfo, dw g_szNfoIdeEnIRQ
164 at MENUITEM.szHelp, dw g_szHelpIdeEnIRQ
[459]165 at MENUITEM.bFlags, db FLG_MENUITEM_MODIFY_MENU | FLG_MENUITEM_FLAGVALUE
[108]166 at MENUITEM.bType, db TYPE_MENUITEM_MULTICHOICE
[57]167 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
168 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgIdeEnIRQ
[108]169 at MENUITEM.itemValue + ITEM_VALUE.szMultichoice, dw g_szMultichoiceBooleanFlag
[57]170 at MENUITEM.itemValue + ITEM_VALUE.rgszValueToStringLookup, dw g_rgszValueToStringLookupForFlagBooleans
171 at MENUITEM.itemValue + ITEM_VALUE.wValueBitmask, dw 15
172iend
173
174g_MenuitemIdeControllerIdeIRQ:
175istruc MENUITEM
176 at MENUITEM.fnActivate, dw Menuitem_ActivateUnsignedInputForMenuitemInDSSI
177 at MENUITEM.fnFormatValue, dw MenuitemPrint_WriteUnsignedValueStringToBufferInESDIfromItemInDSSI
178 at MENUITEM.szName, dw g_szItemIdeIRQ
179 at MENUITEM.szQuickInfo, dw g_szNfoIdeIRQ
180 at MENUITEM.szHelp, dw g_szHelpIdeIRQ
181 at MENUITEM.bFlags, db FLG_MENUITEM_BYTEVALUE
182 at MENUITEM.bType, db TYPE_MENUITEM_UNSIGNED
183 at MENUITEM.itemValue + ITEM_VALUE.wRomvarsValueOffset, dw NULL
184 at MENUITEM.itemValue + ITEM_VALUE.szDialogTitle, dw g_szDlgIdeIRQ
185 at MENUITEM.itemValue + ITEM_VALUE.wMinValue, dw 2
186 at MENUITEM.itemValue + ITEM_VALUE.wMaxValue, dw 15
187iend
188
[153]189g_rgwChoiceToValueLookupForDevice:
190 dw DEVICE_16BIT_ATA
191 dw DEVICE_32BIT_ATA
[481]192 dw DEVICE_8BIT_ATA
193 dw DEVICE_8BIT_XTIDE_REV1
194 dw DEVICE_8BIT_XTIDE_REV2
[601]195 dw DEVICE_8BIT_XTIDE_REV2_OLIVETTI
[481]196 dw DEVICE_8BIT_XTCF_PIO8
[546]197 dw DEVICE_8BIT_XTCF_PIO8_WITH_BIU_OFFLOAD
[585]198 dw DEVICE_8BIT_XTCF_PIO16_WITH_BIU_OFFLOAD
[481]199 dw DEVICE_8BIT_XTCF_DMA
200 dw DEVICE_8BIT_JRIDE_ISA
[536]201 dw DEVICE_8BIT_ADP50L
[153]202 dw DEVICE_SERIAL_PORT
203g_rgszValueToStringLookupForDevice:
204 dw g_szValueCfgDevice16b
205 dw g_szValueCfgDevice32b
[481]206 dw g_szValueCfgDevice8b
207 dw g_szValueCfgDeviceRev1
208 dw g_szValueCfgDeviceRev2
[601]209 dw g_szValueCfgDeviceRev2Olivetti
[546]210 dw g_szValueCfgDeviceXTCFPio8
211 dw g_szValueCfgDeviceXTCFPio8WithBIUOffload
[585]212 dw g_szValueCfgDeviceXTCFPio16WithBIUOffload
[546]213 dw g_szValueCfgDeviceXTCFDMA
[481]214 dw g_szValueCfgDeviceJrIdeIsa
[536]215 dw g_szValueCfgDeviceADP50L
[153]216 dw g_szValueCfgDeviceSerial
[57]217
[233]218g_rgbChoiceToValueLookupForCOM:
219 dw '1'
220 dw '2'
221 dw '3'
222 dw '4'
223 dw '5'
224 dw '6'
225 dw '7'
226 dw '8'
227 dw '9'
228 dw 'A'
229 dw 'B'
230 dw 'C'
[625]231 dw 'x' ; must be last entry (see reader/writer routines)
[242]232g_rgszChoiceToStringLookupForCOM:
[199]233 dw g_szValueCfgCOM1
234 dw g_szValueCfgCOM2
235 dw g_szValueCfgCOM3
236 dw g_szValueCfgCOM4
237 dw g_szValueCfgCOM5
238 dw g_szValueCfgCOM6
239 dw g_szValueCfgCOM7
240 dw g_szValueCfgCOM8
241 dw g_szValueCfgCOM9
242 dw g_szValueCfgCOMA
243 dw g_szValueCfgCOMB
244 dw g_szValueCfgCOMC
245 dw g_szValueCfgCOMx
[233]246 dw NULL
[57]247
[567]248SERIAL_DEFAULT_CUSTOM_PORT EQU 300h ; can't be any of the pre-defined COM values
249SERIAL_DEFAULT_COM EQU '1'
250SERIAL_DEFAULT_BAUD EQU ((115200 / 9600) & 0xff)
[199]251
[567]252PackedCOMPortAddresses: ; COM1 - COMC (or COM12)
253 db SERIAL_COM1_IOADDRESS >> 2
[280]254 db SERIAL_COM2_IOADDRESS >> 2
255 db SERIAL_COM3_IOADDRESS >> 2
256 db SERIAL_COM4_IOADDRESS >> 2
257 db SERIAL_COM5_IOADDRESS >> 2
258 db SERIAL_COM6_IOADDRESS >> 2
259 db SERIAL_COM7_IOADDRESS >> 2
260 db SERIAL_COM8_IOADDRESS >> 2
261 db SERIAL_COM9_IOADDRESS >> 2
262 db SERIAL_COMA_IOADDRESS >> 2
263 db SERIAL_COMB_IOADDRESS >> 2
264 db SERIAL_COMC_IOADDRESS >> 2
265 db SERIAL_DEFAULT_CUSTOM_PORT >> 2 ; must be last entry (see reader/writer routines)
[242]266
[233]267g_rgbChoiceToValueLookupForBaud:
268 dw (115200 / 115200) & 0xff
269 dw (115200 / 57600) & 0xff
270 dw (115200 / 38400) & 0xff
271 dw (115200 / 28800) & 0xff
272 dw (115200 / 19200) & 0xff
273 dw (115200 / 9600) & 0xff
274 dw (115200 / 4800) & 0xff
275 dw (115200 / 2400) & 0xff
276g_rgszChoiceToStringLookupForBaud:
277 dw g_szValueCfgBaud115_2
278 dw g_szValueCfgBaud57_6
279 dw g_szValueCfgBaud38_4
280 dw g_szValueCfgBaud28_8
281 dw g_szValueCfgBaud19_2
282 dw g_szValueCfgBaud9600
283 dw g_szValueCfgBaud4800
284 dw g_szValueCfgBaud2400
285 dw NULL
[199]286
[57]287; Section containing code
288SECTION .text
289
290;--------------------------------------------------------------------
291; IdeControllerMenu_InitializeToIdevarsOffsetInBX
292; Parameters:
293; SS:BP: Menu handle
294; Returns:
295; Nothing
296; Corrupts registers:
297; AX
298;--------------------------------------------------------------------
299ALIGN JUMP_ALIGN
300IdeControllerMenu_InitializeToIdevarsOffsetInBX:
301 lea ax, [bx+IDEVARS.drvParamsMaster]
[621]302 mov [g_MenuitemIdeControllerMasterDrive+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[57]303
304 lea ax, [bx+IDEVARS.drvParamsSlave]
[621]305 mov [g_MenuitemIdeControllerSlaveDrive+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[57]306
[153]307 lea ax, [bx+IDEVARS.bDevice]
[621]308 mov [g_MenuitemIdeControllerDevice+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[57]309
[592]310%ifndef CHECK_FOR_UNUSED_ENTRYPOINTS
311%if IDEVARS.wBasePort = 0
[621]312 mov [g_MenuitemIdeControllerCommandBlockAddress+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], bx
[592]313%else
[481]314 lea ax, [bx+IDEVARS.wBasePort]
[621]315 mov [g_MenuitemIdeControllerCommandBlockAddress+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[592]316%endif
[242]317
[592]318%if IDEVARS.bSerialPort = 0
[621]319 mov [g_MenuitemIdeControllerSerialPort+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], bx
[592]320%else
[242]321 lea ax, [bx+IDEVARS.bSerialPort]
[621]322 mov [g_MenuitemIdeControllerSerialPort+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[592]323%endif
324%endif
[233]325
326 lea ax, [bx+IDEVARS.bSerialBaud]
[621]327 mov [g_MenuitemIdeControllerSerialBaud+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[242]328
[481]329 lea ax, [bx+IDEVARS.wControlBlockPort]
[621]330 mov [g_MenuitemIdeControllerControlBlockAddress+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[242]331
[233]332 lea ax, [bx+IDEVARS.bSerialCOMPortChar]
[621]333 mov [g_MenuitemIdeControllerSerialCOM+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[57]334
335 lea ax, [bx+IDEVARS.bIRQ]
[621]336 mov [g_MenuitemIdeControllerEnableInterrupt+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
337 mov [g_MenuitemIdeControllerIdeIRQ+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset], ax
[199]338
[57]339 ret
340
341
342;--------------------------------------------------------------------
343; IdeControllerMenu_EnterMenuOrModifyItemVisibility
344; Parameters:
345; SS:BP: Menu handle
346; Returns:
347; Nothing
348; Corrupts registers:
349; All, except BP
350;--------------------------------------------------------------------
351ALIGN JUMP_ALIGN
352IdeControllerMenu_EnterMenuOrModifyItemVisibility:
353 push cs
354 pop ds
[567]355 call .EnableOrDisableCommandBlockPort
[483]356 call .EnableOrDisableControlBlockPort
[459]357 call .DisableIRQchannelSelection
358 call .EnableOrDisableEnableInterrupt
[199]359 call .EnableOrDisableSerial
[57]360 mov si, g_MenupageForIdeControllerMenu
361 jmp Menupage_ChangeToNewMenupageInDSSI
362
[459]363
[57]364;--------------------------------------------------------------------
[567]365; .EnableOrDisableCommandBlockPort
366; Parameters:
367; SS:BP: Menu handle
368; Returns:
369; Nothing
370; Corrupts registers:
371; AX, BX
372;--------------------------------------------------------------------
373ALIGN JUMP_ALIGN
374.EnableOrDisableCommandBlockPort:
[592]375 mov bx, [g_MenuitemIdeControllerDevice+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[567]376 call Buffers_GetRomvarsValueToAXfromOffsetInBX
377 mov bx, g_MenuitemIdeControllerCommandBlockAddress
378 cmp al, DEVICE_SERIAL_PORT
379 je SHORT .DisableMenuitemFromCSBX
380 jmp SHORT .EnableMenuitemFromCSBX
381
382
383;--------------------------------------------------------------------
[483]384; .EnableOrDisableControlBlockPort
385; Parameters:
386; SS:BP: Menu handle
387; Returns:
388; Nothing
389; Corrupts registers:
390; AX, BX
391;--------------------------------------------------------------------
392ALIGN JUMP_ALIGN
393.EnableOrDisableControlBlockPort:
[592]394 mov bx, [g_MenuitemIdeControllerDevice+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[483]395 call Buffers_GetRomvarsValueToAXfromOffsetInBX
396 mov bx, g_MenuitemIdeControllerControlBlockAddress
397 cmp al, DEVICE_8BIT_XTCF_PIO8
[536]398 jb SHORT .EnableMenuitemFromCSBX ; Not needed for XT-CF, JR-IDE/ISA and ADP50L
[483]399 jmp SHORT .DisableMenuitemFromCSBX
400
401
402;--------------------------------------------------------------------
[459]403; .EnableOrDisableEnableInterrupt
[57]404; Parameters:
405; SS:BP: Menu handle
406; Returns:
407; Nothing
408; Corrupts registers:
409; AX, BX
410;--------------------------------------------------------------------
411ALIGN JUMP_ALIGN
[459]412.EnableOrDisableEnableInterrupt:
413 call Buffers_GetRomvarsFlagsToAX
414 mov bx, g_MenuitemIdeControllerEnableInterrupt
415 test ax, FLG_ROMVARS_MODULE_IRQ
416 jz SHORT .DisableMenuitemFromCSBX
417
[592]418 mov bx, [g_MenuitemIdeControllerDevice+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[459]419 call Buffers_GetRomvarsValueToAXfromOffsetInBX
420 mov bx, g_MenuitemIdeControllerEnableInterrupt
[567]421 cmp al, DEVICE_8BIT_XTCF_PIO8
[459]422 jae SHORT .DisableMenuitemFromCSBX
423
[567]424 call EnableMenuitemFromCSBX
[459]425 ; Fall to .EnableOrDisableIRQchannelSelection
426
427;--------------------------------------------------------------------
428; .EnableOrDisableIRQchannelSelection
429; Parameters:
430; SS:BP: Menu handle
431; Returns:
432; Nothing
433; Corrupts registers:
434; AX, BX
435;--------------------------------------------------------------------
436ALIGN JUMP_ALIGN
437.EnableOrDisableIRQchannelSelection:
[592]438 mov bx, [g_MenuitemIdeControllerEnableInterrupt+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[57]439 call Buffers_GetRomvarsValueToAXfromOffsetInBX
440 mov bx, g_MenuitemIdeControllerIdeIRQ
[109]441 test al, al
[459]442 jnz SHORT .EnableMenuitemFromCSBX
443.DisableIRQchannelSelection:
444 mov bx, g_MenuitemIdeControllerIdeIRQ
445 ; Fall to .DisableMenuitemFromCSBX
[57]446
[459]447
[57]448;--------------------------------------------------------------------
[459]449; .DisableMenuitemFromCSBX
[57]450; .EnableMenuitemFromCSBX
451; Parameters:
452; CS:BX: Ptr to MENUITEM
453; Returns:
454; Nothing
455; Corrupts registers:
456; Nothing
457;--------------------------------------------------------------------
458ALIGN JUMP_ALIGN
[459]459.DisableMenuitemFromCSBX:
[567]460 jmp DisableMenuitemFromCSBX
[57]461
462ALIGN JUMP_ALIGN
[459]463.EnableMenuitemFromCSBX:
[567]464 jmp EnableMenuitemFromCSBX
[57]465
[459]466
[592]467;--------------------------------------------------------------------
468; .EnableOrDisableSerial
469; Parameters:
470; SS:BP: Menu handle
471; Returns:
472; Nothing
473; Corrupts registers:
474; AX, BX
475;--------------------------------------------------------------------
[199]476.EnableOrDisableSerial:
[592]477 mov bx, [g_MenuitemIdeControllerDevice+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[199]478 call Buffers_GetRomvarsValueToAXfromOffsetInBX
[459]479 cmp al, DEVICE_SERIAL_PORT
[614]480 mov ax, DisableMenuitemFromCSBX
481 jne SHORT .DisableSerialControllerMenuitems
482 mov ax, EnableMenuitemFromCSBX
483 call .EnableSerialControllerMenuitems
[592]484 mov bx, [g_MenuitemIdeControllerSerialCOM+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[199]485 call Buffers_GetRomvarsValueToAXfromOffsetInBX
[567]486 cmp al, 'x'
[614]487 mov ax, DisableMenuitemFromCSBX
488 jne SHORT .DisableCustomPortMenuitem
[199]489 ret
[614]490.DisableSerialControllerMenuitems:
491.EnableSerialControllerMenuitems:
492 mov bx, g_MenuitemIdeControllerSerialCOM
493 call ax
494 mov bx, g_MenuitemIdeControllerSerialBaud
495 call ax
496.DisableCustomPortMenuitem:
497 mov bx, g_MenuitemIdeControllerSerialPort
498 jmp ax
[242]499
[592]500
[57]501;--------------------------------------------------------------------
502; MENUITEM activation functions (.fnActivate)
503; Parameters:
504; SS:BP: Ptr to MENU
505; Returns:
506; Nothing
507; Corrupts registers:
508; All, except segments
509;--------------------------------------------------------------------
510ALIGN JUMP_ALIGN
511MasterDrive:
[614]512 mov bx, g_MenuitemMasterSlaveDisableDetection
513 call DisableMenuitemFromCSBX
[621]514 mov bx, [g_MenuitemIdeControllerMasterDrive+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[57]515 jmp SHORT DisplayMasterSlaveMenu
516
517ALIGN JUMP_ALIGN
518SlaveDrive:
[614]519 mov bx, g_MenuitemMasterSlaveDisableDetection
520 call EnableMenuitemFromCSBX
[621]521 mov bx, [g_MenuitemIdeControllerSlaveDrive+MENUITEM.itemValue+ITEM_VALUE.wRomvarsValueOffset]
[57]522 ; Fall to DisplayMasterSlaveMenu
523
524DisplayMasterSlaveMenu:
525 call MasterSlaveMenu_InitializeToDrvparamsOffsetInBX
526 jmp MasterSlaveMenu_EnterMenuOrModifyItemVisibility
[199]527
[592]528
529;--------------------------------------------------------------------
530; IdeControllerMenu_WriteDevice
[199]531;
[592]532; Sets default values to ports and other device dependent stuff
[199]533;
534; Parameters:
[592]535; AX: IDE controller/Device type menu choice index
536; ES:DI: Ptr to IDEVARS.bDevice
[567]537; DS:SI: MENUITEM pointer
[199]538; Returns:
[592]539; AX: IDE controller/Device type menu choice index
[199]540; Corrupts registers:
[592]541; BX, DX
542;--------------------------------------------------------------------
[483]543ALIGN JUMP_ALIGN
[199]544IdeControllerMenu_WriteDevice:
[567]545 push di
546 push ax
[199]547
[589]548 mov bl, [es:di] ; What is the current Device we are changing from?
549 sub di, BYTE IDEVARS.bDevice - IDEVARS.wBasePort ; Get ready to set the Port addresses
550
[567]551 ; Note! AL is the choice index, not device code
[592]552 eSHL_IM al, 1 ; Selection to device code
[589]553 jz SHORT .StandardIdeDevice ; DEVICE_16BIT_ATA
554
555 cmp al, DEVICE_8BIT_ATA
556 ja SHORT .NotStandardIdeDevice
557 jb SHORT .AdvancedAtaDevice ; DEVICE_32BIT_ATA
558 test BYTE [es:ROMVARS.wFlags], FLG_ROMVARS_MODULE_8BIT_IDE
559 jmp SHORT .CheckZF
560
561.AdvancedAtaDevice:
562 test BYTE [es:ROMVARS.wFlags+1], FLG_ROMVARS_MODULE_ADVANCED_ATA >> 8
563.CheckZF:
564 jz SHORT .SupportForDeviceNotAvailable
565
566 ; Standard ATA controllers, including 8-bit mode
567.StandardIdeDevice:
[621]568 ; Enable IRQ for standard ATA, but only if MODULE_IRQ is included
[607]569
[589]570 lea ax, [di-ROMVARS.ideVars0+IDEVARS.wBasePort]
571 mov bl, IDEVARS_size
572 div bl
[621]573
574 test BYTE [es:ROMVARS.wFlags+1], FLG_ROMVARS_MODULE_IRQ >> 8
575 jz SHORT .DoNotEnableIrq
576
577 mov bx, .rgbDefaultIrqForStdIde ; Enable interrupt for primary and secondary IDE
[607]578 push ax
579 xlat
580 mov [es:di+IDEVARS.bIRQ-IDEVARS.wBasePort], al
581 pop ax
[621]582
583.DoNotEnableIrq:
584 mov bx, .rgbLowByteOfStdIdeInterfacePorts
585 xlat
[589]586 mov ah, 1 ; DEVICE_ATA_*_PORT >> 8
587 mov bh, 3 ; DEVICE_ATA_*_PORTCTRL >> 8
588 mov bl, al
589 jmp SHORT .WriteNonSerial
590
591.rgbLowByteOfStdIdeInterfacePorts: ; Defaults for 16-bit and better ATA devices
592 db DEVICE_ATA_PRIMARY_PORT & 0FFh
593 db DEVICE_ATA_SECONDARY_PORT & 0FFh
594 db DEVICE_ATA_TERTIARY_PORT & 0FFh
595 db DEVICE_ATA_QUATERNARY_PORT & 0FFh
[607]596.rgbDefaultIrqForStdIde:
597 db 14
598 db 15
599 db 0 ; These can vary so lets disable by default
600 db 0
[589]601
602.NotStandardIdeDevice:
[567]603 cmp al, DEVICE_SERIAL_PORT
[589]604 jb SHORT .NotSerialDevice
605 test BYTE [es:ROMVARS.wFlags+1], FLG_ROMVARS_MODULE_SERIAL >> 8
606 jnz SHORT .ChangingToSerial
607
608.SupportForDeviceNotAvailable:
609 mov dx, g_szUnsupportedDevice
610 call Dialogs_DisplayErrorFromCSDX
611
612 ; Restore device type to the previous value
613 pop ax ; Get choice index from stack
614 mov al, bl ; Previous device type to AL
615 shr al, 1 ; Device code to choice index
[592]616 pop di
617 ret
[589]618
619.NotSerialDevice:
620 ; Remaining device types all require MODULE_8BIT_IDE or MODULE_8BIT_IDE_ADVANCED
621 test BYTE [es:ROMVARS.wFlags], FLG_ROMVARS_MODULE_8BIT_IDE | FLG_ROMVARS_MODULE_8BIT_IDE_ADVANCED
622 jz SHORT .SupportForDeviceNotAvailable
623
624 ; We know MODULE_8BIT_IDE is included
625 lahf ; Save the PF
[601]626 cmp al, DEVICE_8BIT_XTIDE_REV2_OLIVETTI
[589]627 jbe SHORT .ChangingToXTIDEorXTCF
628 sahf ; Restore the PF
629 jpo SHORT .SupportForDeviceNotAvailable ; Jump if no MODULE_8BIT_IDE_ADVANCED
[567]630 cmp al, DEVICE_8BIT_JRIDE_ISA
631 je SHORT .ChangingToJrIdeIsa
632 cmp al, DEVICE_8BIT_ADP50L
633 je SHORT .ChangingToADP50L
[242]634
[589]635.ChangingToXTIDEorXTCF:
[567]636 mov ax, DEVICE_XTIDE_DEFAULT_PORT ; Defaults for 8-bit XTIDE and XT-CF devices
637 mov bx, DEVICE_XTIDE_DEFAULT_PORTCTRL
[614]638
[607]639 ; XT-CF does not support IRQ so it must be disabled (IRQ setting is not visible for XT-CF)
640 ; XTIDE does not use IRQs by default
641 mov BYTE [es:di+IDEVARS.bIRQ-IDEVARS.wBasePort], 0
[483]642
[567]643.WriteNonSerial:
644 stosw ; Store defaults in IDEVARS.wBasePort and IDEVARS.wBasePortCtrl
645 xchg bx, ax
646 stosw
647 jmp SHORT .Done
[199]648
[483]649.ChangingToJrIdeIsa:
[567]650 mov ah, JRIDE_DEFAULT_SEGMENT_ADDRESS >> 8
651 SKIP2B bx
[536]652
653.ChangingToADP50L:
[567]654 mov ah, ADP50L_DEFAULT_BIOS_SEGMENT_ADDRESS >> 8
655 xor al, al
656 xor bx, bx
657 jmp SHORT .WriteNonSerial
[199]658
[567]659.ChangingToSerial:
[592]660;
661; For serial drives, we pack the port number and baud rate into a single byte, and thus
662; we need to take care to properly read/write just the bits we need. In addition, since
663; we use the Port/PortCtrl bytes in a special way for serial drives, we need to properly
664; default the values stored in both these words when switching in and out of the Serial
665; device choice.
666;
667 mov al, SERIAL_DEFAULT_COM
[567]668 mov BYTE [es:di+IDEVARS.bSerialBaud-IDEVARS.wBasePort], SERIAL_DEFAULT_BAUD
[592]669 mov [es:di+IDEVARS.bIRQ-IDEVARS.wBasePort], ah ; Clear .bIRQ to keep the boot menu from printing it
[233]670
[567]671 sub di, IDEVARS.wBasePort - IDEVARS.bSerialCOMPortChar
672 call IdeControllerMenu_SerialWriteCOM
673 stosb
[242]674
[567]675.Done:
676 pop ax
[592]677 pop di
[567]678 ret
[199]679
[592]680
681;--------------------------------------------------------------------
682; IdeControllerMenu_SerialWriteCOM
[199]683;
[592]684; Updates the port address based on COM port selection
[242]685;
[592]686; Parameters:
687; AL: COM port
688; ES:DI: Ptr to IDEVARS.bSerialCOMPortChar
689; DS:SI: MENUITEM pointer
690; Returns:
691; Nothing
692; Corrupts registers:
693; BX
694;--------------------------------------------------------------------
[199]695ALIGN JUMP_ALIGN
696IdeControllerMenu_SerialWriteCOM:
[567]697 push ax
698 push si
[242]699
[592]700 mov bx, PackedCOMPortAddresses - 1
701 mov si, g_rgbChoiceToValueLookupForCOM - 2
[199]702
[592]703.Loop:
704 inc bx
[567]705 inc si
706 inc si
[242]707
[592]708 mov ah, [bx]
709 cmp ah, SERIAL_DEFAULT_CUSTOM_PORT >> 2
710 je SHORT .NotFound
[199]711
[592]712 cmp al, [si]
713 jne SHORT .Loop
[242]714
[592]715.NotFound:
[567]716 mov [es:di+IDEVARS.bSerialPort-IDEVARS.bSerialCOMPortChar], ah
[199]717
[567]718 pop si
719 pop ax
720 ret
[199]721
[242]722
[592]723;--------------------------------------------------------------------
724; IdeControllerMenu_SerialReadPort
[199]725;
[233]726; Packed Port (byte) -> Numeric Port (word)
[242]727;
[592]728; Parameters:
729; AX: Value read from the ROMVARS location
730; ES:DI: ROMVARS location where the value was just read from
731; DS:SI: MENUITEM pointer
732; Returns:
733; AX: Value that the MENUITEM system will interact with and display
734; Corrupts registers:
735; Nothing
736;--------------------------------------------------------------------
[199]737ALIGN JUMP_ALIGN
[233]738IdeControllerMenu_SerialReadPort:
[567]739 xor ah, ah
740 eSHL_IM ax, 2
741 ret
[199]742
[592]743
744;--------------------------------------------------------------------
745; IdeControllerMenu_SerialWritePort
[199]746;
[233]747; Numeric Port (word) -> Packed Port (byte)
[199]748;
[592]749; And convert from Custom to a defined COM port if we
750; match one of the pre-defined COM port numbers
751;
752; Parameters:
753; AX: Value that the MENUITEM system was interacting with
754; ES:DI: ROMVARS location where the value is to be stored
755; DS:SI: MENUITEM pointer
756; Returns:
757; AX: Value to actually write to ROMVARS
758; Corrupts registers:
759; BX
760;--------------------------------------------------------------------
[199]761ALIGN JUMP_ALIGN
[242]762IdeControllerMenu_SerialWritePort:
[567]763 push si
[199]764
[567]765 eSHR_IM ax, 2
[592]766 and al, 0FEh ; Force 8-byte boundary
[199]767
[592]768 mov si, g_rgbChoiceToValueLookupForCOM - 2
769 mov bx, PackedCOMPortAddresses - 1 ; Loop, looking for port address in known COM address list
[233]770
[592]771.Loop:
772 inc si
773 inc si
774 inc bx
775
[567]776 mov ah, [si]
777 cmp ah, 'x'
[592]778 je SHORT .Found
[242]779
[567]780 cmp al, [bx]
[592]781 jne SHORT .Loop
[242]782
[592]783.Found:
[567]784 mov [es:di+IDEVARS.bSerialCOMPortChar-IDEVARS.bSerialPort], ah
[233]785
[567]786 pop si
787 ret
[199]788
Note: See TracBrowser for help on using the repository browser.