Changeset 233 in xtideuniversalbios for trunk/XTIDE_Universal_BIOS/Src/Initialization
- Timestamp:
- Feb 4, 2012, 6:21:22 PM (13 years ago)
- google:author:
- gregli@hotmail.com
- Location:
- trunk/XTIDE_Universal_BIOS/Src/Initialization
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/XTIDE_Universal_BIOS/Src/Initialization/DetectDrives.asm
r203 r233 22 22 23 23 .DriveDetectLoop: ; Loop through IDEVARS 24 mov si, g_szDetect ; Setup standard print string 24 push cx 25 26 mov cx, g_szDetectMaster 27 mov bh, MASK_DRVNHEAD_SET ; Select Master drive 28 call StartDetectionWithDriveSelectByteInBHandStringInAX ; Detect and create DPT + BOOTNFO 29 30 mov cx, g_szDetectSlave 31 mov bh, MASK_DRVNHEAD_SET | FLG_DRVNHEAD_DRV 32 call StartDetectionWithDriveSelectByteInBHandStringInAX 33 34 pop cx 35 36 add bp, BYTE IDEVARS_size ; Point to next IDEVARS 37 25 38 %ifdef MODULE_SERIAL 26 cmp byte [cs:bp+IDEVARS.bDevice], DEVICE_SERIAL_PORT 27 jnz .DriveNotSerial ; Special print string for serial drives 28 mov si, g_szDetectCOM 29 .DriveNotSerial: 39 jcxz .done ; Set to zero on .ideVarsSerialAuto iteration (if any) 30 40 %endif 31 32 call .DetectDrives_WithIDEVARS ; Detect Master and Slave 33 add bp, BYTE IDEVARS_size ; Point to next IDEVARS 41 34 42 loop .DriveDetectLoop 35 43 36 44 %ifdef MODULE_SERIAL 37 45 ; 38 ; if serial drive detected, do not scan (avoids duplicate drives and isn't needed - we have a connection) 39 ; Note that XLATEVARS.bLastSerial is zero'd in RamVars_Initialize, called in Initialize_AutoDetectDrives; 40 ; bLastSerial it set in the detection code of SerialCommand.asm 46 ; if serial drive detected, do not scan (avoids duplicate drives and isn't needed - we already have a connection) 41 47 ; 42 cmp byte [RAMVARS.xlateVars+XLATEVARS.bLastSerial],cl ; cx = zero after the loop above 43 ; less instruction bytes than using immediate 44 jnz .done 45 48 call FindDPT_ToDSDIforSerialDevice 49 jc .done 50 51 mov bp, ROMVARS.ideVarsSerialAuto ; Point to our special IDEVARS sructure, just for serial scans 52 46 53 mov al,[cs:ROMVARS.wFlags] ; Configurator set to always scan? 47 54 or al,[es:BDA.bKBFlgs1] ; Or, did the user hold down the ALT key? 48 55 and al,8 ; 8 = alt key depressed, same as FLG_ROMVARS_SERIAL_ALWAYSDETECT 49 jz .done 56 jnz .DriveDetectLoop 57 %endif 50 58 51 mov bp, ROMVARS.ideVarsSerialAuto ; Point to our special IDEVARS sructure, just for serial scans 52 mov si, g_szDetectCOMAuto ; Special, special print string for serial drives during a scan 53 ;;; fall-through 54 %else 59 .done: 55 60 ret 56 %endif57 61 58 62 %if FLG_ROMVARS_SERIAL_SCANDETECT != 8 … … 60 64 %endif 61 65 62 ;--------------------------------------------------------------------63 ; Detects IDE hard disks by using information from IDEVARS.64 ;65 ; DetectDrives_WithIDEVARS66 ; Parameters:67 ; CS:BP: Ptr to IDEVARS68 ; DS: RAMVARS segment69 ; ES: Zero (BDA segment)70 ; SI: Ptr to template string71 ; Returns:72 ; Nothing73 ; Corrupts registers:74 ; AX, BX, DX, SI, DI75 ;--------------------------------------------------------------------76 .DetectDrives_WithIDEVARS:77 push cx78 79 push si80 mov ax, g_szMaster81 mov bh, MASK_DRVNHEAD_SET ; Select Master drive82 call StartDetectionWithDriveSelectByteInBHandStringInAX ; Detect and create DPT + BOOTNFO83 pop si84 85 mov ax, g_szSlave86 mov bh, MASK_DRVNHEAD_SET | FLG_DRVNHEAD_DRV87 call StartDetectionWithDriveSelectByteInBHandStringInAX88 pop cx89 90 .done:91 ret92 93 66 94 67 ;-------------------------------------------------------------------- 95 68 ; StartDetectionWithDriveSelectByteInBHandStringInAX 96 69 ; Parameters: 97 ; AX: Offset to "Master" or "Slave" string98 70 ; BH: Drive Select byte for Drive and Head Register 71 ; CX: Offset to "Master" or "Slave" string 99 72 ; CS:BP: Ptr to IDEVARS for the drive 100 73 ; DS: RAMVARS segment -
trunk/XTIDE_Universal_BIOS/Src/Initialization/DetectPrint.asm
r203 r233 30 30 ; DetectPrint_StartDetectWithMasterOrSlaveStringInAXandIdeVarsInCSBP 31 31 ; Parameters: 32 ; CS: AX: Ptr to "Master" or "Slave" string32 ; CS:CX: Ptr to "Master" or "Slave" string 33 33 ; CS:BP: Ptr to IDEVARS 34 34 ; SI: Ptr to template string … … 39 39 ;-------------------------------------------------------------------- 40 40 DetectPrint_StartDetectWithMasterOrSlaveStringInAXandIdeVarsInCSBP: 41 push bp 42 mov di, [cs:bp+IDEVARS.wPort] 43 %ifdef MODULE_SERIAL 44 mov cx, [cs:bp+IDEVARS.wSerialPackedPrintBaud] 45 %endif 41 42 mov ax, [cs:bp+IDEVARS.wPort] ; for IDE: AX=port address, DH=.bDevice 43 mov dx, [cs:bp+IDEVARS.bDevice-1] ; for Serial: AL=port address>>2, AH=baud rate 44 ; DL=COM number character, DH=.bDevice 45 46 push bp ; setup stack for call to 47 mov bp, sp ; BootMenuPrint_FormatCSSIfromParamsInSSBP 48 49 push cx ; Push "Master" or "Slave" 46 50 47 mov bp, sp 51 mov cl, (g_szDetectPort-$$) & 0xff ; Setup print string for standard IDE 52 ; Note that we modify only the low order bits of CX a lot here, 53 ; saving code space rather than reloading CX completely. 54 ; This optimization requires that all the g_szDetect* strings are 55 ; on the same 256 byte page, which is checked in strings.asm. 48 56 49 push ax ; Push "Master" or "Slave" 57 cmp dx, DEVICE_SERIAL_PORT << 8 ; Check if this is a serial device, 58 ; And also check if DL is zero, check with the jz below 59 ; This optimization requires that DEVICE_SERIAL_PORT be 60 ; the highest value in the DEVICE_* series, ensuring that 61 ; anything less in the high order bits is a different device. 62 63 jl .pushAndPrint ; CX = string to print, AX = port address, DX won't be used 64 65 mov cl, (g_szDetectCOM-$$) & 0xff ; Setup print string for COM ports 66 push cx ; And push now. We use the fact that format strings can contain 67 ; themselves format strings. 68 69 push dx ; Push COM number character 70 71 mov cl, (g_szDetectCOMAuto-$$) & 0xff ; Setup secondary print string for "Auto" 50 72 51 push di ; Push Port address or COM port number 73 jz .pushAndPrint ; CX = string to print, AX and DX won't be used 74 75 mov cl, (g_szDetectCOMLarge-$$) & 0xff ; Setup secondary print string for "COMn/xx.yK" 52 76 53 %ifdef MODULE_SERIAL 54 ; 55 ; Print baud rate from .wSerialPackedPrintBaud, in two parts - %u and then %c 56 ; 57 mov ax,cx ; Unpack baud rate number 58 and ax,DEVICE_SERIAL_PRINTBAUD_NUMBERMASK 59 push ax 77 mov al,ah ; baud rate divisor to AL 78 cbw ; clear AH, AL will always be less than 128 79 xchg si,ax ; move AX to SI for divide 80 mov ax,1152 ; baud rate to displa is 115200/divisor, the "00" is handled 81 ; in the print strings 82 xor dx,dx ; clear top 16-bits of dividend 83 div si ; and divide... Now AX = baud rate/100, DX = 0 (always a clean divide) 84 85 mov si,10 ; Now separate the whole portion from the fractional for "K" display 86 div si ; and divide... Now AX = baud rate/1000, DX = low order digit 87 88 cmp ax,si ; <= 10: "2400", "9600", etc.; >10: "19.2K", "38.4K", etc. 89 jae .pushAndPrint 60 90 61 mov al,ch ; Unpack baud rate postfix ('0' or 'K') 62 eSHR_IM al,2 ; also effectively masks off the postfix 63 add al,DEVICE_SERIAL_PRINTBAUD_POSTCHARADD 64 push ax 65 %endif 66 91 mov cl, (g_szDetectCOMSmall-$$) & 0xff ; Setup secondary print string for "COMn/XXy00" 92 93 .pushAndPrint: 94 push cx ; Push print string 95 push ax ; Push high order digits, or port address, or N/A 96 push dx ; Push low order digit, or N/A 97 98 mov si, g_szDetectOuter ; Finally load SI with wrapper string "IDE %s at %s: " 99 67 100 jmp short DetectPrint_BootMenuPrint_FormatCSSIfromParamsInSSBP_Relay 68 101 … … 92 125 93 126 127
Note:
See TracChangeset
for help on using the changeset viewer.