| #ifndef _FTAPE_ECC_H_ |
| #define _FTAPE_ECC_H_ |
| |
| /* |
| * Copyright (C) 1993 Ning and David Mosberger. |
| * Original: |
| * Copyright (C) 1993 Bas Laarhoven. |
| * Copyright (C) 1992 David L. Brown, Jr. |
| |
| 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/lowlevel/ftape-ecc.h,v $ |
| * $Revision: 1.2 $ |
| * $Date: 1997/10/05 19:18:11 $ |
| * |
| * This file contains the definitions for the |
| * Reed-Solomon error correction code |
| * for the QIC-40/80 tape streamer device driver. |
| */ |
| |
| #include "../lowlevel/ftape-bsm.h" |
| |
| #define BAD_CLEAR(entry) ((entry)=0) |
| #define BAD_SET(entry,sector) ((entry)|=(1<<(sector))) |
| #define BAD_CHECK(entry,sector) ((entry)&(1<<(sector))) |
| |
| /* |
| * Return values for ecc_correct_data: |
| */ |
| enum { |
| ECC_OK, /* Data was correct. */ |
| ECC_CORRECTED, /* Correctable error in data. */ |
| ECC_FAILED, /* Could not correct data. */ |
| }; |
| |
| /* |
| * Representation of an in memory segment. MARKED_BAD lists the |
| * sectors that were marked bad during formatting. If the N-th sector |
| * in a segment is marked bad, bit 1<<N will be set in MARKED_BAD. |
| * The sectors should be read in from the disk and packed, as if the |
| * bad sectors were not there, and the segment just contained fewer |
| * sectors. READ_SECTORS is a bitmap of errors encountered while |
| * reading the data. These offsets are relative to the packed data. |
| * BLOCKS is a count of the sectors not marked bad. This is just to |
| * prevent having to count the zero bits in MARKED_BAD each time this |
| * is needed. DATA is the actual sector packed data from (or to) the |
| * tape. |
| */ |
| struct memory_segment { |
| SectorMap marked_bad; |
| SectorMap read_bad; |
| int blocks; |
| __u8 *data; |
| SectorMap corrected; |
| }; |
| |
| /* |
| * ecc.c defined global variables: |
| */ |
| #ifdef TEST |
| extern int ftape_ecc_tracing; |
| #endif |
| |
| /* |
| * ecc.c defined global functions: |
| */ |
| extern int ftape_ecc_correct_data(struct memory_segment *data); |
| extern int ftape_ecc_set_segment_parity(struct memory_segment *data); |
| |
| #endif /* _FTAPE_ECC_H_ */ |