-
Notifications
You must be signed in to change notification settings - Fork 7
/
extx.h
83 lines (73 loc) · 3.79 KB
/
extx.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*================================================================================*/
/* Copyright (C) 2009, Don Milne. */
/* All rights reserved. */
/* See LICENSE.TXT for conditions on copying, distribution, modification and use. */
/*================================================================================*/
#ifndef EXTX_H
#define EXTX_H
/* Support for Linux ext2,ext3 and ext4 */
#include "fsys.h"
BOOL Extx_IsLinuxVolume(HVDDR hVDI, HUGE iLBA);
/* Does quick check to see if an extx partition starts at the given LBA.
* Returns TRUE if so.
*/
HFSYS Extx_OpenVolume(HVDDR hVDI, HUGE iLBA, HUGE cLBA, UINT cSectorSize);
/* Attempts to open an extX volume (partition). The function returns a non-NULL handle if
* the volume was successfully recognized as an extX volume.
*
* hVDI is the VDD object to read from. This handle must remain valid for as long
* as the EXTx volume is open.
*
* iLBA is the LBA start address of the volume (boot sector). Note NOT the disk MBR,
* at least not unless the MBR and the boot sector are the same.
*
* cLBA is the length of the volume, in sectors.
*
* cSectorSize is the size of one sector (usually 512).
*/
HFSYS Extx_CloseVolume(HFSYS hExt);
/* Closes a previously opened extX volume, returning NULL. Passing NULL to this function
* is a NOP.
*/
int Extx_IsBlockUsed(HFSYS hExt, UINT iBlock, UINT SectorsPerBlockShift);
/* This function determines whether a given "block" is being used by the EXTX filesystem. A
* block is an arbitrarily sized region of disk space - however the block size must be a
* power of two number of sectors.
*
* o hExt must be a handle returned by a prior call to Extx_OpenVolume().
*
* o iBlock is an offset from the start of the disk image, in units of BlockSize. Note that
* this is an absolute disk offset. The referenced block may fully or partly or not at
* all intersect the EXTX volume.
*
* o SectorsPerBlockShift is the number of 512 byte sectors in a block, expressed as a shift
* amount, i.e. log2(SectorsPerBlock). For example a 1MB block has 2048 sectors,
* which when expressed as a shift amount equals 11.
*
* The function returns one of the FSYS_BLOCK_xxxx result codes defined in fsys.h.
*
* FSYS_BLOCK_OUTSIDE - The block falls at least partly outside the EXTX volume, therefore
* the EXTX manager cannot determine whether this block is needed (best
* assume that it is, unless it falls inside some other partition).
* FSYS_BLOCK_USED - The block falls wholly inside the EXTX volume, and the EXTX code has
* determined that at least one used cluster falls inside this block.
* FSYS_BLOCK_UNUSED - The block falls wholly inside the EXTX volume, and the EXTX code has
* determined that no used clusters fall inside this block. (i.e. this
* block can be discarded from a VDI clone).
*/
UINT Extx_GrowPartition(HVDDR hVDI, UINT iLBA, UINT OldSectors, UINT NewSectors, UINT cHeads);
/* Enlarges the partition to fill the space vacated by enlarging the drive. The free space
* is assumed to immediately follow the current partition.
*
* o hVDI is a handle to the COW overlay over a physical disk (it must be a COW overlay to
* allow writes to the drive.
* o iLBA is the start LBA of the EXTx partition.
* o OldSectors is the current size of the partition, in sectors.
* o NewSectors is the maximum size of the enlarged partition.
* o cHeads is the number of heads (for CHS addressing) in the new drive geometry.
*
* The function returns the actual size in sectors of the enlarged partition. On an error
* this will be unchanged from the "OldSectors" argument.
*
*/
#endif