mirror of https://github.com/FDOS/kernel.git
From: Eric Luttmann <ecl@users.sourceforge.net>
Fix for multisegmented device drivers: If there are multiple device drivers in a single driver file, only the END ADDRESS returned by the last INIT call should be the used. It is recommended that all the device drivers in the file return the same address. This fixes a load problem with DUSE. git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@721 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
parent
58808de6c8
commit
8db46073f9
|
@ -535,9 +535,18 @@ BOOL init_device(struct dhdr FAR * dhp, char *cmdLine, COUNT mode,
|
||||||
if (rq.r_endaddr == (BYTE FAR *) dhp)
|
if (rq.r_endaddr == (BYTE FAR *) dhp)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
|
/* Fix for multisegmented device drivers: */
|
||||||
|
/* If there are multiple device drivers in a single driver file, */
|
||||||
|
/* only the END ADDRESS returned by the last INIT call should be */
|
||||||
|
/* the used. It is recommended that all the device drivers in */
|
||||||
|
/* the file return the same address */
|
||||||
|
|
||||||
|
if (FP_OFF(dhp->dh_next) == 0xffff)
|
||||||
|
{
|
||||||
KernelAllocPara(FP_SEG(rq.r_endaddr) + (FP_OFF(rq.r_endaddr) + 15)/16
|
KernelAllocPara(FP_SEG(rq.r_endaddr) + (FP_OFF(rq.r_endaddr) + 15)/16
|
||||||
- FP_SEG(dhp), 'D', name, mode);
|
- FP_SEG(dhp), 'D', name, mode);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!(dhp->dh_attr & ATTR_CHAR) && (rq.r_nunits != 0))
|
if (!(dhp->dh_attr & ATTR_CHAR) && (rq.r_nunits != 0))
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue