56551a9bfb
tty_min, mtinfo and fs_info thoroughout. * fhandler.h: Redefine all set_close_on_exec methods to take a bool argument. (enum conn_state): Rename from connect_state. (class fhandler_base): Rename some status flags to align with accessor method names. Drop encoded flag entirely. Unify status accessor methods. Const'ify all read accessor methods. (class fhandler_socket): Ditto. (class fhandler_dev_raw): Ditto. * fhandler_disk_file.cc (fhandler_base::fstat_fs): Use fs.fs_is_fat() instead of evaluating FATness of file system here. (fhandler_disk_file::opendir): Drop call to set_encoded(). (fhandler_disk_file::readdir): Use pc.isencoded() directly. * mtinfo.h (class mtinfo_drive): Const'ify all read accessor methods. * path.cc (fsinfo_cnt): Add. (fs_info::update): Accomodate class changes. Evaluate file system name specific flags right here. Add thread safety for reading and writing global fsinfo array. * path.h (enum path_types): Drop values for flags kept in fs already. (struct fs_info): Move status informatin into private struct type status_flags. Add accessor methods. Remove path and file system name string arrays in favor of status bits. (class path_conv): Use new fs_info status information where appropriate. (path_conf::fs_has_ea): Rename from fs_fast_ea. (path_conf::fs_has_acls): New method. (path_conf::root_dir): Remove. (path_conf::volname): Remove. * syscalls (statfs): Evaluate root dir locally. * tty.h (class tty_min): Unify status accessor methods. Const'ify all read accessor methods.
148 lines
3.8 KiB
C++
148 lines
3.8 KiB
C++
/* mtinfo.h: Defininitions for the Cygwin tape driver class.
|
|
|
|
Copyright 2004 Red Hat, Inc.
|
|
|
|
This file is part of Cygwin.
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
details. */
|
|
|
|
#define MTINFO_MAGIC 0x179b2af0
|
|
#define MTINFO_VERSION 1
|
|
|
|
/* Maximum number of supported partitions per drive. */
|
|
#define MAX_PARTITION_NUM 64
|
|
/* Maximum number of supported drives. */
|
|
#define MAX_DRIVE_NUM 8
|
|
|
|
/* Values for bookkeeping of the tape position relative to filemarks
|
|
and eod/eom. */
|
|
enum eom_val
|
|
{
|
|
no_eof,
|
|
eof_hit,
|
|
eof,
|
|
eod_hit,
|
|
eod,
|
|
eom_hit,
|
|
eom
|
|
};
|
|
|
|
enum dirty_state
|
|
{
|
|
clean,
|
|
has_read,
|
|
has_written
|
|
};
|
|
|
|
enum lock_state
|
|
{
|
|
unlocked,
|
|
lock_error,
|
|
auto_locked,
|
|
locked
|
|
};
|
|
|
|
/* Partition specific information */
|
|
class mtinfo_part
|
|
{
|
|
public:
|
|
long block; /* logical block no */
|
|
long file; /* current file no */
|
|
long fblock; /* relative block no */
|
|
bool smark; /* At setmark? */
|
|
eom_val emark; /* "end-of"-mark */
|
|
|
|
void initialize (long nblock = -1);
|
|
};
|
|
|
|
class mtinfo_drive
|
|
{
|
|
int drive;
|
|
int lasterr;
|
|
long partition;
|
|
long block;
|
|
dirty_state dirty;
|
|
lock_state lock;
|
|
TAPE_GET_DRIVE_PARAMETERS _dp;
|
|
TAPE_GET_MEDIA_PARAMETERS _mp;
|
|
struct status_flags
|
|
{
|
|
unsigned buffer_writes : 1;
|
|
unsigned two_fm : 1;
|
|
unsigned fast_eom : 1;
|
|
unsigned auto_lock : 1;
|
|
unsigned sysv : 1;
|
|
unsigned nowait : 1;
|
|
} status;
|
|
mtinfo_part _part[MAX_PARTITION_NUM];
|
|
|
|
inline int error (const char *str)
|
|
{
|
|
if (lasterr)
|
|
debug_printf ("%s: Win32 error %d", lasterr);
|
|
return lasterr;
|
|
}
|
|
inline bool get_feature (DWORD parm)
|
|
{
|
|
return ((parm & TAPE_DRIVE_HIGH_FEATURES)
|
|
? ((_dp.FeaturesHigh & parm) != 0)
|
|
: ((_dp.FeaturesLow & parm) != 0));
|
|
}
|
|
int get_pos (HANDLE mt, long *ppartition = NULL, long *pblock = NULL);
|
|
int _set_pos (HANDLE mt, int mode, long count, int partition);
|
|
int create_partitions (HANDLE mt, long count);
|
|
int set_partition (HANDLE mt, long count);
|
|
int write_marks (HANDLE mt, int marktype, DWORD count);
|
|
int erase (HANDLE mt, int mode);
|
|
int prepare (HANDLE mt, int action, bool is_auto = false);
|
|
int set_compression (HANDLE mt, long count);
|
|
int set_blocksize (HANDLE mt, long count);
|
|
int get_status (HANDLE mt, struct mtget *get);
|
|
int set_options (HANDLE mt, long options);
|
|
|
|
public:
|
|
void initialize (int num, bool first_time);
|
|
int get_dp (HANDLE mt);
|
|
int get_mp (HANDLE mt);
|
|
int open (HANDLE mt);
|
|
int close (HANDLE mt, bool rewind);
|
|
int read (HANDLE mt, void *ptr, size_t &ulen);
|
|
int write (HANDLE mt, const void *ptr, size_t &len);
|
|
int ioctl (HANDLE mt, unsigned int cmd, void *buf);
|
|
int set_pos (HANDLE mt, int mode, long count, bool sfm_func);
|
|
|
|
bool buffer_writes () const { return status.buffer_writes; }
|
|
void buffer_writes (bool b) { status.buffer_writes = b; }
|
|
bool two_fm () const { return status.two_fm; }
|
|
void two_fm (bool b) { status.two_fm = b; }
|
|
bool fast_eom () const { return status.fast_eom; }
|
|
void fast_eom (bool b) { status.fast_eom = b; }
|
|
bool auto_lock () const { return status.auto_lock; }
|
|
void auto_lock (bool b) { status.auto_lock = b; }
|
|
bool sysv () const { return status.sysv; }
|
|
void sysv (bool b) { status.sysv = b; }
|
|
bool nowait () const { return status.nowait; }
|
|
void nowait (bool b) { status.nowait = b; }
|
|
PTAPE_GET_DRIVE_PARAMETERS dp (void) { return &_dp; }
|
|
PTAPE_GET_MEDIA_PARAMETERS mp (void) { return &_mp; }
|
|
mtinfo_part *part (int num) { return &_part[num]; }
|
|
};
|
|
|
|
class mtinfo
|
|
{
|
|
DWORD magic;
|
|
DWORD version;
|
|
mtinfo_drive _drive[MAX_DRIVE_NUM];
|
|
|
|
public:
|
|
void initialize (void);
|
|
mtinfo_drive *drive (int num) { return &_drive[num]; }
|
|
};
|
|
|
|
extern HANDLE mt_h;
|
|
extern mtinfo *mt;
|
|
|
|
extern void __stdcall mtinfo_init ();
|