root/src/add-ons/kernel/file_systems/ntfs/libntfs/volume.h
/*
 * volume.h - Exports for NTFS volume handling. Originated from the Linux-NTFS project.
 *
 * Copyright (c) 2000-2004 Anton Altaparmakov
 * Copyright (c) 2004-2005 Richard Russon
 * Copyright (c) 2005-2006 Yura Pakhuchiy
 * Copyright (c) 2005-2009 Szabolcs Szakacsits
 * Copyright (c) 2010      Jean-Pierre Andre
 *
 * This program/include file is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as published
 * by the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program/include file is distributed in the hope that it will be
 * useful, but WITHOUT ANY WARRANTY; without even the implied warranty
 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program (in the main directory of the NTFS-3G
 * distribution in the file COPYING); if not, write to the Free Software
 * Foundation,Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

#ifndef _NTFS_VOLUME_H
#define _NTFS_VOLUME_H

#ifdef HAVE_CONFIG_H
#include "config.h"
#endif

#ifdef HAVE_STDIO_H
#include <stdio.h>
#endif
#ifdef HAVE_SYS_PARAM_H
#include <sys/param.h>
#endif
        /* Do not #include <sys/mount.h> here : conflicts with <linux/fs.h> */
#ifdef HAVE_MNTENT_H
#include <mntent.h>
#endif

/* Forward declaration */
typedef struct _ntfs_volume ntfs_volume;

#include "param.h"
#include "types.h"
#include "support.h"
#include "device.h"
#include "inode.h"
#include "attrib.h"
#include "index.h"

/**
 * enum ntfs_mount_flags -
 *
 * Flags for the ntfs_mount() function.
 */
enum {
        NTFS_MNT_NONE                   = 0x00000000,
        NTFS_MNT_RDONLY                 = 0x00000001,
        NTFS_MNT_MAY_RDONLY             = 0x02000000, /* Allow fallback to ro */
        NTFS_MNT_FORENSIC               = 0x04000000, /* No modification during
                                                       * mount. */
        NTFS_MNT_EXCLUSIVE              = 0x08000000,
        NTFS_MNT_RECOVER                = 0x10000000,
        NTFS_MNT_IGNORE_HIBERFILE       = 0x20000000,
};
typedef unsigned long ntfs_mount_flags;

/**
 * enum ntfs_mounted_flags -
 *
 * Flags returned by the ntfs_check_if_mounted() function.
 */
typedef enum {
        NTFS_MF_MOUNTED         = 1,    /* Device is mounted. */
        NTFS_MF_ISROOT          = 2,    /* Device is mounted as system root. */
        NTFS_MF_READONLY        = 4,    /* Device is mounted read-only. */
} ntfs_mounted_flags;

extern int ntfs_check_if_mounted(const char *file, unsigned long *mnt_flags);

typedef enum {
        NTFS_VOLUME_OK                  = 0,
        NTFS_VOLUME_SYNTAX_ERROR        = 11,
        NTFS_VOLUME_NOT_NTFS            = 12,
        NTFS_VOLUME_CORRUPT             = 13,
        NTFS_VOLUME_HIBERNATED          = 14,
        NTFS_VOLUME_UNCLEAN_UNMOUNT     = 15,
        NTFS_VOLUME_LOCKED              = 16,
        NTFS_VOLUME_RAID                = 17,
        NTFS_VOLUME_UNKNOWN_REASON      = 18,
        NTFS_VOLUME_NO_PRIVILEGE        = 19,
        NTFS_VOLUME_OUT_OF_MEMORY       = 20,
        NTFS_VOLUME_FUSE_ERROR          = 21,
        NTFS_VOLUME_INSECURE            = 22
} ntfs_volume_status;

typedef enum {
        NTFS_FILES_INTERIX,
        NTFS_FILES_WSL,
} ntfs_volume_special_files;

