123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- #ifndef _ZFTAPE_RW_H
- #define _ZFTAPE_RW_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/ftape/zftape/zftape-rw.h,v $
- * $Revision: 1.2 $
- * $Date: 1997/10/05 19:19:09 $
- *
- * This file contains the definitions for the read and write
- * functions for the QIC-117 floppy-tape driver for Linux.
- *
- */
- #include <linux/config.h> /* for CONFIG_ZFT_DFLT_BLK_SZ */
- #include "../zftape/zftape-buffers.h"
- #define SEGMENTS_PER_TAPE (ft_segments_per_track * ft_tracks_per_tape)
- /* QIC-113 Rev. G says that `a maximum of 63488 raw bytes may be
- * compressed into a single frame'.
- * Maybe we should stick to 32kb to make it more `beautiful'
- */
- #define ZFT_MAX_BLK_SZ (62*1024) /* bytes */
- #if !defined(CONFIG_ZFT_DFLT_BLK_SZ)
- # define CONFIG_ZFT_DFLT_BLK_SZ (10*1024) /* bytes, default of gnu tar */
- #elif CONFIG_ZFT_DFLT_BLK_SZ == 0
- # undef CONFIG_ZFT_DFLT_BLK_SZ
- # define CONFIG_ZFT_DFLT_BLK_SZ 1
- #elif (CONFIG_ZFT_DFLT_BLK_SZ % 1024) != 0
- # error CONFIG_ZFT_DFLT_BLK_SZ must be 1 or a multiple of 1024
- #endif
- /* The *optional* compression routines need some overhead per tape
- * block for their purposes. Instead of asking the actual compression
- * implementation how much it needs, we restrict this overhead to be
- * maximal of ZFT_CMPT_OVERHEAD size. We need this for EOT
- * conditions. The tape is assumed to be logical at EOT when the
- * distance from the physical EOT is less than
- * one tape block + ZFT_CMPR_OVERHEAD
- */
- #define ZFT_CMPR_OVERHEAD 16 /* bytes */
- typedef enum
- {
- zft_idle = 0,
- zft_reading,
- zft_writing,
- } zft_status_enum;
- typedef struct /* all values measured in bytes */
- {
- int seg_pos; /* segment currently positioned at */
- int seg_byte_pos; /* offset in current segment */
- __s64 tape_pos; /* real offset from BOT */
- __s64 volume_pos; /* pos. in uncompressed data stream in
- * current volume
- */
- } zft_position;
- extern zft_position zft_pos;
- extern __u8 *zft_deblock_buf;
- extern __u8 *zft_hseg_buf;
- extern int zft_deblock_segment;
- extern zft_status_enum zft_io_state;
- extern int zft_header_changed;
- extern int zft_qic113; /* conform to old specs. and old zftape */
- extern int zft_use_compression;
- extern unsigned int zft_blk_sz;
- extern __s64 zft_capacity;
- extern unsigned int zft_written_segments;
- extern int zft_label_changed;
- /* zftape-rw.c exported functions
- */
- extern unsigned int zft_get_seg_sz(unsigned int segment);
- extern void zft_set_flags(unsigned int minor_unit);
- extern int zft_calc_seg_byte_coord(int *seg_byte_pos, __s64 tape_pos);
- extern __s64 zft_calc_tape_pos(int segment);
- extern __s64 zft_get_capacity(void);
- extern void zft_update_label(__u8 *buffer);
- extern int zft_erase(void);
- extern int zft_verify_write_segments(unsigned int segment,
- __u8 *data, size_t size, __u8 *buffer);
- extern unsigned int zft_get_time(void);
- #endif /* _ZFTAPE_RW_H */
|