提交 85bca3c0 编写于 作者: J Joe Thornber 提交者: Mike Snitzer

dm btree: add a defensive bounds check to insert_at()

Corrupt metadata could trigger an out of bounds write.
Signed-off-by: NJoe Thornber <ejt@redhat.com>
Signed-off-by: NMike Snitzer <snitzer@redhat.com>
上级 c671ffa5
...@@ -81,14 +81,16 @@ void inc_children(struct dm_transaction_manager *tm, struct btree_node *n, ...@@ -81,14 +81,16 @@ void inc_children(struct dm_transaction_manager *tm, struct btree_node *n,
} }
static int insert_at(size_t value_size, struct btree_node *node, unsigned index, static int insert_at(size_t value_size, struct btree_node *node, unsigned index,
uint64_t key, void *value) uint64_t key, void *value)
__dm_written_to_disk(value) __dm_written_to_disk(value)
{ {
uint32_t nr_entries = le32_to_cpu(node->header.nr_entries); uint32_t nr_entries = le32_to_cpu(node->header.nr_entries);
uint32_t max_entries = le32_to_cpu(node->header.max_entries);
__le64 key_le = cpu_to_le64(key); __le64 key_le = cpu_to_le64(key);
if (index > nr_entries || if (index > nr_entries ||
index >= le32_to_cpu(node->header.max_entries)) { index >= max_entries ||
nr_entries >= max_entries) {
DMERR("too many entries in btree node for insert"); DMERR("too many entries in btree node for insert");
__dm_unbless_for_disk(value); __dm_unbless_for_disk(value);
return -ENOMEM; return -ENOMEM;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册