Inlined dos_setdta. Various bug fixes and cleanups from Lucho and Arkady.

git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@941 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
Bart Oldeman 2004-05-23 14:49:11 +00:00
parent 2cdf880b85
commit 42c0af3aee
3 changed files with 21 additions and 43 deletions

View File

@ -1944,11 +1944,6 @@ VOID release_f_node(f_node_ptr fnp)
}
#ifndef IPL
VOID dos_setdta(BYTE FAR * newdta)
{
dta = newdta;
}
COUNT dos_getfattr_fd(COUNT fd)
{
f_node_ptr fnp = xlt_fd(fd);

View File

@ -353,7 +353,7 @@ int int21_fat32(lregs *r)
return DE_INVLDPARM;
}
if (r->DL - 1 >= lastdrive || r->DL == 0)
if (r->DL > lastdrive || r->DL == 0)
return -0x207;
if (r->SI == 0)
@ -608,7 +608,7 @@ dispatch:
/* Set DTA */
case 0x1a:
dos_setdta(FP_DS_DX);
dta = FP_DS_DX;
break;
/* Get Default Drive Data */
@ -907,7 +907,7 @@ dispatch:
lrc = DosSeek(lr.BX, (LONG)((((ULONG) (lr.CX)) << 16) | lr.DX), lr.AL);
if (lrc == -1)
{
lrc = -DE_INVLDHNDL;
lrc = DE_INVLDHNDL;
}
else
{
@ -1266,23 +1266,16 @@ dispatch:
if (lr.AL == 7 || lr.AL == 8)
{
struct cds FAR *cdsp;
if (lr.DL < lastdrive)
if (lr.DL >= lastdrive)
{
rc = DE_INVLDDRV;
goto error_exit;
}
else
{
cdsp = &CDSp[lr.DL];
if (lr.AL == 7)
{
cdsp->cdsFlags |= 0x100;
}
cdsp->cdsFlags |= CDSPHYSDRV;
else
{
cdsp->cdsFlags &= ~0x100;
}
}
cdsp->cdsFlags &= ~CDSPHYSDRV;
}
else
{
@ -1380,7 +1373,7 @@ dispatch:
printf("DosGetData() := %d\n", rc);
goto error_exit;
}
printf("DosGetData() returned successfully\n", rc);
printf("DosGetData() returned successfully\n");
break;
#else
rc = DosGetData(lr.AL, lr.BX, lr.DX, lr.CX, FP_ES_DI);
@ -1421,15 +1414,16 @@ dispatch:
/* Get/Set Serial Number */
case 0x69:
rc = (lr.BL == 0 ? default_drive : lr.BL - 1);
if (lr.AL == 0 || lr.AL == 1)
if (lr.AL < 2)
{
if (get_cds(rc) == NULL)
{
rc = DE_INVLDDRV;
goto error_exit;
}
if (get_dpb(rc) != NULL)
{
UWORD saveCX = lr.CX;
if (get_cds(rc) == NULL)
rc = DE_INVLDDRV;
else if (get_dpb(rc) == NULL)
goto error_invalid;
else
{
lr.CX = lr.AL == 0 ? 0x0866 : 0x0846;
lr.AL = 0x0d;
rc = DosDevIOctl(&lr);
@ -1437,9 +1431,7 @@ dispatch:
goto short_check;
}
}
else
goto error_invalid;
break;
/*
case 0x6a: see case 0x68
case 0x6b: dummy func: return AL=0
@ -1631,21 +1623,14 @@ VOID ASMCFUNC int2526_handler(WORD mode, struct int25regs FAR * r)
r->ax = dskxfer(drv, blkno, buf, nblks, mode);
if (mode == DSKWRITE)
if (r->ax <= 0)
setinvld(drv);
if (r->ax > 0)
r->flags &= ~FLG_CARRY;
if (r->ax != 0)
{
r->flags |= FLG_CARRY;
--InDOS;
return;
if (mode == DSKWRITEINT26)
setinvld(drv);
}
r->ax = 0;
r->flags &= ~FLG_CARRY;
--InDOS;
}
/*
@ -1932,7 +1917,6 @@ VOID ASMCFUNC int2F_12_handler(struct int2f12regs r)
put_unsigned(r.AL, 16, 2);
put_string("\n");
r.FLAGS |= FLG_CARRY;
break;
}
}
}

View File

@ -182,7 +182,6 @@ int dos_cd(char * PathName);
f_node_ptr get_f_node(void);
VOID release_f_node(f_node_ptr fnp);
#define release_near_f_node(fnp) ((fnp)->f_count = 0)
VOID dos_setdta(BYTE FAR * newdta);
COUNT dos_getfattr_fd(COUNT fd);
COUNT dos_getfattr(BYTE * name);
COUNT dos_setfattr(BYTE * name, UWORD attrp);