/**
 * enum ntfs_volume_state_bits -
 *
 * Defined bits for the state field in the ntfs_volume structure.
 */
typedef enum {
        NV_ReadOnly,            /* 1: Volume is read-only. */
        NV_CaseSensitive,       /* 1: Volume is mounted case-sensitive. */
        NV_LogFileEmpty,        /* 1: $logFile journal is empty. */
        NV_ShowSysFiles,        /* 1: Show NTFS metafiles. */
        NV_ShowHidFiles,        /* 1: Show files marked hidden. */
        NV_HideDotFiles,        /* 1: Set hidden flag on dot files */
        NV_Compression,         /* 1: allow compression */
        NV_NoFixupWarn,         /* 1: Do not log fixup errors */
        NV_FreeSpaceKnown,      /* 1: The free space is now known */
} ntfs_volume_state_bits;

#define  test_nvol_flag(nv, flag)        test_bit(NV_##flag, (nv)->state)
#define   set_nvol_flag(nv, flag)         set_bit(NV_##flag, (nv)->state)
#define clear_nvol_flag(nv, flag)       clear_bit(NV_##flag, (nv)->state)

#define NVolReadOnly(nv)                 test_nvol_flag(nv, ReadOnly)
#define NVolSetReadOnly(nv)               set_nvol_flag(nv, ReadOnly)
#define NVolClearReadOnly(nv)           clear_nvol_flag(nv, ReadOnly)

#define NVolCaseSensitive(nv)            test_nvol_flag(nv, CaseSensitive)
#define NVolSetCaseSensitive(nv)          set_nvol_flag(nv, CaseSensitive)
#define NVolClearCaseSensitive(nv)      clear_nvol_flag(nv, CaseSensitive)

#define NVolLogFileEmpty(nv)             test_nvol_flag(nv, LogFileEmpty)
#define NVolSetLogFileEmpty(nv)           set_nvol_flag(nv, LogFileEmpty)
#define NVolClearLogFileEmpty(nv)       clear_nvol_flag(nv, LogFileEmpty)

#define NVolShowSysFiles(nv)             test_nvol_flag(nv, ShowSysFiles)
#define NVolSetShowSysFiles(nv)           set_nvol_flag(nv, ShowSysFiles)
#define NVolClearShowSysFiles(nv)       clear_nvol_flag(nv, ShowSysFiles)

#define NVolShowHidFiles(nv)             test_nvol_flag(nv, ShowHidFiles)
#define NVolSetShowHidFiles(nv)           set_nvol_flag(nv, ShowHidFiles)
#define NVolClearShowHidFiles(nv)       clear_nvol_flag(nv, ShowHidFiles)

#define NVolHideDotFiles(nv)             test_nvol_flag(nv, HideDotFiles)
#define NVolSetHideDotFiles(nv)           set_nvol_flag(nv, HideDotFiles)
#define NVolClearHideDotFiles(nv)       clear_nvol_flag(nv, HideDotFiles)

#define NVolCompression(nv)              test_nvol_flag(nv, Compression)
#define NVolSetCompression(nv)            set_nvol_flag(nv, Compression)
#define NVolClearCompression(nv)        clear_nvol_flag(nv, Compression)

#define NVolNoFixupWarn(nv)              test_nvol_flag(nv, NoFixupWarn)
#define NVolSetNoFixupWarn(nv)            set_nvol_flag(nv, NoFixupWarn)
#define NVolClearNoFixupWarn(nv)        clear_nvol_flag(nv, NoFixupWarn)

#define NVolFreeSpaceKnown(nv)           test_nvol_flag(nv, FreeSpaceKnown)
#define NVolSetFreeSpaceKnown(nv)         set_nvol_flag(nv, FreeSpaceKnown)
#define NVolClearFreeSpaceKnown(nv)     clear_nvol_flag(nv, FreeSpaceKnown)

