mirror of https://github.com/FDOS/kernel.git
inthndler cleanups, mostly from Arkady
Bart: made dosmktmp to return a long: consistent with DosOpen et al and avoids the cast. git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@948 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
parent
e0133fe31b
commit
b723ff9a46
|
@ -382,7 +382,7 @@ int int21_fat32(lregs *r)
|
|||
|
||||
VOID ASMCFUNC int21_service(iregs FAR * r)
|
||||
{
|
||||
COUNT rc = 0;
|
||||
COUNT rc;
|
||||
long lrc;
|
||||
lregs lr; /* 8 local registers (ax, bx, cx, dx, si, di, ds, es) */
|
||||
|
||||
|
@ -671,10 +671,9 @@ dispatch:
|
|||
|
||||
/* Parse File Name */
|
||||
case 0x29:
|
||||
{
|
||||
rc = 0;
|
||||
lr.SI = FcbParseFname(&rc, MK_FP(lr.DS, lr.SI), FP_ES_DI);
|
||||
lr.AL = rc;
|
||||
}
|
||||
break;
|
||||
|
||||
/* Get Date */
|
||||
|
@ -765,8 +764,8 @@ dispatch:
|
|||
|
||||
if (dpb == NULL)
|
||||
{
|
||||
CritErrCode = -DE_INVLDDRV;
|
||||
lr.AL = 0xFF;
|
||||
CritErrCode = 0x0f;
|
||||
break;
|
||||
}
|
||||
/* hazard: no error checking! */
|
||||
|
@ -780,7 +779,7 @@ dispatch:
|
|||
#endif
|
||||
{
|
||||
lr.AL = 0xff;
|
||||
CritErrCode = 0x0f;
|
||||
CritErrCode = -DE_INVLDDRV;
|
||||
break;
|
||||
}
|
||||
lr.DS = FP_SEG(dpb);
|
||||
|
@ -839,22 +838,25 @@ dispatch:
|
|||
if (0xffff == lr.DX)
|
||||
{
|
||||
/* Set Country Code */
|
||||
if ((rc = DosSetCountry(cntry)) < 0)
|
||||
goto error_invalid;
|
||||
rc = DosSetCountry(cntry);
|
||||
goto short_check;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (cntry == 0)
|
||||
cntry--;
|
||||
/* Get Country Information */
|
||||
if ((rc = DosGetCountryInformation(cntry, FP_DS_DX)) < 0)
|
||||
goto error_invalid;
|
||||
rc = DosGetCountryInformation(cntry, FP_DS_DX);
|
||||
if (rc >= SUCCESS)
|
||||
{
|
||||
/* HACK FIXME */
|
||||
if (cntry == (UWORD) - 1)
|
||||
cntry = 1;
|
||||
/* END OF HACK */
|
||||
lr.AX = lr.BX = cntry;
|
||||
}
|
||||
goto short_check;
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
|
@ -928,7 +930,6 @@ dispatch:
|
|||
|
||||
case 0x01:
|
||||
rc = DosSetFattr((BYTE FAR *) FP_DS_DX, lr.CX);
|
||||
if (rc >= SUCCESS)
|
||||
lr.AX = lr.CX;
|
||||
break;
|
||||
|
||||
|
@ -941,11 +942,11 @@ dispatch:
|
|||
case 0x44:
|
||||
rc = DosDevIOctl(&lr); /* can set critical error code! */
|
||||
|
||||
if (rc != SUCCESS)
|
||||
if (rc < SUCCESS)
|
||||
{
|
||||
lr.AX = -rc;
|
||||
if (rc != DE_DEVICE && rc != DE_ACCESS)
|
||||
CritErrCode = -rc;
|
||||
CritErrCode = lr.AX;
|
||||
goto error_carry;
|
||||
}
|
||||
break;
|
||||
|
@ -963,29 +964,24 @@ dispatch:
|
|||
/* Get Current Directory */
|
||||
case 0x47:
|
||||
rc = DosGetCuDir(lr.DL, MK_FP(lr.DS, lr.SI));
|
||||
if (rc >= SUCCESS)
|
||||
lr.AX = 0x0100; /*jpp: from interrupt list */
|
||||
goto short_check;
|
||||
|
||||
/* Allocate memory */
|
||||
case 0x48:
|
||||
if ((rc =
|
||||
DosMemAlloc(lr.BX, mem_access_mode, &(lr.AX), &(lr.BX))) < 0)
|
||||
{
|
||||
DosMemLargest(&(lr.BX));
|
||||
if ((rc = DosMemAlloc(lr.BX, mem_access_mode, &lr.AX, &lr.BX)) < 0)
|
||||
{
|
||||
DosMemLargest(&lr.BX);
|
||||
if (DosMemCheck() != SUCCESS)
|
||||
panic("MCB chain corrupted");
|
||||
}
|
||||
goto error_exit;
|
||||
}
|
||||
else
|
||||
++(lr.AX); /* DosMemAlloc() returns seg of MCB rather than data */
|
||||
lr.AX++; /* DosMemAlloc() returns seg of MCB rather than data */
|
||||
break;
|
||||
|
||||
/* Free memory */
|
||||
case 0x49:
|
||||
if ((rc = DosMemFree((lr.ES) - 1)) < 0)
|
||||
if ((rc = DosMemFree(lr.ES - 1)) < SUCCESS)
|
||||
{
|
||||
if (DosMemCheck() != SUCCESS)
|
||||
panic("MCB chain corrupted");
|
||||
|
@ -1003,10 +999,7 @@ dispatch:
|
|||
#if 0
|
||||
if (cu_psp == lr.ES)
|
||||
{
|
||||
|
||||
psp FAR *p;
|
||||
|
||||
p = MK_FP(cu_psp, 0);
|
||||
psp FAR *p = MK_FP(cu_psp, 0);
|
||||
p->ps_size = lr.BX + cu_psp;
|
||||
}
|
||||
#endif
|
||||
|
@ -1032,21 +1025,18 @@ dispatch:
|
|||
if (((psp FAR *)MK_FP(cu_psp, 0))->ps_parent == cu_psp)
|
||||
break;
|
||||
tsr = FALSE;
|
||||
rc = 0;
|
||||
if (ErrorMode)
|
||||
{
|
||||
ErrorMode = FALSE;
|
||||
rc = 2;
|
||||
rc = 0x200;
|
||||
}
|
||||
else if (break_flg)
|
||||
{
|
||||
break_flg = FALSE;
|
||||
rc = 1;
|
||||
rc = 0x100;
|
||||
}
|
||||
else
|
||||
{
|
||||
rc = 0;
|
||||
}
|
||||
return_code = lr.AL | (rc << 8);
|
||||
return_code = lr.AL | rc;
|
||||
if (DosMemCheck() != SUCCESS)
|
||||
panic("MCB chain corrupted");
|
||||
#ifdef TSC
|
||||
|
@ -1067,7 +1057,6 @@ dispatch:
|
|||
/* dta for this call is set on entry. This */
|
||||
/* needs to be changed for new versions. */
|
||||
rc = DosFindFirst(lr.CX, FP_DS_DX);
|
||||
if (rc >= SUCCESS)
|
||||
lr.AX = 0;
|
||||
goto short_check;
|
||||
|
||||
|
@ -1076,7 +1065,6 @@ dispatch:
|
|||
/* dta for this call is set on entry. This */
|
||||
/* needs to be changed for new versions. */
|
||||
rc = DosFindNext();
|
||||
if (rc >= SUCCESS)
|
||||
lr.AX = 0;
|
||||
goto short_check;
|
||||
/*
|
||||
|
@ -1189,10 +1177,8 @@ dispatch:
|
|||
|
||||
/* Create Temporary File */
|
||||
case 0x5a:
|
||||
if ((rc = DosMkTmp(FP_DS_DX, lr.CX)) < 0)
|
||||
goto error_exit;
|
||||
lr.AX = rc;
|
||||
break;
|
||||
lrc = DosMkTmp(FP_DS_DX, lr.CX);
|
||||
goto long_check;
|
||||
|
||||
/* Create New File */
|
||||
case 0x5b:
|
||||
|
@ -1202,11 +1188,10 @@ dispatch:
|
|||
/* /// Added for SHARE. - Ron Cemer */
|
||||
/* Lock/unlock file access */
|
||||
case 0x5c:
|
||||
if ((rc = DosLockUnlock
|
||||
(lr.BX,
|
||||
(((unsigned long)lr.CX) << 16) | (((unsigned long)lr.DX) ),
|
||||
(((unsigned long)lr.SI) << 16) | (((unsigned long)lr.DI) ),
|
||||
((lr.AX & 0xff) != 0))) != 0)
|
||||
rc = DosLockUnlock
|
||||
(lr.BX, ((unsigned long)lr.CX << 16) | lr.DX,
|
||||
((unsigned long)lr.SI << 16) | lr.DI, lr.AL != 0);
|
||||
if (rc != SUCCESS)
|
||||
goto error_exit;
|
||||
break;
|
||||
/* /// End of additions for SHARE. - Ron Cemer */
|
||||
|
@ -1232,10 +1217,11 @@ dispatch:
|
|||
case 0x08:
|
||||
case 0x09:
|
||||
rc = remote_printredir(lr.DX, Int21AX);
|
||||
CLEAR_CARRY_FLAG();
|
||||
if (rc != SUCCESS)
|
||||
goto error_exit;
|
||||
CLEAR_CARRY_FLAG();
|
||||
break;
|
||||
|
||||
default:
|
||||
CritErrCode = SUCCESS;
|
||||
goto error_invalid;
|
||||
|
@ -1499,21 +1485,19 @@ dispatch:
|
|||
goto error_invalid;
|
||||
}
|
||||
lr.AX = rc;
|
||||
if (rc < 0) goto error_exit;
|
||||
else CLEAR_CARRY_FLAG();
|
||||
break;
|
||||
CLEAR_CARRY_FLAG();
|
||||
goto short_check;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
goto exit_dispatch;
|
||||
long_check:
|
||||
if (lrc < SUCCESS)
|
||||
if (lrc >= SUCCESS)
|
||||
{
|
||||
rc = (int)lrc;
|
||||
goto error_exit;
|
||||
}
|
||||
lr.AX = (UWORD)lrc;
|
||||
goto exit_dispatch;
|
||||
}
|
||||
rc = (int)lrc;
|
||||
short_check:
|
||||
if (rc < SUCCESS)
|
||||
goto error_exit;
|
||||
|
|
|
@ -65,12 +65,12 @@ int SetJFTSize(UWORD nHandles)
|
|||
return SUCCESS;
|
||||
}
|
||||
|
||||
int DosMkTmp(BYTE FAR * pathname, UWORD attr)
|
||||
long DosMkTmp(BYTE FAR * pathname, UWORD attr)
|
||||
{
|
||||
/* create filename from current date and time */
|
||||
char FAR *ptmp;
|
||||
unsigned long randvar;
|
||||
int rc;
|
||||
long rc;
|
||||
int loop;
|
||||
|
||||
ptmp = pathname + fstrlen(pathname);
|
||||
|
@ -94,7 +94,7 @@ int DosMkTmp(BYTE FAR * pathname, UWORD attr)
|
|||
ptmp[i] -= (ptmp[i] < 'A' + 10) ? '0' - 'A' : 10;
|
||||
|
||||
/* only create new file -- 2001/09/22 ska*/
|
||||
rc = (short)DosOpen(pathname, O_LEGACY | O_CREAT | O_RDWR, attr);
|
||||
rc = DosOpen(pathname, O_LEGACY | O_CREAT | O_RDWR, attr);
|
||||
} while (rc == DE_FILEEXISTS && loop++ < 0xfff);
|
||||
|
||||
return rc;
|
||||
|
|
|
@ -373,7 +373,7 @@ VOID InitPSP(VOID);
|
|||
|
||||
/* newstuff.c */
|
||||
int SetJFTSize(UWORD nHandles);
|
||||
int DosMkTmp(BYTE FAR * pathname, UWORD attr);
|
||||
long DosMkTmp(BYTE FAR * pathname, UWORD attr);
|
||||
COUNT truename(const char FAR * src, char * dest, COUNT t);
|
||||
|
||||
/* network.c */
|
||||
|
|
Loading…
Reference in New Issue