88 lines
2.3 KiB
C
88 lines
2.3 KiB
C
|
#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
|