diff options
author | green <green@FreeBSD.org> | 1999-08-27 16:36:46 +0000 |
---|---|---|
committer | green <green@FreeBSD.org> | 1999-08-27 16:36:46 +0000 |
commit | 1b913741fc989b87e05d87474114dad1d6572006 (patch) | |
tree | 95fdea19fde95436a1be803a933577f59b3276c7 | |
parent | 080e369bf20e9a57db62ba812782c46f7290d657 (diff) | |
download | FreeBSD-src-1b913741fc989b87e05d87474114dad1d6572006.zip FreeBSD-src-1b913741fc989b87e05d87474114dad1d6572006.tar.gz |
Use FIODTYPE to unbogosify much of the file type checking in dd.
-rw-r--r-- | bin/dd/dd.c | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/bin/dd/dd.c b/bin/dd/dd.c index b6e0ebb..ece32c4 100644 --- a/bin/dd/dd.c +++ b/bin/dd/dd.c @@ -46,12 +46,14 @@ static char const copyright[] = static char sccsid[] = "@(#)dd.c 8.5 (Berkeley) 4/2/94"; #endif static const char rcsid[] = - "$Id: dd.c,v 1.18 1999/06/20 14:58:51 green Exp $"; + "$Id: dd.c,v 1.19 1999/07/13 18:44:56 green Exp $"; #endif /* not lint */ #include <sys/param.h> #include <sys/stat.h> +#include <sys/conf.h> #include <sys/diskslice.h> +#include <sys/filio.h> #include <sys/mtio.h> #include <ctype.h> @@ -224,19 +226,22 @@ static void getfdtype(io) IO *io; { - struct mtget mt; - struct diskslices ds; struct stat sb; + int type; if (fstat(io->fd, &sb)) err(1, "%s", io->name); - if ((S_ISCHR(sb.st_mode) || S_ISBLK(sb.st_mode)) && - ioctl(io->fd, DIOCGSLICEINFO, &ds) != -1) - io->flags |= ISDISK; - if (S_ISCHR(sb.st_mode)) - io->flags |= ioctl(io->fd, MTIOCGET, &mt) ? ISCHR : ISTAPE; - else if (lseek(io->fd, (off_t)0, SEEK_CUR) == -1 && errno == ESPIPE) - io->flags |= ISPIPE; /* XXX fixed in 4.4BSD */ + if (S_ISCHR(sb.st_mode) || S_ISBLK(sb.st_mode)) { + if (ioctl(io->fd, FIODTYPE, &type) == -1) + err(1, "%s", io->name); + if (type & D_TAPE) + io->flags |= ISTAPE; + else if (type & D_DISK) + io->flags |= ISDISK; + if (S_ISCHR(sb.st_mode) && (type & D_TAPE) == 0) + io->flags |= ISCHR; + } else if (!S_ISREG(sb.st_mode)) + io->flags |= ISPIPE; } static void |