1 From 5aa9c953909b936ba215ebca77461a17160f59fb Mon Sep 17 00:00:00 2001
2 From: George Kiagiadakis <george.kiagiadakis@collabora.com>
3 Date: Thu, 1 Jul 2021 11:50:40 +0300
4 Subject: [PATCH] node-driver: make the timerfd non-blocking
8 Upstream-Status: Backport [from master/0.3.32]
9 Signed-off-by: George Kiagiadakis <george.kiagiadakis@collabora.com>
11 spa/plugins/support/node-driver.c | 8 ++++++--
12 1 file changed, 6 insertions(+), 2 deletions(-)
14 diff --git a/spa/plugins/support/node-driver.c b/spa/plugins/support/node-driver.c
15 index 34533d0d9..32964110d 100644
16 --- a/spa/plugins/support/node-driver.c
17 +++ b/spa/plugins/support/node-driver.c
18 @@ -119,8 +119,11 @@ static void on_timeout(struct spa_source *source)
19 spa_log_trace(this->log, "timeout");
21 if (spa_system_timerfd_read(this->data_system,
22 - this->timer_source.fd, &expirations) < 0)
23 + this->timer_source.fd, &expirations) < 0) {
24 + if (errno == EAGAIN)
26 perror("read timerfd");
29 nsec = this->next_time;
31 @@ -349,7 +352,8 @@ impl_init(const struct spa_handle_factory *factory,
33 this->timer_source.func = on_timeout;
34 this->timer_source.data = this;
35 - this->timer_source.fd = spa_system_timerfd_create(this->data_system, CLOCK_MONOTONIC, SPA_FD_CLOEXEC);
36 + this->timer_source.fd = spa_system_timerfd_create(this->data_system, CLOCK_MONOTONIC,
37 + SPA_FD_CLOEXEC | SPA_FD_NONBLOCK);
38 this->timer_source.mask = SPA_IO_IN;
39 this->timer_source.rmask = 0;
40 this->timerspec.it_value.tv_sec = 0;