blob: b208488d0aae85403d526860b02006b4ef4c1757 [file] [log] [blame]
Mauro Carvalho Chehab898bd372019-04-18 19:45:00 -03001==========================================
Christoph Hellwig04ccc652010-09-03 11:56:17 +02002Explicit volatile write back cache control
Mauro Carvalho Chehab898bd372019-04-18 19:45:00 -03003==========================================
Christoph Hellwig04ccc652010-09-03 11:56:17 +02004
5Introduction
6------------
7
8Many storage devices, especially in the consumer market, come with volatile
9write back caches. That means the devices signal I/O completion to the
10operating system before data actually has hit the non-volatile storage. This
11behavior obviously speeds up various workloads, but it means the operating
12system needs to force data out to the non-volatile storage when it performs
13a data integrity operation like fsync, sync or an unmount.
14
15The Linux block layer provides two simple mechanisms that let filesystems
16control the caching behavior of the storage device. These mechanisms are
17a forced cache flush, and the Force Unit Access (FUA) flag for requests.
18
19
20Explicit cache flushes
21----------------------
22
Mike Christie28a8f0d2016-06-05 14:32:25 -050023The REQ_PREFLUSH flag can be OR ed into the r/w flags of a bio submitted from
Christoph Hellwig04ccc652010-09-03 11:56:17 +020024the filesystem and will make sure the volatile cache of the storage device
25has been flushed before the actual I/O operation is started. This explicitly
26guarantees that previously completed write requests are on non-volatile
Mike Christie28a8f0d2016-06-05 14:32:25 -050027storage before the flagged bio starts. In addition the REQ_PREFLUSH flag can be
Christoph Hellwig04ccc652010-09-03 11:56:17 +020028set on an otherwise empty bio structure, which causes only an explicit cache
29flush without any dependent I/O. It is recommend to use
30the blkdev_issue_flush() helper for a pure cache flush.
31
32
33Forced Unit Access
Mauro Carvalho Chehab898bd372019-04-18 19:45:00 -030034------------------
Christoph Hellwig04ccc652010-09-03 11:56:17 +020035
36The REQ_FUA flag can be OR ed into the r/w flags of a bio submitted from the
37filesystem and will make sure that I/O completion for this request is only
38signaled after the data has been committed to non-volatile storage.
39
40
41Implementation details for filesystems
42--------------------------------------
43
Mike Christie28a8f0d2016-06-05 14:32:25 -050044Filesystems can simply set the REQ_PREFLUSH and REQ_FUA bits and do not have to
Christoph Hellwig04ccc652010-09-03 11:56:17 +020045worry if the underlying devices need any explicit cache flushing and how
Mike Christie28a8f0d2016-06-05 14:32:25 -050046the Forced Unit Access is implemented. The REQ_PREFLUSH and REQ_FUA flags
Christoph Hellwig04ccc652010-09-03 11:56:17 +020047may both be set on a single bio.
48
49
Christoph Hellwigc62b37d2020-07-01 10:59:43 +020050Implementation details for bio based block drivers
Christoph Hellwig04ccc652010-09-03 11:56:17 +020051--------------------------------------------------------------
52
Mike Christie28a8f0d2016-06-05 14:32:25 -050053These drivers will always see the REQ_PREFLUSH and REQ_FUA bits as they sit
Christoph Hellwig04ccc652010-09-03 11:56:17 +020054directly below the submit_bio interface. For remapping drivers the REQ_FUA
55bits need to be propagated to underlying devices, and a global flush needs
Mike Christie28a8f0d2016-06-05 14:32:25 -050056to be implemented for bios with the REQ_PREFLUSH bit set. For real device
57drivers that do not have a volatile cache the REQ_PREFLUSH and REQ_FUA bits
58on non-empty bios can simply be ignored, and REQ_PREFLUSH requests without
Christoph Hellwig04ccc652010-09-03 11:56:17 +020059data can be completed successfully without doing any work. Drivers for
60devices with volatile caches need to implement the support for these
61flags themselves without any help from the block layer.
62
63
64Implementation details for request_fn based block drivers
Mauro Carvalho Chehab898bd372019-04-18 19:45:00 -030065---------------------------------------------------------
Christoph Hellwig04ccc652010-09-03 11:56:17 +020066
67For devices that do not support volatile write caches there is no driver
Mike Christie28a8f0d2016-06-05 14:32:25 -050068support required, the block layer completes empty REQ_PREFLUSH requests before
69entering the driver and strips off the REQ_PREFLUSH and REQ_FUA bits from
Christoph Hellwig04ccc652010-09-03 11:56:17 +020070requests that have a payload. For devices with volatile write caches the
71driver needs to tell the block layer that it supports flushing caches by
Mauro Carvalho Chehab898bd372019-04-18 19:45:00 -030072doing::
Christoph Hellwig04ccc652010-09-03 11:56:17 +020073
Jens Axboe2245f6d2016-03-30 10:19:30 -060074 blk_queue_write_cache(sdkp->disk->queue, true, false);
Christoph Hellwig04ccc652010-09-03 11:56:17 +020075
Mike Christie3a5e02c2016-06-05 14:32:23 -050076and handle empty REQ_OP_FLUSH requests in its prep_fn/request_fn. Note that
Mike Christie28a8f0d2016-06-05 14:32:25 -050077REQ_PREFLUSH requests with a payload are automatically turned into a sequence
Mike Christie3a5e02c2016-06-05 14:32:23 -050078of an empty REQ_OP_FLUSH request followed by the actual write by the block
Christoph Hellwig04ccc652010-09-03 11:56:17 +020079layer. For devices that also support the FUA bit the block layer needs
Mauro Carvalho Chehab898bd372019-04-18 19:45:00 -030080to be told to pass through the REQ_FUA bit using::
Christoph Hellwig04ccc652010-09-03 11:56:17 +020081
Jens Axboe2245f6d2016-03-30 10:19:30 -060082 blk_queue_write_cache(sdkp->disk->queue, true, true);
Christoph Hellwig04ccc652010-09-03 11:56:17 +020083
84and the driver must handle write requests that have the REQ_FUA bit set
85in prep_fn/request_fn. If the FUA bit is not natively supported the block
Mike Christie3a5e02c2016-06-05 14:32:23 -050086layer turns it into an empty REQ_OP_FLUSH request after the actual write.