/*
 * NTFS version 1.1 and 1.2 are used by Windows NT4.
 * NTFS version 2.x is used by Windows 2000 Beta
 * NTFS version 3.0 is used by Windows 2000.
 * NTFS version 3.1 is used by Windows XP, 2003 and Vista.
 */

#define NTFS_V1_1(major, minor) ((major) == 1 && (minor) == 1)
#define NTFS_V1_2(major, minor) ((major) == 1 && (minor) == 2)
#define NTFS_V2_X(major, minor) ((major) == 2)
#define NTFS_V3_0(major, minor) ((major) == 3 && (minor) == 0)
#define NTFS_V3_1(major, minor) ((major) == 3 && (minor) == 1)

#define NTFS_BUF_SIZE 8192

/**
 * struct _ntfs_volume - structure describing an open volume in memory.
 */
struct _ntfs_volume {
        union {
                struct ntfs_device *dev;        /* NTFS device associated with
                                                   the volume. */
                void *sb;       /* For kernel porting compatibility. */
        };
        char *vol_name;         /* Name of the volume. */
        unsigned long state;    /* NTFS specific flags describing this volume.
                                   See ntfs_volume_state_bits above. */

        ntfs_inode *vol_ni;     /* ntfs_inode structure for FILE_Volume. */
        u8 major_ver;           /* Ntfs major version of volume. */
        u8 minor_ver;           /* Ntfs minor version of volume. */
        le16 flags;             /* Bit array of VOLUME_* flags. */

        u16 sector_size;        /* Byte size of a sector. */
        u8 sector_size_bits;    /* Log(2) of the byte size of a sector. */
        u32 cluster_size;       /* Byte size of a cluster. */
        u32 mft_record_size;    /* Byte size of a mft record. */
        u32 indx_record_size;   /* Byte size of a INDX record. */
        u8 cluster_size_bits;   /* Log(2) of the byte size of a cluster. */
        u8 mft_record_size_bits;/* Log(2) of the byte size of a mft record. */
        u8 indx_record_size_bits;/* Log(2) of the byte size of a INDX record. */

        /* Variables used by the cluster and mft allocators. */
        u8 mft_zone_multiplier; /* Initial mft zone multiplier. */
        u8 full_zones;          /* cluster zones which are full */
        s64 mft_data_pos;       /* Mft record number at which to allocate the
                                   next mft record. */
        LCN mft_zone_start;     /* First cluster of the mft zone. */
        LCN mft_zone_end;       /* First cluster beyond the mft zone. */
        LCN mft_zone_pos;       /* Current position in the mft zone. */
        LCN data1_zone_pos;     /* Current position in the first data zone. */
        LCN data2_zone_pos;     /* Current position in the second data zone. */

        s64 nr_clusters;        /* Volume size in clusters, hence also the
                                   number of bits in lcn_bitmap. */
        ntfs_inode *lcnbmp_ni;  /* ntfs_inode structure for FILE_Bitmap. */
        ntfs_attr *lcnbmp_na;   /* ntfs_attr structure for the data attribute
                                   of FILE_Bitmap. Each bit represents a
                                   cluster on the volume, bit 0 representing
                                   lcn 0 and so on. A set bit means that the
                                   cluster and vice versa. */

        LCN mft_lcn;            /* Logical cluster number of the data attribute
                                   for FILE_MFT. */
        ntfs_inode *mft_ni;     /* ntfs_inode structure for FILE_MFT. */
        ntfs_attr *mft_na;      /* ntfs_attr structure for the data attribute
                                   of FILE_MFT. */
        ntfs_attr *mftbmp_na;   /* ntfs_attr structure for the bitmap attribute
                                   of FILE_MFT. Each bit represents an mft
                                   record in the $DATA attribute, bit 0
                                   representing mft record 0 and so on. A set
                                   bit means that the mft record is in use and
                                   vice versa. */

