0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-15 17:16:49 +01:00

modules/client/rooms/state: Optimize parallel closure invariant.

This commit is contained in:
Jason Volk 2019-04-26 05:41:35 -07:00
parent 6335a0ce09
commit ea7e06fe27

View file

@ -192,18 +192,19 @@ ircd::m::sync::room_state_polylog_events(data &data)
*data.out, "events" *data.out, "events"
}; };
bool ret{false};
ctx::mutex mutex; ctx::mutex mutex;
const event::closure_idx each_idx{[&data, &array, &mutex, &ret] std::array<event::idx, 64> md; //TODO: conf
std::vector<event::fetch> event(md.size() * 2);
for(auto &fetch : event)
fetch = event::fetch{_default_fopts};
size_t _i(0);
bool ret{false};
const event::closure_idx each_idx{[&data, &array, &mutex, &ret, &event, &_i]
(const m::event::idx event_idx) (const m::event::idx event_idx)
{ {
const event::fetch event const size_t i{_i++ % event.size()};
{ if(unlikely(!seek(event.at(i), event_idx, std::nothrow)))
event_idx, std::nothrow, _default_fopts
};
//assert(event.valid);
if(unlikely(!event.valid))
{ {
assert(data.room); assert(data.room);
log::error log::error
@ -217,12 +218,10 @@ ircd::m::sync::room_state_polylog_events(data &data)
} }
const std::lock_guard lock{mutex}; const std::lock_guard lock{mutex};
room_state_append(data, array, event, event_idx); room_state_append(data, array, event.at(i), event_idx);
ret = true; ret = true;
}}; }};
//TODO: conf
std::array<event::idx, 64> md;
ctx::parallel<event::idx> parallel ctx::parallel<event::idx> parallel
{ {
m::sync::pool, md, each_idx m::sync::pool, md, each_idx