Home | History | Annotate | Download | only in e2fsck
      1 /*
      2  * flushb.c --- This routine flushes the disk buffers for a disk
      3  *
      4  * Copyright 1997, 2000, by Theodore Ts'o.
      5  *
      6  * WARNING: use of flushb on some older 2.2 kernels on a heavily loaded
      7  * system will corrupt filesystems.  This program is not really useful
      8  * beyond for benchmarking scripts.
      9  *
     10  * %Begin-Header%
     11  * This file may be redistributed under the terms of the GNU Public
     12  * License.
     13  * %End-Header%
     14  */
     15 
     16 #include <stdio.h>
     17 #include <string.h>
     18 #include <unistd.h>
     19 #include <stdlib.h>
     20 #include <fcntl.h>
     21 #include <sys/ioctl.h>
     22 #include <sys/mount.h>
     23 #include "../misc/nls-enable.h"
     24 
     25 /* For Linux, define BLKFLSBUF if necessary */
     26 #if (!defined(BLKFLSBUF) && defined(__linux__))
     27 #define BLKFLSBUF	_IO(0x12,97)	/* flush buffer cache */
     28 #endif
     29 
     30 const char *progname;
     31 
     32 static void usage(void)
     33 {
     34 	fprintf(stderr, _("Usage: %s disk\n"), progname);
     35 	exit(1);
     36 }
     37 
     38 int main(int argc, char **argv)
     39 {
     40 	int	fd;
     41 
     42 	progname = argv[0];
     43 	if (argc != 2)
     44 		usage();
     45 
     46 	fd = open(argv[1], O_RDONLY, 0);
     47 	if (fd < 0) {
     48 		perror("open");
     49 		exit(1);
     50 	}
     51 	/*
     52 	 * Note: to reread the partition table, use the ioctl
     53 	 * BLKRRPART instead of BLKFSLBUF.
     54 	 */
     55 #ifdef BLKFLSBUF
     56 	if (ioctl(fd, BLKFLSBUF, 0) < 0) {
     57 		perror("ioctl BLKFLSBUF");
     58 		exit(1);
     59 	}
     60 	return 0;
     61 #else
     62 	fprintf(stderr,
     63 		_("BLKFLSBUF ioctl not supported!  Can't flush buffers.\n"));
     64 	return 1;
     65 #endif
     66 }
     67