xref: /aosp_15_r20/external/e2fsprogs/lib/ext2fs/flushb.c (revision 6a54128f25917bfc36a8a6e9d722c04a0b4641b6)
1*6a54128fSAndroid Build Coastguard Worker /*
2*6a54128fSAndroid Build Coastguard Worker  * flushb.c --- Hides system-dependent information for both syncing a
3*6a54128fSAndroid Build Coastguard Worker  * 	device to disk and to flush any buffers from disk cache.
4*6a54128fSAndroid Build Coastguard Worker  *
5*6a54128fSAndroid Build Coastguard Worker  * Copyright (C) 2000 Theodore Ts'o.
6*6a54128fSAndroid Build Coastguard Worker  *
7*6a54128fSAndroid Build Coastguard Worker  * %Begin-Header%
8*6a54128fSAndroid Build Coastguard Worker  * This file may be redistributed under the terms of the GNU Library
9*6a54128fSAndroid Build Coastguard Worker  * General Public License, version 2.
10*6a54128fSAndroid Build Coastguard Worker  * %End-Header%
11*6a54128fSAndroid Build Coastguard Worker  */
12*6a54128fSAndroid Build Coastguard Worker 
13*6a54128fSAndroid Build Coastguard Worker #include "config.h"
14*6a54128fSAndroid Build Coastguard Worker #include <stdio.h>
15*6a54128fSAndroid Build Coastguard Worker #if HAVE_ERRNO_H
16*6a54128fSAndroid Build Coastguard Worker #include <errno.h>
17*6a54128fSAndroid Build Coastguard Worker #endif
18*6a54128fSAndroid Build Coastguard Worker #if HAVE_UNISTD_H
19*6a54128fSAndroid Build Coastguard Worker #include <unistd.h>
20*6a54128fSAndroid Build Coastguard Worker #endif
21*6a54128fSAndroid Build Coastguard Worker #if HAVE_SYS_IOCTL_H
22*6a54128fSAndroid Build Coastguard Worker #include <sys/ioctl.h>
23*6a54128fSAndroid Build Coastguard Worker #endif
24*6a54128fSAndroid Build Coastguard Worker #if HAVE_SYS_MOUNT_H
25*6a54128fSAndroid Build Coastguard Worker #include <sys/param.h>
26*6a54128fSAndroid Build Coastguard Worker #include <sys/mount.h>		/* This may define BLKFLSBUF */
27*6a54128fSAndroid Build Coastguard Worker #endif
28*6a54128fSAndroid Build Coastguard Worker 
29*6a54128fSAndroid Build Coastguard Worker #include "ext2_fs.h"
30*6a54128fSAndroid Build Coastguard Worker #include "ext2fs.h"
31*6a54128fSAndroid Build Coastguard Worker 
32*6a54128fSAndroid Build Coastguard Worker /*
33*6a54128fSAndroid Build Coastguard Worker  * For Linux, define BLKFLSBUF and FDFLUSH if necessary, since
34*6a54128fSAndroid Build Coastguard Worker  * not all portable header file does so for us.  This really should be
35*6a54128fSAndroid Build Coastguard Worker  * fixed in the glibc header files.  (Recent glibcs appear to define
36*6a54128fSAndroid Build Coastguard Worker  * BLKFLSBUF in sys/mount.h, but FDFLUSH still doesn't seem to be
37*6a54128fSAndroid Build Coastguard Worker  * defined anywhere portable.)  Until then....
38*6a54128fSAndroid Build Coastguard Worker  */
39*6a54128fSAndroid Build Coastguard Worker #ifdef __linux__
40*6a54128fSAndroid Build Coastguard Worker #ifndef BLKFLSBUF
41*6a54128fSAndroid Build Coastguard Worker #define BLKFLSBUF	_IO(0x12,97)	/* flush buffer cache */
42*6a54128fSAndroid Build Coastguard Worker #endif
43*6a54128fSAndroid Build Coastguard Worker #ifndef FDFLUSH
44*6a54128fSAndroid Build Coastguard Worker #define FDFLUSH		_IO(2,0x4b)	/* flush floppy disk */
45*6a54128fSAndroid Build Coastguard Worker #endif
46*6a54128fSAndroid Build Coastguard Worker #endif
47*6a54128fSAndroid Build Coastguard Worker 
48*6a54128fSAndroid Build Coastguard Worker /*
49*6a54128fSAndroid Build Coastguard Worker  * This function will sync a device/file, and optionally attempt to
50*6a54128fSAndroid Build Coastguard Worker  * flush the buffer cache.  The latter is basically only useful for
51*6a54128fSAndroid Build Coastguard Worker  * system benchmarks and for torturing systems in burn-in tests.  :)
52*6a54128fSAndroid Build Coastguard Worker  */
ext2fs_sync_device(int fd,int flushb)53*6a54128fSAndroid Build Coastguard Worker errcode_t ext2fs_sync_device(int fd, int flushb)
54*6a54128fSAndroid Build Coastguard Worker {
55*6a54128fSAndroid Build Coastguard Worker 	/*
56*6a54128fSAndroid Build Coastguard Worker 	 * We always sync the device in case we're running on old
57*6a54128fSAndroid Build Coastguard Worker 	 * kernels for which we can lose data if we don't.  (There
58*6a54128fSAndroid Build Coastguard Worker 	 * still is a race condition for those kernels, but this
59*6a54128fSAndroid Build Coastguard Worker 	 * reduces it greatly.)
60*6a54128fSAndroid Build Coastguard Worker 	 */
61*6a54128fSAndroid Build Coastguard Worker #if defined(HAVE_FSYNC)
62*6a54128fSAndroid Build Coastguard Worker 	if (fsync (fd) == -1)
63*6a54128fSAndroid Build Coastguard Worker 		return errno;
64*6a54128fSAndroid Build Coastguard Worker #endif
65*6a54128fSAndroid Build Coastguard Worker 
66*6a54128fSAndroid Build Coastguard Worker 	if (flushb) {
67*6a54128fSAndroid Build Coastguard Worker 		errcode_t	retval = 0;
68*6a54128fSAndroid Build Coastguard Worker 
69*6a54128fSAndroid Build Coastguard Worker #ifdef BLKFLSBUF
70*6a54128fSAndroid Build Coastguard Worker 		if (ioctl (fd, BLKFLSBUF, 0) == 0)
71*6a54128fSAndroid Build Coastguard Worker 			return 0;
72*6a54128fSAndroid Build Coastguard Worker 		retval = errno;
73*6a54128fSAndroid Build Coastguard Worker #elif defined(__linux__)
74*6a54128fSAndroid Build Coastguard Worker #warning BLKFLSBUF not defined
75*6a54128fSAndroid Build Coastguard Worker #endif
76*6a54128fSAndroid Build Coastguard Worker #ifdef FDFLUSH
77*6a54128fSAndroid Build Coastguard Worker 		/* In case this is a floppy */
78*6a54128fSAndroid Build Coastguard Worker 		if (ioctl(fd, FDFLUSH, 0) == 0)
79*6a54128fSAndroid Build Coastguard Worker 			return 0;
80*6a54128fSAndroid Build Coastguard Worker 		if (retval == 0)
81*6a54128fSAndroid Build Coastguard Worker 			retval = errno;
82*6a54128fSAndroid Build Coastguard Worker #elif defined(__linux__)
83*6a54128fSAndroid Build Coastguard Worker #warning FDFLUSH not defined
84*6a54128fSAndroid Build Coastguard Worker #endif
85*6a54128fSAndroid Build Coastguard Worker 		return retval;
86*6a54128fSAndroid Build Coastguard Worker 	}
87*6a54128fSAndroid Build Coastguard Worker 	return 0;
88*6a54128fSAndroid Build Coastguard Worker }
89