File chromium-103-VirtualCursor-std-layout.patch of Package chromium-ffmpeg-extra (Revision acf13cd4d3b182c723d1231bb1ce7ca6)
Currently displaying revision acf13cd4d3b182c723d1231bb1ce7ca6 , Show latest
232
1
From 144479ad7b4287bee4067f95e4218f614798a865 Mon Sep 17 00:00:00 2001
2
From: Stephan Hartmann <stha09@googlemail.com>
3
Date: Sun, 16 Jan 2022 19:15:26 +0000
4
Subject: [PATCH] sql: make VirtualCursor standard layout type
5
6
sql::recover::VirtualCursor needs to be a standard layout type, but
7
has members of type std::unique_ptr. However, std::unique_ptr is not
8
guaranteed to be standard layout. Compiling with clang combined with
9
gcc-11 libstdc++ fails because of this.
10
11
Bug: 1189788
12
Change-Id: Ia6dc388cc5ef1c0f2afc75f8ca45b9f12687ca9c
13
---
14
15
diff --git a/sql/recover_module/btree.cc b/sql/recover_module/btree.cc
16
index cc9420e5..f12d8fa 100644
17
--- a/sql/recover_module/btree.cc
18
+++ b/sql/recover_module/btree.cc
19
20
"Move the destructor to the .cc file if it's non-trival");
21
#endif // !DCHECK_IS_ON()
22
23
-LeafPageDecoder::LeafPageDecoder(DatabasePageReader* db_reader) noexcept
24
- : page_id_(db_reader->page_id()),
25
- db_reader_(db_reader),
26
- cell_count_(ComputeCellCount(db_reader)),
27
- next_read_index_(0),
28
- last_record_size_(0) {
29
+LeafPageDecoder::LeafPageDecoder() noexcept = default;
30
+
31
+void LeafPageDecoder::Initialize(DatabasePageReader* db_reader) {
32
+ page_id_ = db_reader->page_id();
33
+ db_reader_ = db_reader;
34
+ cell_count_ = ComputeCellCount(db_reader);
35
+ next_read_index_ = 0;
36
+ last_record_size_ = 0;
37
DCHECK(IsOnValidPage(db_reader));
38
DCHECK(DatabasePageReader::IsValidPageId(page_id_));
39
}
40
41
+void LeafPageDecoder::Reset() {
42
+ db_reader_ = nullptr;
43
+}
44
+
45
bool LeafPageDecoder::TryAdvance() {
46
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
47
DCHECK(CanAdvance());
48
diff --git a/sql/recover_module/btree.h b/sql/recover_module/btree.h
49
index eaa087a5..df0e0c9 100644
50
--- a/sql/recover_module/btree.h
51
+++ b/sql/recover_module/btree.h
52
53
public:
54
// Creates a decoder for a DatabasePageReader's last read page.
55
//
56
- // |db_reader| must have been used to read an inner page of a table B-tree.
57
- // |db_reader| must outlive this instance.
58
- explicit LeafPageDecoder(DatabasePageReader* db_reader) noexcept;
59
+ LeafPageDecoder() noexcept;
60
~LeafPageDecoder() noexcept = default;
61
62
LeafPageDecoder(const LeafPageDecoder&) = delete;
63
64
// read as long as CanAdvance() returns true.
65
bool TryAdvance();
66
67
+ // Initialize with DatabasePageReader
68
+ // |db_reader| must have been used to read an inner page of a table B-tree.
69
+ // |db_reader| must outlive this instance.
70
+ void Initialize(DatabasePageReader* db_reader);
71
+
72
+ // Reset internal DatabasePageReader
73
+ void Reset();
74
+
75
+ // True if DatabasePageReader is valid
76
+ bool IsValid() { return (db_reader_ != nullptr); }
77
+
78
// True if the given reader may point to an inner page in a table B-tree.
79
//
80
// The last ReadPage() call on |db_reader| must have succeeded.
81
82
static int ComputeCellCount(DatabasePageReader* db_reader);
83
84
// The number of the B-tree page this reader is reading.
85
- const int64_t page_id_;
86
+ int64_t page_id_;
87
// Used to read the tree page.
88
//
89
// Raw pointer usage is acceptable because this instance's owner is expected
90
// to ensure that the DatabasePageReader outlives this.
91
- DatabasePageReader* const db_reader_;
92
+ DatabasePageReader* db_reader_;
93
// Caches the ComputeCellCount() value for this reader's page.
94
- const int cell_count_ = ComputeCellCount(db_reader_);
95
+ int cell_count_;
96
97
// The reader's cursor state.
98
//
99
diff --git a/sql/recover_module/cursor.cc b/sql/recover_module/cursor.cc
100
index 4f827ed..240de499 100644
101
--- a/sql/recover_module/cursor.cc
102
+++ b/sql/recover_module/cursor.cc
103
104
int VirtualCursor::First() {
105
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
106
inner_decoders_.clear();
107
- leaf_decoder_ = nullptr;
108
+ leaf_decoder_.Reset();
109
110
AppendPageDecoder(table_->root_page_id());
111
return Next();
112
113
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
114
record_reader_.Reset();
115
116
- while (!inner_decoders_.empty() || leaf_decoder_.get()) {
117
- if (leaf_decoder_.get()) {
118
- if (!leaf_decoder_->CanAdvance()) {
119
+ while (!inner_decoders_.empty() || leaf_decoder_.IsValid()) {
120
+ if (leaf_decoder_.IsValid()) {
121
+ if (!leaf_decoder_.CanAdvance()) {
122
// The leaf has been exhausted. Remove it from the DFS stack.
123
- leaf_decoder_ = nullptr;
124
+ leaf_decoder_.Reset();
125
continue;
126
}
127
- if (!leaf_decoder_->TryAdvance())
128
+ if (!leaf_decoder_.TryAdvance())
129
continue;
130
131
- if (!payload_reader_.Initialize(leaf_decoder_->last_record_size(),
132
- leaf_decoder_->last_record_offset())) {
133
+ if (!payload_reader_.Initialize(leaf_decoder_.last_record_size(),
134
+ leaf_decoder_.last_record_offset())) {
135
continue;
136
}
137
if (!record_reader_.Initialize())
138
139
int64_t VirtualCursor::RowId() {
140
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
141
DCHECK(record_reader_.IsInitialized());
142
- DCHECK(leaf_decoder_.get());
143
- return leaf_decoder_->last_record_rowid();
144
+ DCHECK(leaf_decoder_.IsValid());
145
+ return leaf_decoder_.last_record_rowid();
146
}
147
148
void VirtualCursor::AppendPageDecoder(int page_id) {
149
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
150
- DCHECK(leaf_decoder_.get() == nullptr)
151
+ DCHECK(!leaf_decoder_.IsValid())
152
<< __func__
153
<< " must only be called when the current path has no leaf decoder";
154
155
156
return;
157
158
if (LeafPageDecoder::IsOnValidPage(&db_reader_)) {
159
- leaf_decoder_ = std::make_unique<LeafPageDecoder>(&db_reader_);
160
+ leaf_decoder_.Initialize(&db_reader_);
161
return;
162
}
163
164
diff --git a/sql/recover_module/cursor.h b/sql/recover_module/cursor.h
165
index 845b785..cc4e85f8 100644
166
--- a/sql/recover_module/cursor.h
167
+++ b/sql/recover_module/cursor.h
168
169
std::vector<std::unique_ptr<InnerPageDecoder>> inner_decoders_;
170
171
// Decodes the leaf page containing records.
172
- std::unique_ptr<LeafPageDecoder> leaf_decoder_;
173
+ LeafPageDecoder leaf_decoder_;
174
175
SEQUENCE_CHECKER(sequence_checker_);
176
};
177
diff --git a/sql/recover_module/pager.cc b/sql/recover_module/pager.cc
178
index 58e75de..69d98cef 100644
179
--- a/sql/recover_module/pager.cc
180
+++ b/sql/recover_module/pager.cc
181
182
"ints are not appropriate for representing page IDs");
183
184
DatabasePageReader::DatabasePageReader(VirtualTable* table)
185
- : page_data_(std::make_unique<uint8_t[]>(table->page_size())),
186
- table_(table) {
187
+ : page_data_(table->page_size()), table_(table) {
188
DCHECK(table != nullptr);
189
DCHECK(IsValidPageSize(table->page_size()));
190
}
191
192
"The |read_offset| computation above may overflow");
193
194
int sqlite_status =
195
- RawRead(sqlite_file, read_size, read_offset, page_data_.get());
196
+ RawRead(sqlite_file, read_size, read_offset, page_data_.data());
197
198
// |page_id_| needs to be set to kInvalidPageId if the read failed.
199
// Otherwise, future ReadPage() calls with the previous |page_id_| value
200
diff --git a/sql/recover_module/pager.h b/sql/recover_module/pager.h
201
index 07cac3cb..d08f093 100644
202
--- a/sql/recover_module/pager.h
203
+++ b/sql/recover_module/pager.h
204
205
#define SQL_RECOVER_MODULE_PAGER_H_
206
207
#include <cstdint>
208
-#include <memory>
209
#include <ostream>
210
+#include <vector>
211
212
#include "base/check_op.h"
213
#include "base/memory/raw_ptr.h"
214
215
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
216
DCHECK_NE(page_id_, kInvalidPageId)
217
<< "Successful ReadPage() required before accessing pager state";
218
- return page_data_.get();
219
+ return page_data_.data();
220
}
221
222
// The number of bytes in the page read by the last ReadPage() call.
223
224
int page_id_ = kInvalidPageId;
225
// Stores the bytes of the last page successfully read by ReadPage().
226
// The content is undefined if the last call to ReadPage() did not succeed.
227
- const std::unique_ptr<uint8_t[]> page_data_;
228
+ std::vector<uint8_t> page_data_;
229
// Raw pointer usage is acceptable because this instance's owner is expected
230
// to ensure that the VirtualTable outlives this.
231
const raw_ptr<VirtualTable> table_;
232