        ntfs_inode *secure_ni;  /* ntfs_inode structure for FILE $Secure */
        ntfs_index_context *secure_xsii; /* index for using $Secure:$SII */
        ntfs_index_context *secure_xsdh; /* index for using $Secure:$SDH */
        int secure_reentry;  /* check for non-rentries */
        unsigned int secure_flags;  /* flags, see security.h for values */

        int mftmirr_size;       /* Size of the FILE_MFTMirr in mft records. */
        LCN mftmirr_lcn;        /* Logical cluster number of the data attribute
                                   for FILE_MFTMirr. */
        ntfs_inode *mftmirr_ni; /* ntfs_inode structure for FILE_MFTMirr. */
        ntfs_attr *mftmirr_na;  /* ntfs_attr structure for the data attribute
                                   of FILE_MFTMirr. */

        ntfschar *upcase;       /* Upper case equivalents of all 65536 2-byte
                                   Unicode characters. Obtained from
                                   FILE_UpCase. */
        u32 upcase_len;         /* Length in Unicode characters of the upcase
                                   table. */
        ntfschar *locase;       /* Lower case equivalents of all 65536 2-byte
                                   Unicode characters. Only if option
                                   case_ignore is set. */

        ATTR_DEF *attrdef;      /* Attribute definitions. Obtained from
                                   FILE_AttrDef. */
        s32 attrdef_len;        /* Size of the attribute definition table in
                                   bytes. */

        s64 free_clusters;      /* Track the number of free clusters which
                                   greatly improves statfs() performance */
        s64 free_mft_records;   /* Same for free mft records (see above) */
        BOOL efs_raw;           /* volume is mounted for raw access to
                                   efs-encrypted files */
        ntfs_volume_special_files special_files; /* Implementation of special files */
        const char *abs_mnt_point; /* Mount point */
#ifdef XATTR_MAPPINGS
        struct XATTRMAPPING *xattr_mapping;
#endif /* XATTR_MAPPINGS */
#if CACHE_INODE_SIZE
        struct CACHE_HEADER *xinode_cache;
#endif
#if CACHE_NIDATA_SIZE
        struct CACHE_HEADER *nidata_cache;
#endif
#if CACHE_LOOKUP_SIZE
        struct CACHE_HEADER *lookup_cache;
#endif
#if CACHE_SECURID_SIZE
        struct CACHE_HEADER *securid_cache;
#endif
#if CACHE_LEGACY_SIZE
        struct CACHE_HEADER *legacy_cache;
#endif
};

extern const char *ntfs_home;

extern ntfs_volume *ntfs_volume_alloc(void);

extern ntfs_volume *ntfs_volume_startup(struct ntfs_device *dev,
                ntfs_mount_flags flags);

extern ntfs_volume *ntfs_device_mount(struct ntfs_device *dev,
                ntfs_mount_flags flags);

extern ntfs_volume *ntfs_mount(const char *name, ntfs_mount_flags flags);
extern int ntfs_umount(ntfs_volume *vol, const BOOL force);

extern int ntfs_version_is_supported(ntfs_volume *vol);
extern int ntfs_volume_check_hiberfile(ntfs_volume *vol, int verbose);
extern int ntfs_logfile_reset(ntfs_volume *vol);

extern int ntfs_volume_write_flags(ntfs_volume *vol, const le16 flags);

extern int ntfs_volume_error(int err);
extern void ntfs_mount_error(const char *vol, const char *mntpoint, int err);

extern int ntfs_volume_get_free_space(ntfs_volume *vol);
extern int ntfs_volume_rename(ntfs_volume *vol, const ntfschar *label,
                int label_len);

extern int ntfs_set_shown_files(ntfs_volume *vol,
                BOOL show_sys_files, BOOL show_hid_files, BOOL hide_dot_files);
extern int ntfs_set_locale(void);
extern int ntfs_set_ignore_case(ntfs_volume *vol);

#endif /* defined _NTFS_VOLUME_H */