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:
Bart Oldeman 2001-03-24 22:13:05 +00:00
parent bf042f7fac
commit 851eb99b63
5 changed files with 373 additions and 213 deletions

View File

@ -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

View File

@ -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;

View File

@ -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

View File

@ -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;

View File

@ -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
; ;