diff options
-rw-r--r-- | sbin/i386/ft/ft.8 | 22 | ||||
-rw-r--r-- | sbin/i386/ft/ft.c | 88 | ||||
-rw-r--r-- | sbin/i386/ft/ftecc.c | 6 |
3 files changed, 67 insertions, 49 deletions
diff --git a/sbin/i386/ft/ft.8 b/sbin/i386/ft/ft.8 index 18449de..986bb92 100644 --- a/sbin/i386/ft/ft.8 +++ b/sbin/i386/ft/ft.8 @@ -10,7 +10,7 @@ .\" notice, this list of conditions and the following disclaimer in the .\" documentation and/or other materials provided with the distribution. .\" 3. All advertising materials mentioning features or use of this software -.\" must display the following acknowledgement: +.\" must display the following acknowledgment: .\" This product includes software developed by the University of .\" California, Berkeley and its contributors. .\" 4. Neither the name of the University nor the names of its contributors @@ -30,6 +30,7 @@ .\" SUCH DAMAGE. .\" .\" @(#)ft.8 +.\" $Id$ .\" .Dd February 7, 1994 .Dt FT 8 @@ -40,15 +41,30 @@ .Sh SYNOPSIS .Nm ft .Op Fl f Ar tape +.Op Fl r .Op Ar description .Sh DESCRIPTION The -.Nm ft +.Nm command allows multi-volume dump, extract, and view of tape labels, for any pre-formatted QIC-40/80 tapes. It is totally system dependent, and has nothing to do with the QIC standards. .Pp -.Nm ft +The following options are available: +.Bl -tag -width indent +.It Fl f Ar tape +Read or write the specified +.Ar tape +(default is +.Pa /dev/rft0 +unless the environment variable +.Ev TAPE +is set). +.It Fl r +Do retension tape. +.El +.Pp +.Nm Ft is used primarily as a filter for tape i/o. For example, to save and compress the .Pa /usr diff --git a/sbin/i386/ft/ft.c b/sbin/i386/ft/ft.c index 3df36e5..41591a4 100644 --- a/sbin/i386/ft/ft.c +++ b/sbin/i386/ft/ft.c @@ -31,14 +31,21 @@ * 09/02/93 v0.2 pl01 * Initial revision. * - * usage: ft [ -f tape ] [ description ] + * usage: ft [ -f tape ] [ -r ] [ description ] */ +#ifndef lint +static const char rcsid[] = + "$Id$"; +#endif /* not lint */ + +#include <err.h> +#include <fcntl.h> #include <stdio.h> #include <stdlib.h> #include <string.h> -#include <signal.h> #include <time.h> +#include <unistd.h> #include <sys/ftape.h> #define DEFQIC "/dev/rft0" @@ -73,7 +80,7 @@ int doretension = 0; /* TRUE if we should retension tape */ void usage(void) { - fprintf(stderr, "usage: ft [ -r ] [ -f device ] [ \"description\" ]\n"); + fprintf(stderr, "usage: ft [-f device] [-r] [\"description\"]\n"); exit(1); } @@ -84,35 +91,35 @@ usage(void) int check_stat(int fd, int wr) { - int r, s; + int s; int sawit = 0; /* get tape status */ if (ioctl(fd, QIOSTATUS, &s) < 0) { - fprintf(stderr, "could not get drive status\n"); + warnx("could not get drive status"); return(1); } /* wait for the tape drive to become ready */ while ((s & QS_READY) == 0) { if (!sawit) { - fprintf(stderr, "waiting for drive to become ready...\n"); + warnx("waiting for drive to become ready"); sawit = 1; } sleep(2); if (ioctl(fd, QIOSTATUS, &s) < 0) { - fprintf(stderr, "could not get drive status\n"); + warnx("could not get drive status"); return(1); } } if ((s & QS_FMTOK) == 0) { - fprintf(stderr, "tape is not formatted\n"); + warnx("tape is not formatted"); return(2); } if (wr && (s & QS_RDONLY) != 0) { - fprintf(stderr, "tape is write protected\n"); + warnx("tape is write protected"); return(3); } @@ -186,12 +193,12 @@ char *qstr(char *str, int nchar) int get_header(int fd) { - int r, sn, bytes; + int r, sn; QIC_Segment s; int gothdr = 0; if (ioctl(fd, QIOGEOM, &geo) < 0) { - fprintf(stderr, "couldn't determine tape geometry\n"); + warnx("couldn't determine tape geometry"); return(1); } @@ -208,7 +215,7 @@ get_header(int fd) if (hsn >= 0) { dhsn = sn; if (!r && !gothdr) { - fprintf(stderr, "using secondary header\n"); + warnx("using secondary header"); bcopy(s.sg_data, hbuff, QCV_SEGSIZE); gothdr = 1; } @@ -219,13 +226,13 @@ get_header(int fd) bcopy(s.sg_data, hbuff, QCV_SEGSIZE); gothdr = 1; } else { - fprintf(stderr, "too many errors in primary header\n"); + warnx("too many errors in primary header"); } } } if (!gothdr) { - fprintf(stderr, "couldn't read header segment\n"); + warnx("couldn't read header segment"); ioctl(fd, QIOREWIND); return(1); } @@ -237,16 +244,14 @@ get_header(int fd) /* * Open /dev/tty and ask for next volume. */ +void ask_vol(int vn) { - FILE *inp; int fd; char c; - if ((fd = open("/dev/tty", 2)) < 0) { - fprintf(stderr, "argh!! can't open /dev/tty\n"); - exit(1); - } + if ((fd = open("/dev/tty", 2)) < 0) + errx(1, "argh!! can't open /dev/tty"); fprintf(stderr, "Insert ftfilt volume %02d and press enter:", vn); read(fd, &c, 1); @@ -273,7 +278,7 @@ do_getname(void) void do_read(void) { - int sno, vno, sbytes, r, eccfails; + int sno, vno, sbytes, eccfails; long curpos; char *hname; QIC_Segment s; @@ -330,13 +335,12 @@ do_read(void) if (check_parity(s.sg_data, s.sg_badmap, s.sg_crcmap)) { if (++eccfails <= 5) { - fprintf(stderr, - "ft: retry %d at segment %d byte %ld\n", + warnx("retry %d at segment %d byte %ld", eccfails, sno, curpos); continue; } else - fprintf(stderr, - "ft: *** ecc failure in segment %d at byte %ld\n", + warnx( + "*** ecc failure in segment %d at byte %ld", sno, curpos); } if (tvsize < sbytes) sbytes = tvsize; @@ -360,7 +364,7 @@ void do_write(void) { int sno, vno, amt, sbytes; - int c, maxseg, r; + int maxseg, r; ULONG qnow; QIC_Segment s; char tmpstr[80]; @@ -414,11 +418,9 @@ do_write(void) if (amt < sbytes) bzero(&s.sg_data[amt], sbytes - amt); r = set_parity(s.sg_data, s.sg_badmap); - if (r) fprintf(stderr, "** warning: ecc problem !!\n"); - if (ioctl(tfd, QIOWRITE, &s) < 0) { - perror("QIOWRITE"); - exit(1); - } + if (r) warnx("** warning: ecc problem !!"); + if (ioctl(tfd, QIOWRITE, &s) < 0) + err(1, "QIOWRITE"); tvsize += amt; } } @@ -439,11 +441,9 @@ do_write(void) s.sg_badmap = 0; s.sg_data = (UCHAR *)hbuff; r = set_parity(s.sg_data, s.sg_badmap); - if (r) fprintf(stderr, "** warning: header ecc problem !!\n"); - if (ioctl(tfd, QIOWRITE, &s) < 0) { - perror("QIOWRITE"); - exit(1); - } + if (r) warnx("** warning: header ecc problem !!"); + if (ioctl(tfd, QIOWRITE, &s) < 0) + err(1, "QIOWRITE"); } if (dhsn >= 0) { s.sg_trk = dhsn / geo.g_segtrk; @@ -451,11 +451,9 @@ do_write(void) s.sg_badmap = 0; s.sg_data = (UCHAR *)hbuff; r = set_parity(s.sg_data, s.sg_badmap); - if (r) fprintf(stderr, "** warning: duphdr ecc problem !!\n"); - if (ioctl(tfd, QIOWRITE, &s) < 0) { - perror("QIOWRITE"); - exit(1); - } + if (r) warnx("** warning: duphdr ecc problem !!"); + if (ioctl(tfd, QIOWRITE, &s) < 0) + err(1, "QIOWRITE"); } ioctl(tfd, QIOREWIND); if (tvlast) break; @@ -467,10 +465,10 @@ do_write(void) /* * Entry. */ -void +int main(int argc, char *argv[]) { - int r, s, i; + int i; char *tape, *getenv(); @@ -500,10 +498,8 @@ main(int argc, char *argv[]) } /* Open the tape device */ - if ((tfd = open(tape, 2)) < 0) { - perror(tape); - exit(1); - } + if ((tfd = open(tape, 2)) < 0) + err(1, "%s", tape); if (!isatty(0)) do_write(); diff --git a/sbin/i386/ft/ftecc.c b/sbin/i386/ft/ftecc.c index 95de073..abc6d43 100644 --- a/sbin/i386/ft/ftecc.c +++ b/sbin/i386/ft/ftecc.c @@ -29,6 +29,12 @@ * Modified slightly to fit with my driver. Based entirely upon David * L. Brown's package. */ + +#ifndef lint +static const char rcsid[] = + "$Id$"; +#endif /* not lint */ + #include <sys/ftape.h> /* Inverse matrix */ |