mirror of
https://github.com/Zygo/bees.git
synced 2025-05-18 05:45:45 +02:00
context: reduce the size of LOGICAL_INO buffers
Since we'll never process more than BEES_MAX_EXTENT_REF_COUNT extent references by definition, it follows that we should not allocate buffer space for them when we perform the LOGICAL_INO ioctl. There is some evidence (particularly https://github.com/Zygo/bees/issues/260#issuecomment-1627598058) that the kernel is subjecting the page cache to a lot of disruption when trying allocate large buffers for LOGICAL_INO. Signed-off-by: Zygo Blaxell <bees@furryterror.org>
This commit is contained in:
parent
cfb7592859
commit
75131f396f
@ -925,7 +925,8 @@ BeesContext::start()
|
|||||||
return make_shared<BeesTempFile>(shared_from_this());
|
return make_shared<BeesTempFile>(shared_from_this());
|
||||||
});
|
});
|
||||||
m_logical_ino_pool.generator([]() {
|
m_logical_ino_pool.generator([]() {
|
||||||
return make_shared<BtrfsIoctlLogicalInoArgs>(0);
|
const auto extent_ref_size = sizeof(uint64_t) * 3;
|
||||||
|
return make_shared<BtrfsIoctlLogicalInoArgs>(0, BEES_MAX_EXTENT_REF_COUNT * extent_ref_size + sizeof(btrfs_data_container));
|
||||||
});
|
});
|
||||||
m_tmpfile_pool.checkin([](const shared_ptr<BeesTempFile> &btf) {
|
m_tmpfile_pool.checkin([](const shared_ptr<BeesTempFile> &btf) {
|
||||||
catch_all([&](){
|
catch_all([&](){
|
||||||
|
Loading…
x
Reference in New Issue
Block a user