mirror of https://github.com/FDOS/kernel.git
See history.txt: dsk.c changes, warning removal and int21 entry handling.
git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@176 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
parent
bf042f7fac
commit
851eb99b63
|
@ -1,3 +1,10 @@
|
||||||
|
2001 Mar 24 - Build 2022
|
||||||
|
-------- Bart Oldeman (bart.oldeman@bristol.ac.uk)
|
||||||
|
+ Fixes Tom and Bart: cli/sti handling and other fixes in entry.asm,
|
||||||
|
procsupt.asm and apisupt.asm.
|
||||||
|
Bart: warning removal + other compile time fixes.
|
||||||
|
Tom: * more partition detection fixes in dsk.c.
|
||||||
|
* dos_gettime() fix.
|
||||||
2001 Mar 21 - Build 2022
|
2001 Mar 21 - Build 2022
|
||||||
-------- Bart Oldeman (bart.oldeman@bristol.ac.uk)
|
-------- Bart Oldeman (bart.oldeman@bristol.ac.uk)
|
||||||
+ Clean A lot of space savings by Tom Ehlert, merely because Turbo C 2.01 does not
|
+ Clean A lot of space savings by Tom Ehlert, merely because Turbo C 2.01 does not
|
||||||
|
|
397
kernel/dsk.c
397
kernel/dsk.c
|
@ -33,6 +33,9 @@ static BYTE *dskRcsId = "$Id$";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* $Log$
|
* $Log$
|
||||||
|
* Revision 1.12 2001/03/24 22:13:05 bartoldeman
|
||||||
|
* See history.txt: dsk.c changes, warning removal and int21 entry handling.
|
||||||
|
*
|
||||||
* Revision 1.11 2001/03/21 02:56:25 bartoldeman
|
* Revision 1.11 2001/03/21 02:56:25 bartoldeman
|
||||||
* See history.txt for changes. Bug fixes and HMA support are the main ones.
|
* See history.txt for changes. Bug fixes and HMA support are the main ones.
|
||||||
*
|
*
|
||||||
|
@ -251,7 +254,7 @@ WORD _dsk_init(rqptr),
|
||||||
blk_error(rqptr);
|
blk_error(rqptr);
|
||||||
COUNT ltop(WORD *, WORD *, WORD *, COUNT, COUNT, ULONG, byteptr);
|
COUNT ltop(WORD *, WORD *, WORD *, COUNT, COUNT, ULONG, byteptr);
|
||||||
WORD dskerr(COUNT);
|
WORD dskerr(COUNT);
|
||||||
COUNT processtable(int table_type,COUNT ptDrive, BYTE ptHead, UWORD ptCylinder, BYTE ptSector, LONG ptAccuOff);
|
COUNT processtable(int table_type,COUNT ptDrive, BYTE ptHead, UWORD ptCylinder, BYTE ptSector, LONG ptAccuOff, UWORD PartitionDone);
|
||||||
#else
|
#else
|
||||||
WORD _dsk_init(),
|
WORD _dsk_init(),
|
||||||
mediachk(),
|
mediachk(),
|
||||||
|
@ -312,6 +315,7 @@ static WORD(*dispatch[NENTRY]) () =
|
||||||
#define SIZEOF_PARTENT 16
|
#define SIZEOF_PARTENT 16
|
||||||
|
|
||||||
#define PRIMARY 0x01
|
#define PRIMARY 0x01
|
||||||
|
#define PRIMARY2 0x02
|
||||||
|
|
||||||
#define FAT12 0x01
|
#define FAT12 0x01
|
||||||
#define FAT16SMALL 0x04
|
#define FAT16SMALL 0x04
|
||||||
|
@ -333,6 +337,7 @@ ULONG StartSector(WORD ptDrive, unsigned BeginCylinder,
|
||||||
|
|
||||||
unsigned cylinders,heads,sectors;
|
unsigned cylinders,heads,sectors;
|
||||||
ULONG startPos;
|
ULONG startPos;
|
||||||
|
ULONG oldStartPos;
|
||||||
|
|
||||||
regs.a.x = 0x0800; /* get drive parameters */
|
regs.a.x = 0x0800; /* get drive parameters */
|
||||||
regs.d.x = ptDrive;
|
regs.d.x = ptDrive;
|
||||||
|
@ -354,15 +359,113 @@ ULONG StartSector(WORD ptDrive, unsigned BeginCylinder,
|
||||||
BeginCylinder, BeginHead, BeginSector,
|
BeginCylinder, BeginHead, BeginSector,
|
||||||
BeginCylinder, BeginHead, BeginSector,
|
BeginCylinder, BeginHead, BeginSector,
|
||||||
startPos, startPos));
|
startPos, startPos));
|
||||||
|
|
||||||
|
|
||||||
|
oldStartPos = peStartSector + ptAccuOff;
|
||||||
|
|
||||||
|
PartCodePrintf(("oldStartPos = %lx - ", oldStartPos));
|
||||||
|
|
||||||
|
|
||||||
|
if (startPos != oldStartPos)
|
||||||
|
{
|
||||||
|
printf("PART TABLE mismatch for drive %x, CHS=%d %d %d, startsec %d, offset %ld\n",
|
||||||
|
ptDrive, BeginCylinder, BeginHead,BeginSector,
|
||||||
|
peStartSector, ptAccuOff);
|
||||||
|
|
||||||
|
printf(" old startpos = %ld, new startpos = %ld, using new\n",
|
||||||
|
oldStartPos, startPos);
|
||||||
|
}
|
||||||
|
|
||||||
return startPos;
|
return startPos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
thats what MSDN says:
|
||||||
|
|
||||||
|
How Windows 2000 Assigns, Reserves, and Stores Drive Letters
|
||||||
|
ID: q234048
|
||||||
|
|
||||||
|
BASIC Disk - Drive Letter Assignment Rules
|
||||||
|
The following are the basic disk drive letter assignment rules for Windows 2000:
|
||||||
|
Scan all fixed hard disks as they are enumerated, assign drive letters
|
||||||
|
starting with any active primary partitions (if there is one), otherwise,
|
||||||
|
scan the first primary partition on each drive. Assign next available
|
||||||
|
letter starting with C:
|
||||||
|
|
||||||
|
|
||||||
|
Repeat scan for all fixed hard disks and removable (JAZ, MO) disks
|
||||||
|
and assign drive letters to all logical drives in an extended partition,
|
||||||
|
or the removable disk(s) as enumerated. Assign next available letter
|
||||||
|
starting with C:
|
||||||
|
|
||||||
|
|
||||||
|
Finally, repeat scan for all fixed hard disk drives, and assign drive
|
||||||
|
letters to all remaining primary partitions. Assign next available letter
|
||||||
|
starting with C:
|
||||||
|
|
||||||
|
Floppy drives. Assign letter starting with A:
|
||||||
|
|
||||||
|
CD-ROM drives. Assign next available letter starting with D:
|
||||||
|
|
||||||
|
*************************************************************************
|
||||||
|
Order in Which MS-DOS and Windows Assign Drive Letters
|
||||||
|
ID: q51978
|
||||||
|
|
||||||
|
MORE INFORMATION
|
||||||
|
The following occurs at startup:
|
||||||
|
|
||||||
|
MS-DOS checks all installed disk devices, assigning the drive letter A
|
||||||
|
to the first physical floppy disk drive that is found.
|
||||||
|
|
||||||
|
If a second physical floppy disk drive is present, it is assigned drive letter B. If it is not present, a logical drive B is created that uses the first physical floppy disk drive.
|
||||||
|
|
||||||
|
|
||||||
|
Regardless of whether a second floppy disk drive is present,
|
||||||
|
MS-DOS then assigns the drive letter C to the primary MS-DOS
|
||||||
|
partition on the first physical hard disk, and then goes on
|
||||||
|
to check for a second hard disk.
|
||||||
|
|
||||||
|
|
||||||
|
If a second physical hard disk is found, and a primary partition exists
|
||||||
|
on the second physical drive, the primary MS-DOS partition on the second
|
||||||
|
physical hard drive is assigned the letter D. MS-DOS version 5.0, which
|
||||||
|
supports up to eight physical drives, will continue to search for more
|
||||||
|
physical hard disk drives at this point. For example, if a third physical
|
||||||
|
hard disk is found, and a primary partition exists on the third physical
|
||||||
|
drive, the primary MS-DOS partition on the third physical hard drive is
|
||||||
|
assigned the letter E.
|
||||||
|
|
||||||
|
|
||||||
|
MS-DOS returns to the first physical hard disk drive and assigns drive
|
||||||
|
letters to any additional logical drives (in extended MS-DOS partitions)
|
||||||
|
on that drive in sequence.
|
||||||
|
|
||||||
|
|
||||||
|
MS-DOS repeats this process for the second physical hard disk drive,
|
||||||
|
if present. MS-DOS 5.0 will repeat this process for up to eight physical
|
||||||
|
hard drives, if present. After all logical drives (in extended MS-DOS
|
||||||
|
partitions) have been assigned drive letters, MS-DOS 5.0 returns to
|
||||||
|
the first physical drive and assigns drive letters to any other primary
|
||||||
|
MS-DOS partitions that exist, then searches other physical drives for
|
||||||
|
additional primary MS-DOS partitions. This support for multiple primary
|
||||||
|
MS-DOS partitions was added to version 5.0 for backward compatibility
|
||||||
|
with the previous OEM MS-DOS versions that support multiple primary partitions.
|
||||||
|
|
||||||
|
|
||||||
|
After all logical drives on the hard disk(s) have been assigned drive
|
||||||
|
letters, drive letters are assigned to drives installed using DRIVER.SYS
|
||||||
|
or created using RAMDRIVE.SYS in the order in which the drivers are loaded
|
||||||
|
in the CONFIG.SYS file. Which drive letters are assigned to which devices
|
||||||
|
can be influenced by changing the order of the device drivers or, if necessary,
|
||||||
|
by creating "dummy" drive letters with DRIVER.SYS.
|
||||||
|
|
||||||
|
********************************************************
|
||||||
|
|
||||||
|
I don't know, if I did it right, but I tried to do it that way. TE
|
||||||
|
|
||||||
|
*/
|
||||||
COUNT processtable(int table_type,COUNT ptDrive, BYTE ptHead, UWORD ptCylinder,
|
COUNT processtable(int table_type,COUNT ptDrive, BYTE ptHead, UWORD ptCylinder,
|
||||||
BYTE ptSector, LONG ptAccuOff)
|
BYTE ptSector, LONG ptAccuOff, UWORD PartitionDone )
|
||||||
{
|
{
|
||||||
struct /* Temporary partition table */
|
struct /* Temporary partition table */
|
||||||
{
|
{
|
||||||
|
@ -383,162 +486,177 @@ COUNT processtable(int table_type,COUNT ptDrive, BYTE ptHead, UWORD ptCylinder,
|
||||||
int retry;
|
int retry;
|
||||||
UBYTE packed_byte,
|
UBYTE packed_byte,
|
||||||
pb1;
|
pb1;
|
||||||
/* COUNT Part; */
|
|
||||||
BYTE *p;
|
BYTE *p;
|
||||||
int partition_chain = 0;
|
int partition_chain = 0;
|
||||||
int ret;
|
int ret;
|
||||||
ULONG newStartPos;
|
ULONG newStartPos;
|
||||||
|
UWORD partMask;
|
||||||
|
int loop;
|
||||||
|
|
||||||
restart: /* yes, it's a GOTO >:-) */
|
restart: /* yes, it's a GOTO >:-) */
|
||||||
|
|
||||||
/* if someone has a circular linked
|
/* if someone has a circular linked
|
||||||
extended partition list, stop it sooner or later */
|
extended partition list, stop it sooner or later */
|
||||||
if (partition_chain > 64)
|
if (partition_chain > 64)
|
||||||
return TRUE;
|
return PartitionDone;
|
||||||
|
|
||||||
|
|
||||||
PartCodePrintf(("searching partition table at %x %x %x %x %lx\n",
|
PartCodePrintf(("searching partition table at %x %x %x %x %lx\n",
|
||||||
ptDrive, ptCylinder, ptHead, ptSector, ptAccuOff));
|
ptDrive, ptCylinder, ptHead, ptSector, ptAccuOff));
|
||||||
|
|
||||||
/* Read partition table */
|
/* Read partition table */
|
||||||
for ( retry = N_RETRY; --retry >= 0; )
|
for ( retry = N_RETRY; --retry >= 0; )
|
||||||
{
|
{
|
||||||
ret = fl_read((WORD) ptDrive, (WORD) ptHead, (WORD) ptCylinder,
|
ret = fl_read((WORD) ptDrive, (WORD) ptHead, (WORD) ptCylinder,
|
||||||
(WORD) ptSector, (WORD) 1, (byteptr) & buffer);
|
(WORD) ptSector, (WORD) 1, (byteptr) & buffer);
|
||||||
if (ret == 0)
|
if (ret == 0)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
return FALSE;
|
return PartitionDone;
|
||||||
|
|
||||||
/* Read each partition into temporary array */
|
/* Read each partition into temporary array */
|
||||||
|
|
||||||
p = (BYTE *) & buffer.bytes[PARTOFF];
|
p = (BYTE *) & buffer.bytes[PARTOFF];
|
||||||
|
|
||||||
for (ptemp_part = &temp_part[0];
|
for (ptemp_part = &temp_part[0];
|
||||||
ptemp_part < &temp_part[N_PART]; ptemp_part++)
|
ptemp_part < &temp_part[N_PART]; ptemp_part++)
|
||||||
{
|
{
|
||||||
|
|
||||||
getbyte((VOID *) (p+0), &ptemp_part->peBootable);
|
getbyte((VOID *) (p+0), &ptemp_part->peBootable);
|
||||||
getbyte((VOID *) (p+1), &ptemp_part->peBeginHead);
|
getbyte((VOID *) (p+1), &ptemp_part->peBeginHead);
|
||||||
getbyte((VOID *) (p+2), &packed_byte);
|
getbyte((VOID *) (p+2), &packed_byte);
|
||||||
ptemp_part->peBeginSector = packed_byte & 0x3f;
|
ptemp_part->peBeginSector = packed_byte & 0x3f;
|
||||||
getbyte((VOID *) (p+3), &pb1);
|
getbyte((VOID *) (p+3), &pb1);
|
||||||
ptemp_part->peBeginCylinder = pb1 + ((UWORD) (0xc0 & packed_byte) << 2);
|
ptemp_part->peBeginCylinder = pb1 + ((UWORD) (0xc0 & packed_byte) << 2);
|
||||||
getbyte((VOID *) (p+4), &ptemp_part->peFileSystem);
|
getbyte((VOID *) (p+4), &ptemp_part->peFileSystem);
|
||||||
getbyte((VOID *) (p+5), &ptemp_part->peEndHead);
|
getbyte((VOID *) (p+5), &ptemp_part->peEndHead);
|
||||||
getbyte((VOID *) (p+6), &packed_byte);
|
getbyte((VOID *) (p+6), &packed_byte);
|
||||||
ptemp_part->peEndSector = packed_byte & 0x3f;
|
ptemp_part->peEndSector = packed_byte & 0x3f;
|
||||||
getbyte((VOID *) (p+7), &pb1);
|
getbyte((VOID *) (p+7), &pb1);
|
||||||
ptemp_part->peEndCylinder = pb1 + ((UWORD) (0xc0 & packed_byte) << 2);
|
ptemp_part->peEndCylinder = pb1 + ((UWORD) (0xc0 & packed_byte) << 2);
|
||||||
getlong((VOID *) (p+8), &ptemp_part->peStartSector);
|
getlong((VOID *) (p+8), &ptemp_part->peStartSector);
|
||||||
getlong((VOID *) (p+12), &ptemp_part->peSectors);
|
getlong((VOID *) (p+12), &ptemp_part->peSectors);
|
||||||
|
|
||||||
p += SIZEOF_PARTENT; /* == 16 */
|
p += SIZEOF_PARTENT; /* == 16 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Walk through the table, add DOS partitions to global
|
/* Walk through the table, add DOS partitions to global
|
||||||
array and process extended partitions */
|
array and process extended partitions */
|
||||||
|
|
||||||
/* when searching the EXT chain,
|
/* when searching the EXT chain,
|
||||||
must skip primary partitions */
|
must skip primary partitions */
|
||||||
if ( (table_type==PRIMARY) ||
|
if ( table_type==PRIMARY ||
|
||||||
( (table_type==EXTENDED) && (partition_chain!=0) ) )
|
table_type==PRIMARY2 ||
|
||||||
{
|
partition_chain!=0 )
|
||||||
|
{
|
||||||
for (ptemp_part = &temp_part[0];
|
/* do this for
|
||||||
ptemp_part < &temp_part[N_PART] && nUnits < NDEV; ptemp_part++)
|
0) all active partitions
|
||||||
{
|
1) the first primary partition
|
||||||
|
*/
|
||||||
if ( ptemp_part->peFileSystem == FAT12 ||
|
for (loop = 0; loop < 2; loop++)
|
||||||
ptemp_part->peFileSystem == FAT16SMALL ||
|
{
|
||||||
ptemp_part->peFileSystem == FAT16LARGE )
|
for (ptemp_part = &temp_part[0], partMask = 1;
|
||||||
{
|
ptemp_part < &temp_part[N_PART] && nUnits < NDEV;
|
||||||
struct dos_partitionS *pdos_partition;
|
partMask <<= 1,ptemp_part++)
|
||||||
|
{
|
||||||
struct media_info *pmiarray = getPMiarray(nUnits);
|
|
||||||
|
|
||||||
pmiarray->mi_offset = ptemp_part->peStartSector + ptAccuOff;
|
if (loop == 0 && /* scan for only for active */
|
||||||
|
!ptemp_part->peBootable)
|
||||||
PartCodePrintf(("mioffset1 = %lx - ", pmiarray->mi_offset));
|
{
|
||||||
pmiarray->mi_drive = ptDrive;
|
continue;
|
||||||
pmiarray->mi_partidx = nPartitions;
|
}
|
||||||
|
|
||||||
newStartPos = StartSector(ptDrive,
|
|
||||||
ptemp_part->peBeginCylinder,
|
|
||||||
ptemp_part->peBeginHead,
|
|
||||||
ptemp_part->peBeginSector,
|
|
||||||
ptemp_part->peStartSector,
|
|
||||||
ptAccuOff);
|
|
||||||
|
|
||||||
if (newStartPos != pmiarray->mi_offset)
|
|
||||||
{
|
|
||||||
printf("PART TABLE mismatch for drive %x, CHS=%d %d %d, startsec %d, offset %ld\n",
|
|
||||||
ptDrive,
|
|
||||||
ptemp_part->peBeginCylinder, ptemp_part->peBeginHead,ptemp_part->peBeginSector,
|
|
||||||
ptemp_part->peStartSector, ptAccuOff);
|
|
||||||
|
|
||||||
printf(" old startpos = %ld, new startpos = %ld, using new\n",
|
|
||||||
pmiarray->mi_offset, newStartPos);
|
|
||||||
|
|
||||||
pmiarray->mi_offset = newStartPos;
|
|
||||||
}
|
|
||||||
|
|
||||||
nUnits++;
|
|
||||||
|
|
||||||
pdos_partition = &dos_partition[nPartitions];
|
|
||||||
|
|
||||||
pdos_partition->peDrive = ptDrive;
|
|
||||||
pdos_partition->peBootable = ptemp_part->peBootable;
|
|
||||||
pdos_partition->peBeginHead = ptemp_part->peBeginHead;
|
|
||||||
pdos_partition->peBeginSector = ptemp_part->peBeginSector;
|
|
||||||
pdos_partition->peBeginCylinder=ptemp_part->peBeginCylinder;
|
|
||||||
pdos_partition->peFileSystem =ptemp_part->peFileSystem;
|
|
||||||
pdos_partition->peEndHead =ptemp_part->peEndHead;
|
|
||||||
pdos_partition->peEndSector =ptemp_part->peEndSector;
|
|
||||||
pdos_partition->peEndCylinder =ptemp_part->peEndCylinder;
|
|
||||||
pdos_partition->peStartSector =ptemp_part->peStartSector;
|
|
||||||
pdos_partition->peSectors =ptemp_part->peSectors;
|
|
||||||
pdos_partition->peAbsStart =ptemp_part->peStartSector + ptAccuOff;
|
|
||||||
|
|
||||||
PartCodePrintf(("DOS PARTITION drive %x CHS %x-%x-%x %x-%x-%x %lx %lx %lx FS %x\n",
|
|
||||||
pdos_partition->peDrive,
|
|
||||||
pdos_partition->peBeginCylinder,pdos_partition->peBeginHead ,pdos_partition->peBeginSector ,
|
|
||||||
pdos_partition->peEndCylinder ,pdos_partition->peEndHead ,pdos_partition->peEndSector ,
|
|
||||||
pdos_partition->peStartSector ,
|
|
||||||
pdos_partition->peSectors ,
|
|
||||||
pdos_partition->peAbsStart ,
|
|
||||||
pdos_partition->peFileSystem
|
|
||||||
));
|
|
||||||
|
|
||||||
nPartitions++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* search for EXT partitions only on 2. run */
|
|
||||||
if (table_type==EXTENDED)
|
|
||||||
{
|
|
||||||
for (ptemp_part = &temp_part[0];
|
|
||||||
ptemp_part < &temp_part[N_PART] && nUnits < NDEV; ptemp_part++)
|
|
||||||
{
|
|
||||||
if ( (ptemp_part->peFileSystem == EXTENDED ||
|
|
||||||
ptemp_part->peFileSystem == EXTENDED_INT32 ) )
|
|
||||||
{
|
|
||||||
/* restart with new extended part table, don't recurs */
|
|
||||||
partition_chain++;
|
|
||||||
|
|
||||||
ptHead = ptemp_part->peBeginHead;
|
|
||||||
ptCylinder = ptemp_part->peBeginCylinder;
|
|
||||||
ptSector = ptemp_part->peBeginSector;
|
|
||||||
ptAccuOff = ptemp_part->peStartSector + ptAccuOff;
|
|
||||||
|
|
||||||
goto restart;
|
if (PartitionDone & partMask) /* don't reassign partitions */
|
||||||
}
|
{
|
||||||
}
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( ptemp_part->peFileSystem == FAT12 ||
|
||||||
|
ptemp_part->peFileSystem == FAT16SMALL ||
|
||||||
|
ptemp_part->peFileSystem == FAT16LARGE )
|
||||||
|
{
|
||||||
|
struct dos_partitionS *pdos_partition;
|
||||||
|
|
||||||
|
struct media_info *pmiarray = getPMiarray(nUnits);
|
||||||
|
|
||||||
|
pmiarray->mi_drive = ptDrive;
|
||||||
|
pmiarray->mi_partidx = nPartitions;
|
||||||
|
|
||||||
|
pmiarray->mi_offset = StartSector(ptDrive,
|
||||||
|
ptemp_part->peBeginCylinder,
|
||||||
|
ptemp_part->peBeginHead,
|
||||||
|
ptemp_part->peBeginSector,
|
||||||
|
ptemp_part->peStartSector,
|
||||||
|
ptAccuOff);
|
||||||
|
|
||||||
|
nUnits++;
|
||||||
|
|
||||||
|
pdos_partition = &dos_partition[nPartitions];
|
||||||
|
|
||||||
|
pdos_partition->peDrive = ptDrive;
|
||||||
|
pdos_partition->peBootable = ptemp_part->peBootable;
|
||||||
|
pdos_partition->peBeginHead = ptemp_part->peBeginHead;
|
||||||
|
pdos_partition->peBeginSector = ptemp_part->peBeginSector;
|
||||||
|
pdos_partition->peBeginCylinder=ptemp_part->peBeginCylinder;
|
||||||
|
pdos_partition->peFileSystem =ptemp_part->peFileSystem;
|
||||||
|
pdos_partition->peEndHead =ptemp_part->peEndHead;
|
||||||
|
pdos_partition->peEndSector =ptemp_part->peEndSector;
|
||||||
|
pdos_partition->peEndCylinder =ptemp_part->peEndCylinder;
|
||||||
|
pdos_partition->peStartSector =ptemp_part->peStartSector;
|
||||||
|
pdos_partition->peSectors =ptemp_part->peSectors;
|
||||||
|
pdos_partition->peAbsStart =ptemp_part->peStartSector + ptAccuOff;
|
||||||
|
|
||||||
|
PartCodePrintf(("DOS PARTITION drive %x CHS %x-%x-%x %x-%x-%x %lx %lx %lx FS %x\n",
|
||||||
|
pdos_partition->peDrive,
|
||||||
|
pdos_partition->peBeginCylinder,pdos_partition->peBeginHead ,pdos_partition->peBeginSector ,
|
||||||
|
pdos_partition->peEndCylinder ,pdos_partition->peEndHead ,pdos_partition->peEndSector ,
|
||||||
|
pdos_partition->peStartSector ,
|
||||||
|
pdos_partition->peSectors ,
|
||||||
|
pdos_partition->peAbsStart ,
|
||||||
|
pdos_partition->peFileSystem
|
||||||
|
));
|
||||||
|
|
||||||
|
nPartitions++;
|
||||||
|
|
||||||
|
PartitionDone |= partMask;
|
||||||
|
|
||||||
|
if ( table_type==PRIMARY )
|
||||||
|
{
|
||||||
|
return PartitionDone; /* we are done */
|
||||||
|
}
|
||||||
|
|
||||||
|
} /* end FAT16 detected */
|
||||||
|
} /* end PArtitionentry 0..3 */
|
||||||
|
} /* end of loop 0..1 for active, nonactive */
|
||||||
|
} /* if ( table_type==PRIMARY ) */
|
||||||
|
|
||||||
return TRUE;
|
/* search for EXT partitions only on 2. run */
|
||||||
|
if (table_type==EXTENDED)
|
||||||
|
{
|
||||||
|
for (ptemp_part = &temp_part[0];
|
||||||
|
ptemp_part < &temp_part[N_PART] && nUnits < NDEV; ptemp_part++)
|
||||||
|
{
|
||||||
|
if ( (ptemp_part->peFileSystem == EXTENDED ||
|
||||||
|
ptemp_part->peFileSystem == EXTENDED_INT32 ) )
|
||||||
|
{
|
||||||
|
/* restart with new extended part table, don't recurs */
|
||||||
|
partition_chain++;
|
||||||
|
|
||||||
|
ptHead = ptemp_part->peBeginHead;
|
||||||
|
ptCylinder = ptemp_part->peBeginCylinder;
|
||||||
|
ptSector = ptemp_part->peBeginSector;
|
||||||
|
ptAccuOff = ptemp_part->peStartSector + ptAccuOff;
|
||||||
|
|
||||||
|
PartitionDone = 0; /* not important for EXTENDED */
|
||||||
|
|
||||||
|
goto restart;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return PartitionDone;
|
||||||
}
|
}
|
||||||
|
|
||||||
COUNT FAR init_call_blk_driver(rqptr rp)
|
COUNT FAR init_call_blk_driver(rqptr rp)
|
||||||
|
@ -561,6 +679,7 @@ WORD _dsk_init(rqptr rp)
|
||||||
Unit;
|
Unit;
|
||||||
struct media_info *pmiarray;
|
struct media_info *pmiarray;
|
||||||
bpb *pbpbarray;
|
bpb *pbpbarray;
|
||||||
|
UBYTE foundPartitions[16];
|
||||||
|
|
||||||
|
|
||||||
/* Reset the drives */
|
/* Reset the drives */
|
||||||
|
@ -600,31 +719,37 @@ WORD _dsk_init(rqptr rp)
|
||||||
}
|
}
|
||||||
|
|
||||||
nHardDisk = fl_nrdrives();
|
nHardDisk = fl_nrdrives();
|
||||||
|
|
||||||
|
nHardDisk = min(nHardDisk,sizeof(foundPartitions));
|
||||||
|
|
||||||
/* as rather well documented, DOS searches 1st) all primary patitions on
|
/* as rather well documented, DOS searches 1st) 1 primary patitions on
|
||||||
all drives, 2nd) all extended partitions. that
|
all drives, 2nd) all extended partitions. that
|
||||||
makes many people (including me) unhappy, as all DRIVES D:,E:...
|
makes many people (including me) unhappy, as all DRIVES D:,E:...
|
||||||
on 1st disk will move up/down, if other disk with
|
on 1st disk will move up/down, if other disk with
|
||||||
primary partitions are added/removed, but
|
primary partitions are added/removed, but
|
||||||
thats the way it is (hope I got it right)
|
thats the way it is (hope I got it right)
|
||||||
TE (with a little help from my friends) */
|
TE (with a little help from my friends)
|
||||||
|
see also above for WIN2000,DOS,MSDN */
|
||||||
|
|
||||||
PartCodePrintf(("DSK init: found %d disk drives\n",nHardDisk));
|
PartCodePrintf(("DSK init: found %d disk drives\n",nHardDisk));
|
||||||
|
|
||||||
|
|
||||||
|
/* Process primary partition table 1 partition only */
|
||||||
for (HardDrive = 0; HardDrive < nHardDisk; HardDrive++)
|
for (HardDrive = 0; HardDrive < nHardDisk; HardDrive++)
|
||||||
{
|
{
|
||||||
/* Process primary partition table */
|
foundPartitions[HardDrive] =
|
||||||
if (!processtable(PRIMARY, (HardDrive | 0x80), 0, 0l, 1, 0l))
|
processtable(PRIMARY, (HardDrive | 0x80), 0, 0l, 1, 0l,0);
|
||||||
/* Exit if no hard drive */
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
/* Process extended partition table */
|
||||||
for (HardDrive = 0; HardDrive < nHardDisk; HardDrive++)
|
for (HardDrive = 0; HardDrive < nHardDisk; HardDrive++)
|
||||||
{
|
{
|
||||||
/* Process extended partition table */
|
processtable(EXTENDED, (HardDrive | 0x80), 0, 0l, 1, 0l,0);
|
||||||
if (!processtable(EXTENDED, (HardDrive | 0x80), 0, 0l, 1, 0l))
|
}
|
||||||
/* Exit if no hard drive */
|
|
||||||
break;
|
/* Process primary a 2nd time */
|
||||||
|
for (HardDrive = 0; HardDrive < nHardDisk; HardDrive++)
|
||||||
|
{
|
||||||
|
processtable(PRIMARY, (HardDrive | 0x80), 0, 0l, 1, 0l,foundPartitions[HardDrive]);
|
||||||
}
|
}
|
||||||
|
|
||||||
rp->r_nunits = nUnits;
|
rp->r_nunits = nUnits;
|
||||||
|
|
152
kernel/entry.asm
152
kernel/entry.asm
|
@ -28,8 +28,8 @@
|
||||||
; $Id$
|
; $Id$
|
||||||
;
|
;
|
||||||
; $Log$
|
; $Log$
|
||||||
; Revision 1.5 2001/03/22 20:46:46 bartoldeman
|
; Revision 1.6 2001/03/24 22:13:05 bartoldeman
|
||||||
; cli/sti corrections (Bart) and int25, 26 stack corrections (Tom)
|
; See history.txt: dsk.c changes, warning removal and int21 entry handling.
|
||||||
;
|
;
|
||||||
; Revision 1.4 2001/03/21 02:56:25 bartoldeman
|
; Revision 1.4 2001/03/21 02:56:25 bartoldeman
|
||||||
; See history.txt for changes. Bug fixes and HMA support are the main ones.
|
; See history.txt for changes. Bug fixes and HMA support are the main ones.
|
||||||
|
@ -80,6 +80,7 @@
|
||||||
|
|
||||||
segment HMA_TEXT
|
segment HMA_TEXT
|
||||||
extern _int21_syscall:wrt HGROUP
|
extern _int21_syscall:wrt HGROUP
|
||||||
|
extern _int21_service:wrt HGROUP
|
||||||
extern _int25_handler:wrt HGROUP
|
extern _int25_handler:wrt HGROUP
|
||||||
extern _int26_handler:wrt HGROUP
|
extern _int26_handler:wrt HGROUP
|
||||||
extern _set_stack:wrt HGROUP
|
extern _set_stack:wrt HGROUP
|
||||||
|
@ -218,6 +219,7 @@ reloc_call_int21_handler:
|
||||||
; NB: stack frame is MS-DOS dependent and not compatible
|
; NB: stack frame is MS-DOS dependent and not compatible
|
||||||
; with compiler interrupt stack frames.
|
; with compiler interrupt stack frames.
|
||||||
;
|
;
|
||||||
|
sti
|
||||||
PUSH$ALL
|
PUSH$ALL
|
||||||
|
|
||||||
;
|
;
|
||||||
|
@ -226,18 +228,51 @@ reloc_call_int21_handler:
|
||||||
; NB: At this point, SS != DS and won't be set that way
|
; NB: At this point, SS != DS and won't be set that way
|
||||||
; until later when which stack to run on is determined.
|
; until later when which stack to run on is determined.
|
||||||
;
|
;
|
||||||
mov bp,DGROUP
|
mov dx,DGROUP
|
||||||
mov ds,bp
|
mov ds,dx
|
||||||
|
|
||||||
|
int21_reentry:
|
||||||
|
cmp ah,33h
|
||||||
|
je int21_user
|
||||||
|
cmp ah,50h
|
||||||
|
je int21_user
|
||||||
|
cmp ah,51h
|
||||||
|
je int21_user
|
||||||
|
cmp ah,62h
|
||||||
|
jne int21_1
|
||||||
|
|
||||||
|
int21_user:
|
||||||
|
mov bp,sp
|
||||||
|
push ss
|
||||||
|
push bp
|
||||||
|
call _int21_syscall
|
||||||
|
pop cx
|
||||||
|
pop cx
|
||||||
|
jmp int21_ret
|
||||||
|
|
||||||
|
;
|
||||||
|
; normal entry, use one of our 4 stacks
|
||||||
|
;
|
||||||
|
; DX=DGROUP
|
||||||
|
; CX=STACK
|
||||||
|
; AX=userSS
|
||||||
|
; BX=userSP
|
||||||
|
|
||||||
|
|
||||||
|
int21_1:
|
||||||
|
mov ax,ss ; save user stack, to be retored later
|
||||||
|
mov bx,sp
|
||||||
|
|
||||||
|
|
||||||
;
|
;
|
||||||
; Now DS is set, let's save our stack for rentry
|
; Now DS is set, let's save our stack for rentry (???TE)
|
||||||
;
|
;
|
||||||
mov bp,ss
|
; I don't know who needs that, but ... (TE)
|
||||||
mov word [_lpUserStack+2],bp
|
;
|
||||||
mov word [_user_r+2],bp
|
mov word [_lpUserStack+2],ss
|
||||||
mov bp,sp
|
mov word [_user_r+2],ss
|
||||||
mov word [_lpUserStack],bp ; store and init
|
mov word [_lpUserStack],sp ; store and init
|
||||||
mov word [_user_r],bp ; store and init
|
mov word [_user_r],sp ; store and init
|
||||||
|
|
||||||
;
|
;
|
||||||
; Decide which stack to run on.
|
; Decide which stack to run on.
|
||||||
|
@ -253,82 +288,69 @@ reloc_call_int21_handler:
|
||||||
; call number. Finally, all others run on the disk stack.
|
; call number. Finally, all others run on the disk stack.
|
||||||
; They are evaluated in that order.
|
; They are evaluated in that order.
|
||||||
|
|
||||||
int21_reentry:
|
|
||||||
cmp ah,33h
|
|
||||||
je int21_user
|
|
||||||
cmp ah,50h
|
|
||||||
je int21_user
|
|
||||||
cmp ah,51h
|
|
||||||
je int21_user
|
|
||||||
cmp ah,62h
|
|
||||||
jne int21_1
|
|
||||||
|
|
||||||
int21_user: sti
|
cmp byte [_InDOS],0
|
||||||
push word [_user_r+2]
|
jne int21_onerrorstack
|
||||||
push word [_user_r]
|
|
||||||
call _int21_syscall
|
|
||||||
pop cx
|
|
||||||
pop cx
|
|
||||||
jmp int21_ret
|
|
||||||
|
|
||||||
int21_1: cli
|
|
||||||
cmp byte [_ErrorMode],0
|
cmp byte [_ErrorMode],0
|
||||||
je int21_2
|
je int21_2
|
||||||
mov bp,ds
|
|
||||||
mov ss,bp
|
int21_onerrorstack:
|
||||||
mov bp,_error_tos
|
mov cx,_error_tos
|
||||||
mov sp,bp
|
|
||||||
|
|
||||||
|
cli
|
||||||
|
mov ss,dx
|
||||||
|
mov sp,cx
|
||||||
sti
|
sti
|
||||||
push word [_user_r+2]
|
|
||||||
push word [_user_r]
|
push ax ; user SS:SP
|
||||||
call _int21_syscall
|
push bx
|
||||||
jmp short int21_exit
|
|
||||||
|
call _int21_service
|
||||||
|
jmp short int21_exit_nodec
|
||||||
|
|
||||||
|
|
||||||
int21_2: inc byte [_InDOS]
|
int21_2: inc byte [_InDOS]
|
||||||
cmp ah,0ch
|
cmp ah,0ch
|
||||||
jg int21_3
|
mov cx,_char_api_tos
|
||||||
;
|
jle int21_normalentry
|
||||||
; Make FreeDOS better than the others!
|
|
||||||
;
|
|
||||||
cmp byte [_dosidle_flag],0
|
|
||||||
jne int21_user
|
|
||||||
|
|
||||||
mov bp,ds
|
|
||||||
mov ss,bp
|
|
||||||
mov bp,_char_api_tos
|
|
||||||
mov sp,bp
|
|
||||||
sti
|
|
||||||
push word [_user_r+2]
|
|
||||||
push word [_user_r]
|
|
||||||
call _int21_syscall
|
|
||||||
jmp short int21_exit
|
|
||||||
|
|
||||||
int21_3:
|
int21_3:
|
||||||
call dos_crit_sect
|
call dos_crit_sect
|
||||||
|
mov cx,_disk_api_tos
|
||||||
|
|
||||||
mov bp,ds
|
int21_normalentry:
|
||||||
mov ss,bp
|
|
||||||
mov bp,_disk_api_tos
|
cli
|
||||||
mov sp,bp
|
mov ss,dx
|
||||||
|
mov sp,cx
|
||||||
sti
|
sti
|
||||||
|
|
||||||
;
|
;
|
||||||
; Push the far pointer to the register frame for
|
; Push the far pointer to the register frame for
|
||||||
; int21_syscall and remainder of kernel.
|
; int21_syscall and remainder of kernel.
|
||||||
;
|
;
|
||||||
push word [_user_r+2]
|
|
||||||
push word [_user_r]
|
push ax ; user SS:SP
|
||||||
call _int21_syscall
|
push bx
|
||||||
|
call _int21_service
|
||||||
|
|
||||||
|
int21_exit: dec byte [_InDOS]
|
||||||
|
|
||||||
;
|
;
|
||||||
; Recover registers from system call. Registers and flags
|
; Recover registers from system call. Registers and flags
|
||||||
; were modified by the system call.
|
; were modified by the system call.
|
||||||
;
|
;
|
||||||
int21_exit: cli
|
|
||||||
mov bp,word [_user_r+2]
|
|
||||||
mov ss,bp
|
int21_exit_nodec:
|
||||||
mov bp,word [_user_r] ; store and init
|
pop bx ; get back user stack
|
||||||
mov sp,bp
|
pop ax
|
||||||
dec byte [_InDOS]
|
|
||||||
|
cli
|
||||||
|
mov ss,ax
|
||||||
|
mov sp,bx
|
||||||
sti
|
sti
|
||||||
int21_ret: POP$ALL
|
int21_ret: POP$ALL
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,9 @@ BYTE *RcsId = "$Id$";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* $Log$
|
* $Log$
|
||||||
|
* Revision 1.12 2001/03/24 22:13:05 bartoldeman
|
||||||
|
* See history.txt: dsk.c changes, warning removal and int21 entry handling.
|
||||||
|
*
|
||||||
* Revision 1.11 2001/03/22 04:26:14 bartoldeman
|
* Revision 1.11 2001/03/22 04:26:14 bartoldeman
|
||||||
* dos_gettime() fix by Tom Ehlert.
|
* dos_gettime() fix by Tom Ehlert.
|
||||||
*
|
*
|
||||||
|
@ -216,7 +219,7 @@ static void merge_file_changes(struct f_node FAR *fnp, int collect);
|
||||||
/* /// Added - Ron Cemer */
|
/* /// Added - Ron Cemer */
|
||||||
static int is_same_file(struct f_node FAR *fnp1, struct f_node FAR *fnp2);
|
static int is_same_file(struct f_node FAR *fnp1, struct f_node FAR *fnp2);
|
||||||
/* /// Added - Ron Cemer */
|
/* /// Added - Ron Cemer */
|
||||||
static int copy_file_changes(struct f_node FAR *src, struct f_node FAR *dst);
|
static void copy_file_changes(struct f_node FAR *src, struct f_node FAR *dst);
|
||||||
date dos_getdate(VOID);
|
date dos_getdate(VOID);
|
||||||
time dos_gettime(VOID);
|
time dos_gettime(VOID);
|
||||||
BOOL find_free(struct f_node FAR *);
|
BOOL find_free(struct f_node FAR *);
|
||||||
|
@ -507,7 +510,7 @@ static int is_same_file(struct f_node FAR *fnp1, struct f_node FAR *fnp2) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* /// Added - Ron Cemer */
|
/* /// Added - Ron Cemer */
|
||||||
static int copy_file_changes(struct f_node FAR *src, struct f_node FAR *dst) {
|
static void copy_file_changes(struct f_node FAR *src, struct f_node FAR *dst) {
|
||||||
dst->f_highwater = src->f_highwater;
|
dst->f_highwater = src->f_highwater;
|
||||||
dst->f_dir.dir_start = src->f_dir.dir_start;
|
dst->f_dir.dir_start = src->f_dir.dir_start;
|
||||||
dst->f_dir.dir_size = src->f_dir.dir_size;
|
dst->f_dir.dir_size = src->f_dir.dir_size;
|
||||||
|
|
|
@ -30,6 +30,9 @@
|
||||||
; $Id$
|
; $Id$
|
||||||
;
|
;
|
||||||
; $Log$
|
; $Log$
|
||||||
|
; Revision 1.5 2001/03/24 22:13:05 bartoldeman
|
||||||
|
; See history.txt: dsk.c changes, warning removal and int21 entry handling.
|
||||||
|
;
|
||||||
; Revision 1.4 2001/03/21 02:56:26 bartoldeman
|
; Revision 1.4 2001/03/21 02:56:26 bartoldeman
|
||||||
; See history.txt for changes. Bug fixes and HMA support are the main ones.
|
; See history.txt for changes. Bug fixes and HMA support are the main ones.
|
||||||
;
|
;
|
||||||
|
@ -113,18 +116,19 @@ segment _TEXT
|
||||||
global _exec_user
|
global _exec_user
|
||||||
_exec_user:
|
_exec_user:
|
||||||
|
|
||||||
PUSH$ALL
|
; PUSH$ALL
|
||||||
mov ds,[_DGROUP_]
|
; mov ds,[_DGROUP_]
|
||||||
|
; cld
|
||||||
|
;
|
||||||
|
;
|
||||||
|
;
|
||||||
mov bp,sp
|
mov bp,sp
|
||||||
cld
|
|
||||||
|
mov ax,word [bp+6] ; irp (user ss:sp)
|
||||||
|
mov dx,word [bp+8]
|
||||||
cli
|
cli
|
||||||
;
|
|
||||||
;
|
|
||||||
;
|
|
||||||
mov ax,word [bp+irp_low] ; irp (user ss:sp)
|
|
||||||
mov dx,word [bp+irp_hi]
|
|
||||||
mov sp,ax ; set-up user stack
|
|
||||||
mov ss,dx
|
mov ss,dx
|
||||||
|
mov sp,ax ; set-up user stack
|
||||||
sti
|
sti
|
||||||
;
|
;
|
||||||
POP$ALL
|
POP$ALL
|
||||||
|
@ -308,7 +312,6 @@ _spawn_int23:
|
||||||
|
|
||||||
global _init_call_spawn_int23
|
global _init_call_spawn_int23
|
||||||
_init_call_spawn_int23:
|
_init_call_spawn_int23:
|
||||||
int 3
|
|
||||||
call _spawn_int23
|
call _spawn_int23
|
||||||
retf
|
retf
|
||||||
;
|
;
|
||||||
|
|
Loading…
Reference in New Issue