#ifndef _ZFTAPE_H
#define _ZFTAPE_H

/*
 * Copyright (C) 1996, 1997 Claus-Justus Heine.

 This program 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, or (at your option)
 any later version.

 This program 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; see the file COPYING.  If not, write to
 the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.

 *
 * $Source: /homes/cvs/ftape-stacked/include/linux/zftape.h,v $
 * $Revision: 1.12 $
 * $Date: 1997/10/21 11:02:37 $
 *
 *      Special ioctl and other global info for the zftape VFS
 *      interface for the QIC-40/80/3010/3020 floppy-tape driver for
 *      Linux.
 */

#define ZFTAPE_VERSION  "zftape for " FTAPE_VERSION

#include <linux/ftape.h>

#define ZFTAPE_LABEL       "Ftape - The Linux Floppy Tape Project!"

/* Bits of the minor device number that control the operation mode */
#define ZFT_Q80_MODE		(1 << 3)
#define ZFT_ZIP_MODE		(1 << 4)
#define ZFT_RAW_MODE		(1 << 5)
#define ZFT_MINOR_OP_MASK	(ZFT_Q80_MODE	| 	\
				 ZFT_ZIP_MODE	| 	\
				 ZFT_RAW_MODE)
#define ZFT_MINOR_MASK		(FTAPE_SEL_MASK		|	\
				 ZFT_MINOR_OP_MASK	|	\
				 FTAPE_NO_REWIND)

#ifdef ZFT_OBSOLETE
struct mtblksz {
	unsigned int mt_blksz;
};
#define MTIOC_ZFTAPE_GETBLKSZ _IOR('m', 104, struct mtblksz)
#endif

#ifdef __KERNEL__

extern int zft_init(void);

static inline __s64 zft_div_blksz(__s64 value, __u32 blk_sz)
{
	if (blk_sz == 1) {
		return value;
	} else {
		return (__s64)(((__u32)(value >> 10) + (blk_sz >> 10) - 1) 
			       / (blk_sz >> 10));
	} 
}

static inline __s64 zft_mul_blksz(__s64 value, __u32 blk_sz)
{
	if (blk_sz == 1) {
		return value;
	} else {
		/*  if blk_sz != 1, then it is a multiple of 1024. In
		 *  this case, `value' will also fit into 32 bits.
		 * 
		 *  Actually, this limits the capacity to 42
		 *  bits. This is (2^32)*1024, roughly a thousand
		 *  times 2GB, or 3 Terabytes. Hopefully this is enough
		 */
		return(__s64)(((__u32)(value)*(blk_sz>>10))<<10);
	}
}

#endif

#endif