#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 #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