summaryrefslogtreecommitdiff
path: root/src/sna
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2014-06-09 13:13:25 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2014-06-09 13:14:51 +0100
commitaf3130cbba8375b9060a3a8cef5b03189d01c419 (patch)
tree0c012a932b9ee18a366a66dc170b2904b01b9632 /src/sna
parent981af18190be772b469761bc124b9f46c19d5093 (diff)
sna: Do not rely on udev_monitor_receive_device() being non-blocking
The libudev documentation says that is it non-blocking by default, but experience shows otherwise. Reported-by: Sedat Dilek <sedat.dilek@gmail.com> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src/sna')
-rw-r--r--src/sna/sna_display.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/sna/sna_display.c b/src/sna/sna_display.c
index 231fc68c..51875151 100644
--- a/src/sna/sna_display.c
+++ b/src/sna/sna_display.c
@@ -189,14 +189,19 @@ static inline struct sna_crtc *to_sna_crtc(xf86CrtcPtr crtc)
return crtc->driver_private;
}
-static bool sna_mode_has_pending_events(struct sna *sna)
+static inline bool event_pending(int fd)
{
struct pollfd pfd;
- pfd.fd = sna->kgem.fd;
+ pfd.fd = fd;
pfd.events = POLLIN;
return poll(&pfd, 1, 0) == 1;
}
+static bool sna_mode_has_pending_events(struct sna *sna)
+{
+ return event_pending(sna->kgem.fd);
+}
+
static bool sna_mode_wait_for_event(struct sna *sna)
{
struct pollfd pfd;
@@ -411,17 +416,19 @@ sna_backlight_uevent(int fd, void *closure)
DBG(("%s()\n", __FUNCTION__));
/* Drain the event queue */
- do {
+ while (event_pending(fd)) {
struct udev_device *dev;
+ DBG(("%s: waiting for uevent\n", __FUNCTION__));
dev = udev_monitor_receive_device(sna->mode.backlight_monitor);
if (dev == NULL)
break;
udev_device_unref(dev);
- } while (1);
+ }
/* Query all backlights for any changes */
+ DBG(("%s: probing backlights for changes\n", __FUNCTION__));
for (i = 0; i < sna->mode.num_real_output; i++) {
xf86OutputPtr output = config->output[i];
struct sna_output *sna_output = to_sna_output(output);