blob: 14c07f0865755f101fd7d8191ea0437527411806 [file] [log] [blame]
#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 */