summaryrefslogtreecommitdiffstats
path: root/storage/innobase/include/os0file.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-07-01 18:15:00 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-07-01 18:15:00 +0000
commita2a2e32c02643a0cec111511220227703fda1cd5 (patch)
tree69cc2b631234c2a8e026b9cd4d72676c61c594df /storage/innobase/include/os0file.h
parentReleasing progress-linux version 1:10.11.8-1~progress7.99u1. (diff)
downloadmariadb-a2a2e32c02643a0cec111511220227703fda1cd5.tar.xz
mariadb-a2a2e32c02643a0cec111511220227703fda1cd5.zip
Merging upstream version 1:11.4.2.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'storage/innobase/include/os0file.h')
-rw-r--r--storage/innobase/include/os0file.h12
1 files changed, 12 insertions, 0 deletions
diff --git a/storage/innobase/include/os0file.h b/storage/innobase/include/os0file.h
index 7eba359f..ce686475 100644
--- a/storage/innobase/include/os0file.h
+++ b/storage/innobase/include/os0file.h
@@ -197,10 +197,14 @@ public:
WRITE_SYNC= 16,
/** Asynchronous write */
WRITE_ASYNC= WRITE_SYNC | 1,
+ /** Asynchronous doublewritten page */
+ WRITE_DBL= WRITE_ASYNC | 4,
/** A doublewrite batch */
DBLWR_BATCH= WRITE_ASYNC | 8,
/** Write data and punch hole for the rest */
PUNCH= WRITE_ASYNC | 16,
+ /** Write doublewritten data and punch hole for the rest */
+ PUNCH_DBL= PUNCH | 4,
/** Zero out a range of bytes in fil_space_t::io() */
PUNCH_RANGE= WRITE_SYNC | 32,
};
@@ -216,6 +220,14 @@ public:
bool is_read() const { return (type & READ_SYNC) != 0; }
bool is_write() const { return (type & WRITE_SYNC) != 0; }
bool is_async() const { return (type & (READ_SYNC ^ READ_ASYNC)) != 0; }
+ bool is_doublewritten() const { return (type & 4) != 0; }
+
+ /** Create a write request for the doublewrite buffer. */
+ IORequest doublewritten() const
+ {
+ ut_ad(type == WRITE_ASYNC || type == PUNCH);
+ return IORequest{bpage, slot, node, Type(type | 4)};
+ }
void write_complete(int io_error) const;
void read_complete(int io_error) const;