zftape.h
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:2k
- #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