blob: 2720864c286ef320dcb8eab6adaab582807cdd6a [file] [log] [blame]
Steve Kondik2111ad72013-07-07 12:07:44 -07001/*
2 * volume.h - Exports for NTFS volume handling. Originated from the Linux-NTFS project.
3 *
4 * Copyright (c) 2000-2004 Anton Altaparmakov
5 * Copyright (c) 2004-2005 Richard Russon
6 * Copyright (c) 2005-2006 Yura Pakhuchiy
7 * Copyright (c) 2005-2009 Szabolcs Szakacsits
8 * Copyright (c) 2010 Jean-Pierre Andre
9 *
10 * This program/include file is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License as published
12 * by the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program/include file is distributed in the hope that it will be
16 * useful, but WITHOUT ANY WARRANTY; without even the implied warranty
17 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program (in the main directory of the NTFS-3G
22 * distribution in the file COPYING); if not, write to the Free Software
23 * Foundation,Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 */
25
26#ifndef _NTFS_VOLUME_H
27#define _NTFS_VOLUME_H
28
29#ifdef HAVE_CONFIG_H
30#include "config.h"
31#endif
32
33#ifdef HAVE_STDIO_H
34#include <stdio.h>
35#endif
36#ifdef HAVE_SYS_PARAM_H
37#include <sys/param.h>
38#endif
Steve Kondik79165c32015-11-09 19:43:00 -080039 /* Do not #include <sys/mount.h> here : conflicts with <linux/fs.h> */
Steve Kondik2111ad72013-07-07 12:07:44 -070040#ifdef HAVE_MNTENT_H
41#include <mntent.h>
42#endif
43
44/* Forward declaration */
45typedef struct _ntfs_volume ntfs_volume;
46
47#include "param.h"
48#include "types.h"
49#include "support.h"
50#include "device.h"
51#include "inode.h"
52#include "attrib.h"
53#include "index.h"
54
55/**
56 * enum ntfs_mount_flags -
57 *
58 * Flags for the ntfs_mount() function.
59 */
60enum {
61 NTFS_MNT_NONE = 0x00000000,
62 NTFS_MNT_RDONLY = 0x00000001,
63 NTFS_MNT_FORENSIC = 0x04000000, /* No modification during
64 * mount. */
65 NTFS_MNT_EXCLUSIVE = 0x08000000,
66 NTFS_MNT_RECOVER = 0x10000000,
67 NTFS_MNT_IGNORE_HIBERFILE = 0x20000000,
68};
69typedef unsigned long ntfs_mount_flags;
70
71/**
72 * enum ntfs_mounted_flags -
73 *
74 * Flags returned by the ntfs_check_if_mounted() function.
75 */
76typedef enum {
77 NTFS_MF_MOUNTED = 1, /* Device is mounted. */
78 NTFS_MF_ISROOT = 2, /* Device is mounted as system root. */
79 NTFS_MF_READONLY = 4, /* Device is mounted read-only. */
80} ntfs_mounted_flags;
81
82extern int ntfs_check_if_mounted(const char *file, unsigned long *mnt_flags);
83
84typedef enum {
85 NTFS_VOLUME_OK = 0,
86 NTFS_VOLUME_SYNTAX_ERROR = 11,
87 NTFS_VOLUME_NOT_NTFS = 12,
88 NTFS_VOLUME_CORRUPT = 13,
89 NTFS_VOLUME_HIBERNATED = 14,
90 NTFS_VOLUME_UNCLEAN_UNMOUNT = 15,
91 NTFS_VOLUME_LOCKED = 16,
92 NTFS_VOLUME_RAID = 17,
93 NTFS_VOLUME_UNKNOWN_REASON = 18,
94 NTFS_VOLUME_NO_PRIVILEGE = 19,
95 NTFS_VOLUME_OUT_OF_MEMORY = 20,
96 NTFS_VOLUME_FUSE_ERROR = 21,
97 NTFS_VOLUME_INSECURE = 22
98} ntfs_volume_status;
99
100/**
101 * enum ntfs_volume_state_bits -
102 *
103 * Defined bits for the state field in the ntfs_volume structure.
104 */
105typedef enum {
106 NV_ReadOnly, /* 1: Volume is read-only. */
107 NV_CaseSensitive, /* 1: Volume is mounted case-sensitive. */
108 NV_LogFileEmpty, /* 1: $logFile journal is empty. */
109 NV_ShowSysFiles, /* 1: Show NTFS metafiles. */
110 NV_ShowHidFiles, /* 1: Show files marked hidden. */
111 NV_HideDotFiles, /* 1: Set hidden flag on dot files */
112 NV_Compression, /* 1: allow compression */
113 NV_NoFixupWarn, /* 1: Do not log fixup errors */
114} ntfs_volume_state_bits;
115
116#define test_nvol_flag(nv, flag) test_bit(NV_##flag, (nv)->state)
117#define set_nvol_flag(nv, flag) set_bit(NV_##flag, (nv)->state)
118#define clear_nvol_flag(nv, flag) clear_bit(NV_##flag, (nv)->state)
119
120#define NVolReadOnly(nv) test_nvol_flag(nv, ReadOnly)
121#define NVolSetReadOnly(nv) set_nvol_flag(nv, ReadOnly)
122#define NVolClearReadOnly(nv) clear_nvol_flag(nv, ReadOnly)
123
124#define NVolCaseSensitive(nv) test_nvol_flag(nv, CaseSensitive)
125#define NVolSetCaseSensitive(nv) set_nvol_flag(nv, CaseSensitive)
126#define NVolClearCaseSensitive(nv) clear_nvol_flag(nv, CaseSensitive)
127
128#define NVolLogFileEmpty(nv) test_nvol_flag(nv, LogFileEmpty)
129#define NVolSetLogFileEmpty(nv) set_nvol_flag(nv, LogFileEmpty)
130#define NVolClearLogFileEmpty(nv) clear_nvol_flag(nv, LogFileEmpty)
131
132#define NVolShowSysFiles(nv) test_nvol_flag(nv, ShowSysFiles)
133#define NVolSetShowSysFiles(nv) set_nvol_flag(nv, ShowSysFiles)
134#define NVolClearShowSysFiles(nv) clear_nvol_flag(nv, ShowSysFiles)
135
136#define NVolShowHidFiles(nv) test_nvol_flag(nv, ShowHidFiles)
137#define NVolSetShowHidFiles(nv) set_nvol_flag(nv, ShowHidFiles)
138#define NVolClearShowHidFiles(nv) clear_nvol_flag(nv, ShowHidFiles)
139
140#define NVolHideDotFiles(nv) test_nvol_flag(nv, HideDotFiles)
141#define NVolSetHideDotFiles(nv) set_nvol_flag(nv, HideDotFiles)
142#define NVolClearHideDotFiles(nv) clear_nvol_flag(nv, HideDotFiles)
143
144#define NVolCompression(nv) test_nvol_flag(nv, Compression)
145#define NVolSetCompression(nv) set_nvol_flag(nv, Compression)
146#define NVolClearCompression(nv) clear_nvol_flag(nv, Compression)
147
148#define NVolNoFixupWarn(nv) test_nvol_flag(nv, NoFixupWarn)
149#define NVolSetNoFixupWarn(nv) set_nvol_flag(nv, NoFixupWarn)
150#define NVolClearNoFixupWarn(nv) clear_nvol_flag(nv, NoFixupWarn)
151
152/*
153 * NTFS version 1.1 and 1.2 are used by Windows NT4.
154 * NTFS version 2.x is used by Windows 2000 Beta
155 * NTFS version 3.0 is used by Windows 2000.
156 * NTFS version 3.1 is used by Windows XP, 2003 and Vista.
157 */
158
159#define NTFS_V1_1(major, minor) ((major) == 1 && (minor) == 1)
160#define NTFS_V1_2(major, minor) ((major) == 1 && (minor) == 2)
161#define NTFS_V2_X(major, minor) ((major) == 2)
162#define NTFS_V3_0(major, minor) ((major) == 3 && (minor) == 0)
163#define NTFS_V3_1(major, minor) ((major) == 3 && (minor) == 1)
164
165#define NTFS_BUF_SIZE 8192
166
167/**
168 * struct _ntfs_volume - structure describing an open volume in memory.
169 */
170struct _ntfs_volume {
171 union {
172 struct ntfs_device *dev; /* NTFS device associated with
173 the volume. */
174 void *sb; /* For kernel porting compatibility. */
175 };
176 char *vol_name; /* Name of the volume. */
177 unsigned long state; /* NTFS specific flags describing this volume.
178 See ntfs_volume_state_bits above. */
179
180 ntfs_inode *vol_ni; /* ntfs_inode structure for FILE_Volume. */
181 u8 major_ver; /* Ntfs major version of volume. */
182 u8 minor_ver; /* Ntfs minor version of volume. */
183 le16 flags; /* Bit array of VOLUME_* flags. */
184
185 u16 sector_size; /* Byte size of a sector. */
186 u8 sector_size_bits; /* Log(2) of the byte size of a sector. */
187 u32 cluster_size; /* Byte size of a cluster. */
188 u32 mft_record_size; /* Byte size of a mft record. */
189 u32 indx_record_size; /* Byte size of a INDX record. */
190 u8 cluster_size_bits; /* Log(2) of the byte size of a cluster. */
191 u8 mft_record_size_bits;/* Log(2) of the byte size of a mft record. */
192 u8 indx_record_size_bits;/* Log(2) of the byte size of a INDX record. */
193
194 /* Variables used by the cluster and mft allocators. */
195 u8 mft_zone_multiplier; /* Initial mft zone multiplier. */
196 u8 full_zones; /* cluster zones which are full */
197 s64 mft_data_pos; /* Mft record number at which to allocate the
198 next mft record. */
199 LCN mft_zone_start; /* First cluster of the mft zone. */
200 LCN mft_zone_end; /* First cluster beyond the mft zone. */
201 LCN mft_zone_pos; /* Current position in the mft zone. */
202 LCN data1_zone_pos; /* Current position in the first data zone. */
203 LCN data2_zone_pos; /* Current position in the second data zone. */
204
205 s64 nr_clusters; /* Volume size in clusters, hence also the
206 number of bits in lcn_bitmap. */
207 ntfs_inode *lcnbmp_ni; /* ntfs_inode structure for FILE_Bitmap. */
208 ntfs_attr *lcnbmp_na; /* ntfs_attr structure for the data attribute
209 of FILE_Bitmap. Each bit represents a
210 cluster on the volume, bit 0 representing
211 lcn 0 and so on. A set bit means that the
212 cluster and vice versa. */
213
214 LCN mft_lcn; /* Logical cluster number of the data attribute
215 for FILE_MFT. */
216 ntfs_inode *mft_ni; /* ntfs_inode structure for FILE_MFT. */
217 ntfs_attr *mft_na; /* ntfs_attr structure for the data attribute
218 of FILE_MFT. */
219 ntfs_attr *mftbmp_na; /* ntfs_attr structure for the bitmap attribute
220 of FILE_MFT. Each bit represents an mft
221 record in the $DATA attribute, bit 0
222 representing mft record 0 and so on. A set
223 bit means that the mft record is in use and
224 vice versa. */
225
226 ntfs_inode *secure_ni; /* ntfs_inode structure for FILE $Secure */
227 ntfs_index_context *secure_xsii; /* index for using $Secure:$SII */
228 ntfs_index_context *secure_xsdh; /* index for using $Secure:$SDH */
229 int secure_reentry; /* check for non-rentries */
230 unsigned int secure_flags; /* flags, see security.h for values */
231
232 int mftmirr_size; /* Size of the FILE_MFTMirr in mft records. */
233 LCN mftmirr_lcn; /* Logical cluster number of the data attribute
234 for FILE_MFTMirr. */
235 ntfs_inode *mftmirr_ni; /* ntfs_inode structure for FILE_MFTMirr. */
236 ntfs_attr *mftmirr_na; /* ntfs_attr structure for the data attribute
237 of FILE_MFTMirr. */
238
239 ntfschar *upcase; /* Upper case equivalents of all 65536 2-byte
240 Unicode characters. Obtained from
241 FILE_UpCase. */
242 u32 upcase_len; /* Length in Unicode characters of the upcase
243 table. */
244 ntfschar *locase; /* Lower case equivalents of all 65536 2-byte
245 Unicode characters. Only if option
246 case_ignore is set. */
247
248 ATTR_DEF *attrdef; /* Attribute definitions. Obtained from
249 FILE_AttrDef. */
250 s32 attrdef_len; /* Size of the attribute definition table in
251 bytes. */
252
253 s64 free_clusters; /* Track the number of free clusters which
254 greatly improves statfs() performance */
255 s64 free_mft_records; /* Same for free mft records (see above) */
256 BOOL efs_raw; /* volume is mounted for raw access to
257 efs-encrypted files */
258#ifdef XATTR_MAPPINGS
259 struct XATTRMAPPING *xattr_mapping;
260#endif /* XATTR_MAPPINGS */
261#if CACHE_INODE_SIZE
262 struct CACHE_HEADER *xinode_cache;
263#endif
264#if CACHE_NIDATA_SIZE
265 struct CACHE_HEADER *nidata_cache;
266#endif
267#if CACHE_LOOKUP_SIZE
268 struct CACHE_HEADER *lookup_cache;
269#endif
270#if CACHE_SECURID_SIZE
271 struct CACHE_HEADER *securid_cache;
272#endif
273#if CACHE_LEGACY_SIZE
274 struct CACHE_HEADER *legacy_cache;
275#endif
276
277};
278
279extern const char *ntfs_home;
280
281extern ntfs_volume *ntfs_volume_alloc(void);
282
283extern ntfs_volume *ntfs_volume_startup(struct ntfs_device *dev,
284 ntfs_mount_flags flags);
285
286extern ntfs_volume *ntfs_device_mount(struct ntfs_device *dev,
287 ntfs_mount_flags flags);
288
289extern ntfs_volume *ntfs_mount(const char *name, ntfs_mount_flags flags);
290extern int ntfs_umount(ntfs_volume *vol, const BOOL force);
291
292extern int ntfs_version_is_supported(ntfs_volume *vol);
293extern int ntfs_volume_check_hiberfile(ntfs_volume *vol, int verbose);
294extern int ntfs_logfile_reset(ntfs_volume *vol);
295
296extern int ntfs_volume_write_flags(ntfs_volume *vol, const le16 flags);
297
298extern int ntfs_volume_error(int err);
299extern void ntfs_mount_error(const char *vol, const char *mntpoint, int err);
300
301extern int ntfs_volume_get_free_space(ntfs_volume *vol);
302extern int ntfs_volume_rename(ntfs_volume *vol, const ntfschar *label,
303 int label_len);
304
305extern int ntfs_set_shown_files(ntfs_volume *vol,
306 BOOL show_sys_files, BOOL show_hid_files, BOOL hide_dot_files);
307extern int ntfs_set_locale(void);
308extern int ntfs_set_ignore_case(ntfs_volume *vol);
309
310#endif /* defined _NTFS_VOLUME_H */
311