Bump GPLv2+ to GPLv3+ for some files, clarify BSD 2-clause. Everything else stays under GPLv3+. New Linking Exception exempts resulting executables from LGPLv3 section 4. Add CONTRIBUTORS file to keep track of licensing. Remove 'Copyright Red Hat Inc' comments. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
		
			
				
	
	
		
			140 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/* mtinfo.h: Defininitions for the Cygwin tape driver class.
 | 
						|
 | 
						|
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. */
 | 
						|
 | 
						|
/* 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,
 | 
						|
  async_write_pending
 | 
						|
};
 | 
						|
 | 
						|
enum lock_state
 | 
						|
{
 | 
						|
  unlocked,
 | 
						|
  lock_error,
 | 
						|
  auto_locked,
 | 
						|
  locked
 | 
						|
};
 | 
						|
 | 
						|
/* Partition specific information */
 | 
						|
class mtinfo_part
 | 
						|
{
 | 
						|
public:
 | 
						|
  int64_t block;	/* logical block no */
 | 
						|
  int64_t fblock;	/* relative block no */
 | 
						|
  int32_t file;		/* current file no */
 | 
						|
  bool smark;		/* At setmark? */
 | 
						|
  eom_val emark;	/* "end-of"-mark */
 | 
						|
 | 
						|
  void initialize (int64_t nblock = -1);
 | 
						|
};
 | 
						|
 | 
						|
class mtinfo_drive
 | 
						|
{
 | 
						|
  int drive;
 | 
						|
  int lasterr;
 | 
						|
  int32_t partition;
 | 
						|
  int64_t block;
 | 
						|
  dirty_state dirty;
 | 
						|
  lock_state lock;
 | 
						|
  TAPE_GET_DRIVE_PARAMETERS _dp;
 | 
						|
  TAPE_GET_MEDIA_PARAMETERS _mp;
 | 
						|
  /* sizeof(OVERLAPPED) == 20 on 32 bit, 32 on 64 bit.  A drive is always
 | 
						|
     opened exclusively by a single process, though, so instead of the
 | 
						|
     OVERLAPPED structure, we just keep track of the pointer to the
 | 
						|
     OVERLAPPED structure in the application's fhandler. */
 | 
						|
  LPOVERLAPPED ov;
 | 
						|
  struct status_flags
 | 
						|
  {
 | 
						|
    unsigned buffer_writes : 1;
 | 
						|
    unsigned async_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", str, 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, int32_t *ppartition = NULL, int64_t *pblock = NULL);
 | 
						|
  int _set_pos (HANDLE mt, int mode, int64_t count, int partition, BOOL dont_wait);
 | 
						|
  int create_partitions (HANDLE mt, int32_t count);
 | 
						|
  int set_partition (HANDLE mt, int32_t 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, int32_t count);
 | 
						|
  int set_blocksize (HANDLE mt, DWORD count);
 | 
						|
  int get_status (HANDLE mt, struct mtget *get);
 | 
						|
  int set_options (HANDLE mt, int32_t options);
 | 
						|
  int async_wait (HANDLE mt, DWORD *bytes_written);
 | 
						|
 | 
						|
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, LPOVERLAPPED pov, void *ptr, size_t &ulen);
 | 
						|
  int write (HANDLE mt, LPOVERLAPPED pov, const void *ptr, size_t &len);
 | 
						|
  int ioctl (HANDLE mt, unsigned int cmd, void *buf);
 | 
						|
  int set_pos (HANDLE mt, int mode, int64_t count, bool sfm_func);
 | 
						|
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, buffer_writes)
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, async_writes)
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, two_fm)
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, fast_eom)
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, auto_lock)
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, sysv)
 | 
						|
  IMPLEMENT_STATUS_FLAG (bool, nowait)
 | 
						|
 | 
						|
  PTAPE_GET_DRIVE_PARAMETERS dp () { return &_dp; }
 | 
						|
  PTAPE_GET_MEDIA_PARAMETERS mp () { return &_mp; }
 | 
						|
  mtinfo_part *part (int num) { return &_part[num]; }
 | 
						|
};
 | 
						|
 | 
						|
class mtinfo
 | 
						|
{
 | 
						|
  mtinfo_drive _drive[MAX_DRIVE_NUM];
 | 
						|
 | 
						|
public:
 | 
						|
  void initialize ();
 | 
						|
  mtinfo_drive *drive (int num) { return &_drive[num]; }
 | 
						|
};
 |