3 * Copyright (C) 1998-2003 Brian Palmer <brianp@sginet.com>
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 void delay(unsigned msec
);
32 void delay(unsigned msec
)
39 // BIOS - WAIT (AT,PS)
42 // CX:DX = interval in microseconds
44 // CF clear if successful (wait interval elapsed)
45 // CF set on error or AH=83h wait already in progress
46 // AH = status (see #00496)
48 // Note: The resolution of the wait period is 977 microseconds on
49 // many systems because many BIOSes use the 1/1024 second fast
50 // interrupt from the AT real-time clock chip which is available on INT 70;
51 // because newer BIOSes may have much more precise timers available, it is
52 // not possible to use this function accurately for very short delays unless
53 // the precise behavior of the BIOS is known (or found through testing)
64 usec
= msec_this
* 1000;
67 Regs
.w
.cx
= usec
>> 16;
68 Regs
.w
.dx
= usec
& 0xffff;
69 Int386(0x15, &Regs
, &Regs
);
81 WRITE_PORT_UCHAR((PUCHAR
)0x61, READ_PORT_UCHAR((PUCHAR
)0x61) & ~3);
85 scale
= 1193046 / freq
;
86 WRITE_PORT_UCHAR((PUCHAR
)0x43, 0xb6);
87 WRITE_PORT_UCHAR((PUCHAR
)0x42, scale
& 0xff);
88 WRITE_PORT_UCHAR((PUCHAR
)0x42, scale
>> 8);
89 WRITE_PORT_UCHAR((PUCHAR
)0x61, READ_PORT_UCHAR((PUCHAR
)0x61) | 3);
92 VOID __cdecl
ChainLoadBiosBootSectorCode(
93 IN UCHAR BootDrive OPTIONAL
,
94 IN ULONG BootPartition OPTIONAL
)
98 RtlZeroMemory(&Regs
, sizeof(Regs
));
100 /* Set the boot drive and the boot partition */
101 Regs
.b
.dl
= (UCHAR
)(BootDrive
? BootDrive
: FrldrBootDrive
);
102 Regs
.b
.dh
= (UCHAR
)(BootPartition
? BootPartition
: FrldrBootPartition
);
105 * Don't stop the floppy drive motor when we are just booting a bootsector,
106 * a drive, or a partition. If we were to stop the floppy motor, the BIOS
107 * wouldn't be informed and if the next read is to a floppy then the BIOS
108 * will still think the motor is on and this will result in a read error.
110 // DiskStopFloppyMotor();
112 Relocator16Boot(&Regs
,
113 /* Stack segment:pointer */
115 /* Code segment:pointer */