Skip to content

Commit

Permalink
backend: idle fd improvements
Browse files Browse the repository at this point in the history
  • Loading branch information
vaxerski committed Jul 2, 2024
1 parent 04b2db8 commit 8741839
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 9 deletions.
1 change: 1 addition & 0 deletions include/aquamarine/backend/Backend.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,7 @@ namespace Aquamarine {
} idle;

void dispatchIdle();
void updateIdleTimer();

//
struct {
Expand Down
13 changes: 12 additions & 1 deletion src/backend/Backend.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -174,14 +174,17 @@ std::vector<Hyprutils::Memory::CSharedPointer<SPollFD>> Aquamarine::CBackend::ge
for (auto& i : implementations) {
auto pollfds = i->pollFDs();
for (auto& p : pollfds) {
log(AQ_LOG_DEBUG, std::format("backend: poll fd {} for implementation {}", p->fd, backendTypeToName(i->type())));
result.emplace_back(p);
}
}

for (auto& sfd : sessionFDs) {
log(AQ_LOG_DEBUG, std::format("backend: poll fd {} for session", sfd->fd));
result.emplace_back(sfd);
}

log(AQ_LOG_DEBUG, std::format("backend: poll fd {} for idle", idle.fd));
result.emplace_back(makeShared<SPollFD>(idle.fd, [this]() { dispatchIdle(); }));

return result;
Expand Down Expand Up @@ -224,9 +227,15 @@ const std::vector<SP<IBackendImplementation>>& Aquamarine::CBackend::getImplemen
void Aquamarine::CBackend::addIdleEvent(SP<std::function<void(void)>> fn) {
auto r = idle.pending.emplace_back(fn);

// update timerfd
updateIdleTimer();
}

void Aquamarine::CBackend::updateIdleTimer() {
uint64_t ADD_NS = idle.pending.empty() ? TIMESPEC_NSEC_PER_SEC * 240ULL /* 240s, 4 mins */ : 0;

timespec now;
clock_gettime(CLOCK_MONOTONIC, &now);
timespecAddNs(&now, ADD_NS);

itimerspec ts = {.it_value = now};

Expand All @@ -246,4 +255,6 @@ void Aquamarine::CBackend::dispatchIdle() {
if (i && *i)
(*i)();
}

updateIdleTimer();
}
17 changes: 9 additions & 8 deletions src/backend/Headless.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ bool Aquamarine::CHeadlessBackend::createOutput(const std::string& name) {
auto output = SP<CHeadlessOutput>(new CHeadlessOutput(name.empty() ? std::format("HEADLESS-{}", ++outputIDCounter) : name, self.lock()));
outputs.emplace_back(output);
output->swapchain = CSwapchain::create(backend->allocator, self.lock());
output->self = output;
output->self = output;
backend->events.newOutput.emit(SP<IOutput>(output));

return true;
Expand All @@ -147,22 +147,23 @@ void Aquamarine::CHeadlessBackend::dispatchTimers() {
}

void Aquamarine::CHeadlessBackend::updateTimerFD() {
long long lowest = 42069133769LL;
long long lowestNs = TIMESPEC_NSEC_PER_SEC * 240 /* 240s, 4 mins */;
const auto clocknow = std::chrono::steady_clock::now();
bool any = false;

for (auto& t : timers.timers) {
auto delta = std::chrono::duration_cast<std::chrono::microseconds>(t.when - clocknow).count();
auto delta = std::chrono::duration_cast<std::chrono::microseconds>(t.when - clocknow).count() * 1000 /* µs -> ns */;

if (delta < lowest)
lowest = delta;
if (delta < lowestNs)
lowestNs = delta;
}

if (lowest < 0)
lowest = 0;
if (lowestNs < 0)
lowestNs = 0;

timespec now;
clock_gettime(CLOCK_MONOTONIC, &now);
timespecAddNs(&now, lowest * 1000); // µs -> ns => * 1000
timespecAddNs(&now, lowestNs);

itimerspec ts = {.it_value = now};

Expand Down

0 comments on commit 8741839

Please sign in to comment.