mirror of https://github.com/FDOS/kernel.git
Some of Arkady's fattab optimizations -- the others only increase the kernel
size for Watcom. git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@898 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
parent
3227b87d5d
commit
490a27b857
|
@ -145,9 +145,9 @@ void write_fsinfo(struct dpb FAR * dpbp)
|
||||||
/* */
|
/* */
|
||||||
/* The FAT file system is difficult to trace through FAT table. */
|
/* The FAT file system is difficult to trace through FAT table. */
|
||||||
/* There are two kinds of FAT's, 12 bit and 16 bit. The 16 bit */
|
/* There are two kinds of FAT's, 12 bit and 16 bit. The 16 bit */
|
||||||
/* FAT is the easiest, since it is noting more than a series of */
|
/* FAT is the easiest, since it is nothing more than a series */
|
||||||
/* UWORD's. The 12 bit FAT is difficult, because it packs 3 FAT */
|
/* of UWORD's. The 12 bit FAT is difficult, because it packs 3 */
|
||||||
/* entries into two BYTE's. The are packed as follows: */
|
/* FAT entries into two BYTE's. These are packed as follows: */
|
||||||
/* */
|
/* */
|
||||||
/* 0x0003 0x0004 0x0005 0x0006 0x0007 0x0008 0x0009 ... */
|
/* 0x0003 0x0004 0x0005 0x0006 0x0007 0x0008 0x0009 ... */
|
||||||
/* */
|
/* */
|
||||||
|
@ -177,9 +177,8 @@ unsigned link_fat(struct dpb FAR * dpbp, CLUSTER Cluster1,
|
||||||
|
|
||||||
/* form an index so that we can read the block as a */
|
/* form an index so that we can read the block as a */
|
||||||
/* byte array */
|
/* byte array */
|
||||||
idx = (unsigned) ((((unsigned)Cluster1 << 1) + (unsigned)Cluster1) >> 1)
|
idx = (((unsigned)Cluster1 << 1) + (unsigned)Cluster1) % dpbp->dpb_secsize;
|
||||||
% dpbp->dpb_secsize;
|
|
||||||
|
|
||||||
/* Test to see if the cluster straddles the block. If */
|
/* Test to see if the cluster straddles the block. If */
|
||||||
/* it does, get the next block and use both to form the */
|
/* it does, get the next block and use both to form the */
|
||||||
/* the FAT word. Otherwise, just point to the next */
|
/* the FAT word. Otherwise, just point to the next */
|
||||||
|
@ -201,13 +200,13 @@ unsigned link_fat(struct dpb FAR * dpbp, CLUSTER Cluster1,
|
||||||
/* Now pack the value in */
|
/* Now pack the value in */
|
||||||
if ((unsigned)Cluster1 & 0x01)
|
if ((unsigned)Cluster1 & 0x01)
|
||||||
{
|
{
|
||||||
*fbp0 = (*fbp0 & 0x0f) | (((UBYTE)Cluster2 & 0x0f) << 4);
|
*fbp0 = (*fbp0 & 0x0f) | (UBYTE)((UBYTE)Cluster2 << 4);
|
||||||
*fbp1 = (UBYTE)((unsigned)Cluster2 >> 4);
|
*fbp1 = (UBYTE)((unsigned)Cluster2 >> 4);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
*fbp0 = (UBYTE)Cluster2;
|
*fbp0 = (UBYTE)Cluster2;
|
||||||
*fbp1 = (*fbp1 & 0xf0) | ((UBYTE)((unsigned)Cluster2 >> 8) & 0x0f);
|
*fbp1 = (*fbp1 & 0xf0) | (UBYTE)((unsigned)Cluster2 >> 8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (ISFAT16(dpbp))
|
else if (ISFAT16(dpbp))
|
||||||
|
|
Loading…
Reference in New Issue