You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
350 lines
8.1 KiB
350 lines
8.1 KiB
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
// Copyright (C) Microsoft Corporation, 1991 - 1996.
|
|
//
|
|
// File: header.hxx
|
|
//
|
|
// Contents: MSF header class
|
|
//
|
|
// Classes: CMSFHeader
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
#ifndef __HEADER_HXX__
|
|
#define __HEADER_HXX__
|
|
|
|
#include "msf.hxx"
|
|
#include "storagep.h"
|
|
|
|
#define HDR_NOFORCE 0x0000
|
|
#define HDR_FORCE 0x0001
|
|
#define HDR_ALL 0x0002
|
|
|
|
struct SPreHeader : protected SStorageFile
|
|
{
|
|
protected:
|
|
USHORT _uMinorVersion;
|
|
USHORT _uDllVersion;
|
|
USHORT _uByteOrder;
|
|
|
|
USHORT _uSectorShift;
|
|
USHORT _uMiniSectorShift;
|
|
|
|
USHORT _usReserved;
|
|
ULONG _ulReserved1;
|
|
|
|
FSINDEX _csectDir; // valid only for >512b sectors
|
|
FSINDEX _csectFat;
|
|
SECT _sectDirStart;
|
|
|
|
DFSIGNATURE _signature;
|
|
|
|
ULONG _ulMiniSectorCutoff;
|
|
|
|
SECT _sectMiniFatStart;
|
|
FSINDEX _csectMiniFat;
|
|
|
|
SECT _sectDifStart;
|
|
FSINDEX _csectDif;
|
|
};
|
|
|
|
|
|
const USHORT CSECTFATREAL = (HEADERSIZE - sizeof(SPreHeader)) / sizeof(SECT);
|
|
|
|
const USHORT CSECTFAT = CSECTFATREAL;
|
|
|
|
class CMSFHeader: private SPreHeader
|
|
{
|
|
public:
|
|
|
|
CMSFHeader(USHORT uSectorShift);
|
|
|
|
SCODE Validate(VOID) const;
|
|
|
|
inline USHORT GetMinorVersion(VOID) const;
|
|
inline USHORT GetDllVersion(VOID) const;
|
|
|
|
inline SCODE SetDirLength(const FSINDEX cDirSect);
|
|
inline FSINDEX GetDirLength(VOID) const;
|
|
|
|
inline SCODE SetFatLength(const FSINDEX cFatSect);
|
|
inline FSINDEX GetFatLength(VOID) const;
|
|
|
|
inline SCODE SetMiniFatLength(const FSINDEX cFatSect);
|
|
inline FSINDEX GetMiniFatLength(VOID) const;
|
|
|
|
inline SCODE SetDirStart(const SECT sect);
|
|
inline SECT GetDirStart(VOID) const;
|
|
|
|
inline SCODE SetFatStart(const SECT sect);
|
|
inline SECT GetFatStart(VOID) const;
|
|
|
|
inline SCODE SetMiniFatStart(const SECT sect);
|
|
inline SECT GetMiniFatStart(VOID) const;
|
|
|
|
inline SCODE SetDifStart(const SECT sect);
|
|
inline SECT GetDifStart(VOID) const;
|
|
|
|
inline SCODE SetDifLength(const FSINDEX cFatSect);
|
|
inline FSINDEX GetDifLength(VOID) const;
|
|
|
|
inline SECT GetFatSect(const FSINDEX oSect) const;
|
|
inline SCODE SetFatSect(const FSINDEX oSect, const SECT sect);
|
|
|
|
inline USHORT GetSectorShift(VOID) const;
|
|
inline USHORT GetMiniSectorShift(VOID) const;
|
|
|
|
inline ULONG GetMiniSectorCutoff(VOID) const;
|
|
|
|
inline DFSIGNATURE GetCommitSig(VOID) const;
|
|
inline void SetCommitSig(const DFSIGNATURE sig);
|
|
|
|
// whether machine is using diff order from file format
|
|
inline BOOL DiffByteOrder(VOID) const;
|
|
inline void ByteSwap(VOID);
|
|
|
|
private:
|
|
SECT _sectFat[CSECTFAT];
|
|
|
|
SCODE SetSig(const BYTE *pbSig);
|
|
};
|
|
|
|
inline SCODE CMSFHeader::SetDirLength(const FSINDEX cDirSect)
|
|
{
|
|
if (_uSectorShift > SECTORSHIFT512)
|
|
{
|
|
_csectDir = cDirSect;
|
|
}
|
|
return S_OK;
|
|
}
|
|
|
|
inline FSINDEX CMSFHeader::GetDirLength(VOID) const
|
|
{
|
|
return _csectDir;
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetFatLength(const FSINDEX cFatSect)
|
|
{
|
|
msfDebugOut((DEB_TRACE,"In CMSFHeader::SetFatLength(%lu)\n",cFatSect));
|
|
_csectFat = cFatSect;
|
|
msfDebugOut((DEB_TRACE,"Out CMSFHeader::SetFatLength()\n"));
|
|
return S_OK;
|
|
}
|
|
|
|
inline FSINDEX CMSFHeader::GetFatLength(VOID) const
|
|
{
|
|
return _csectFat;
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetMiniFatLength(const FSINDEX cFatSect)
|
|
{
|
|
msfDebugOut((DEB_TRACE,"In CMSFHeader::SetMiniFatLength(%lu)\n",cFatSect));
|
|
_csectMiniFat = cFatSect;
|
|
msfDebugOut((DEB_TRACE,"Out CMSFHeader::SetMiniFatLength()\n"));
|
|
return S_OK;
|
|
}
|
|
|
|
inline FSINDEX CMSFHeader::GetMiniFatLength(VOID) const
|
|
{
|
|
return(_csectMiniFat);
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetDirStart(const SECT sectNew)
|
|
{
|
|
_sectDirStart = sectNew;
|
|
return S_OK;
|
|
}
|
|
|
|
inline SECT CMSFHeader::GetDirStart(VOID) const
|
|
{
|
|
return _sectDirStart;
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetFatStart(const SECT sectNew)
|
|
{
|
|
_sectFat[0] = sectNew;
|
|
return S_OK;
|
|
}
|
|
|
|
inline SECT CMSFHeader::GetFatStart(VOID) const
|
|
{
|
|
return _sectFat[0];
|
|
}
|
|
|
|
//+-------------------------------------------------------------------------
|
|
//
|
|
// Member: CMSFHeader::SetMiniFatStart
|
|
//
|
|
// Synopsis: Sets minifat's first sector's index
|
|
//
|
|
// Arguments: [sectNew] -- sector index
|
|
//
|
|
// Returns: S_OK (necessary?)
|
|
//
|
|
// Modifies: _sectMiniFatStart
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
inline SCODE CMSFHeader::SetMiniFatStart(const SECT sectNew)
|
|
{
|
|
_sectMiniFatStart = sectNew;
|
|
return S_OK;
|
|
}
|
|
|
|
//+-------------------------------------------------------------------------
|
|
//
|
|
// Member: CMSFHeader::GetMiniFatStart
|
|
//
|
|
// Synopsis: Gets minifat's first sector's index
|
|
//
|
|
// Returns: minifat's first sector's index
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
inline SECT CMSFHeader::GetMiniFatStart(VOID) const
|
|
{
|
|
return(_sectMiniFatStart);
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetDifStart(const SECT sectNew)
|
|
{
|
|
_sectDifStart = sectNew;
|
|
return S_OK;
|
|
}
|
|
|
|
inline SECT CMSFHeader::GetDifStart(VOID) const
|
|
{
|
|
return _sectDifStart;
|
|
}
|
|
|
|
inline SECT CMSFHeader::GetFatSect(const FSINDEX oSect) const
|
|
{
|
|
msfAssert(oSect < CSECTFAT);
|
|
return _sectFat[oSect];
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetFatSect(const FSINDEX oSect, const SECT sect)
|
|
{
|
|
msfAssert(oSect < CSECTFAT);
|
|
_sectFat[oSect] = sect;
|
|
return S_OK;
|
|
}
|
|
|
|
inline SCODE CMSFHeader::SetDifLength(const FSINDEX cFatSect)
|
|
{
|
|
_csectDif = cFatSect;
|
|
return S_OK;
|
|
}
|
|
|
|
|
|
inline FSINDEX CMSFHeader::GetDifLength(VOID) const
|
|
{
|
|
return _csectDif;
|
|
}
|
|
|
|
|
|
inline USHORT CMSFHeader::GetSectorShift(VOID) const
|
|
{
|
|
return _uSectorShift;
|
|
}
|
|
|
|
|
|
inline DFSIGNATURE CMSFHeader::GetCommitSig(VOID) const
|
|
{
|
|
return _signature;
|
|
}
|
|
|
|
inline void CMSFHeader::SetCommitSig(const DFSIGNATURE sig)
|
|
{
|
|
_signature = sig;
|
|
}
|
|
|
|
inline USHORT CMSFHeader::GetMiniSectorShift(VOID) const
|
|
{
|
|
return _uMiniSectorShift;
|
|
}
|
|
|
|
inline ULONG CMSFHeader::GetMiniSectorCutoff(VOID) const
|
|
{
|
|
return _ulMiniSectorCutoff;
|
|
}
|
|
|
|
inline USHORT CMSFHeader::GetMinorVersion(VOID) const
|
|
{
|
|
return _uMinorVersion;
|
|
}
|
|
|
|
inline USHORT CMSFHeader::GetDllVersion(VOID) const
|
|
{
|
|
return _uDllVersion;
|
|
}
|
|
|
|
// we always store Litte Endian on disk
|
|
#define DISK_BYTE_ORDER 0xFFFE
|
|
|
|
// whether machine is using diff order than file format
|
|
inline BOOL CMSFHeader::DiffByteOrder(VOID) const
|
|
{
|
|
// _uByteOrder stores what the machine will see
|
|
// when it reads in a Little Endian 0xFFFE on disk
|
|
#ifndef _GENERATE_REVERSE_
|
|
return _uByteOrder != DISK_BYTE_ORDER;
|
|
#else
|
|
return _uByteOrder == DISK_BYTE_ORDER;
|
|
#endif
|
|
}
|
|
|
|
inline void CMSFHeader::ByteSwap(VOID)
|
|
{
|
|
if (DiffByteOrder())
|
|
{
|
|
::ByteSwap(& _uMinorVersion);
|
|
::ByteSwap(& _uDllVersion);
|
|
// note: _uByteOrder should not be swapped so that we know
|
|
// which Endian the machine is operating in.
|
|
::ByteSwap(& _uSectorShift);
|
|
::ByteSwap(& _uMiniSectorShift);
|
|
|
|
::ByteSwap(& _usReserved);
|
|
::ByteSwap(& _ulReserved1);
|
|
|
|
::ByteSwap(& _csectDir);
|
|
::ByteSwap(& _csectFat);
|
|
::ByteSwap(& _sectDirStart);
|
|
|
|
::ByteSwap(& _signature);
|
|
|
|
::ByteSwap(& _ulMiniSectorCutoff);
|
|
|
|
::ByteSwap(& _sectMiniFatStart);
|
|
::ByteSwap(& _csectMiniFat);
|
|
|
|
::ByteSwap(& _sectDifStart);
|
|
::ByteSwap(& _csectDif);
|
|
|
|
// swapping the Fat table
|
|
for (int cnt=0; cnt < CSECTFAT; cnt++)
|
|
::ByteSwap( &(_sectFat[cnt]) );
|
|
}
|
|
}
|
|
|
|
const ULONG OACCESS = 0xFFFFFF00;
|
|
const ULONG OREADLOCK = OACCESS + 1;
|
|
const ULONG CREADLOCKS = 16;
|
|
const ULONG OUPDATE = OREADLOCK + CREADLOCKS + 1;
|
|
const ULONG OOPENLOCK = OUPDATE + 1;
|
|
const ULONG COPENLOCKS = 20;
|
|
const ULONG OOPENREADLOCK = OOPENLOCK;
|
|
const ULONG OOPENWRITELOCK = OOPENLOCK + COPENLOCKS;
|
|
const ULONG OOPENDENYREADLOCK = OOPENWRITELOCK + COPENLOCKS;
|
|
const ULONG OOPENDENYWRITELOCK = OOPENDENYREADLOCK + COPENLOCKS;
|
|
const ULONG OLOCKREGIONEND = OOPENDENYWRITELOCK + COPENLOCKS;
|
|
|
|
|
|
#endif //__HEADER_HXX__
|
|
|
|
|
|
|
|
|
|
|