Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp4258739ybz; Tue, 28 Apr 2020 08:18:56 -0700 (PDT) X-Google-Smtp-Source: APiQypI3dPWRsPFY6qUWzggBvJnV1JujD4E2XfaLtcv/dDvWd89AwMZaaySr4A5p6ws0F8NjOvKV X-Received: by 2002:a17:906:ecb8:: with SMTP id qh24mr24825017ejb.299.1588087136318; Tue, 28 Apr 2020 08:18:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588087136; cv=none; d=google.com; s=arc-20160816; b=nw6QjXHZv9Zp6Dm5MevXKya/rlB2PU823taSmXLyVry2ZkEVYcmo6OlyxF03nb0G26 UyBZmqHLGRYVjYmghK0SddHRCsaZQ6kFBc8qP6omMSVYurydDmL47bUYQI7asDzYoiou HQhVP5cipza9r0OAChR0YksUeUTtXBeHg0Z5iw8vcboykDayYSjEc2wgVnMfXOhFIBFL LHVozqs8mrHxNluslEnBzGUayd/wxDtEJGZ/N1YCTZJSZINXTPDv2hxnbPR5XF28UyFv bWEpITpKsud3Dc6eU/ncoyLmsPu5B9RlSfzwmWGblFZ+hm+bo5CjP+L7ANLyn46KVUNi x9Eg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:mail-followup-to:message-id:subject:cc:to :from:date:dkim-signature; bh=gPj1O/jOW1qBAm9wItVCoQg+/JQBV9DNAyjrAa3CJ1s=; b=H/FQ/jtPveNx1ioao64gE9tEQ0a2PnnFOYZXknJQFAtVGXeHvOTFJMvlu+E5yHloA0 PDs8XEolK+1IJgT9lwwQZ3HkvHX0jlvJqhxTrfXwNF4h6W6BKDCQLgvItysNTsrGlBCN cSA5k0bu6NZ+EcKdn98g+Kd38I9GqnfYtpJ+xQ1/nfUWnSrkRuM/Wzx/wa+jvA0ycgSA ceB9AQYvqUe1wqtFI/IumR6jFoL/kNhWY0zbSnY1qjfPMzEeQSN5dNyzG4Y1/pv5ugD1 S0dfeM5KqgzUJo4KLL2k3ew0oHHzTwweTfIlhZRSqdbh3ScFvEDk4/30+0cy+9oQbqWz wUNg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=dt9JvUZu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d20si1641350edz.32.2020.04.28.08.18.27; Tue, 28 Apr 2020 08:18:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=dt9JvUZu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728073AbgD1POQ (ORCPT + 99 others); Tue, 28 Apr 2020 11:14:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41028 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1727108AbgD1POP (ORCPT ); Tue, 28 Apr 2020 11:14:15 -0400 Received: from mail-wr1-x442.google.com (mail-wr1-x442.google.com [IPv6:2a00:1450:4864:20::442]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EC7F1C03C1AB for ; Tue, 28 Apr 2020 08:14:13 -0700 (PDT) Received: by mail-wr1-x442.google.com with SMTP id d17so25096187wrg.11 for ; Tue, 28 Apr 2020 08:14:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=date:from:to:cc:subject:message-id:mail-followup-to:references :mime-version:content-disposition:in-reply-to; bh=gPj1O/jOW1qBAm9wItVCoQg+/JQBV9DNAyjrAa3CJ1s=; b=dt9JvUZu3Yez0wBMSlGnIr5B7uhLVVv3xwgu+ys50HNnfNjJK9xsLpXf2bo0UZ1oym ecWCqYvougpWP61bBgvZZAZn43EYIJgizSjuwvDRtGA34DKbLCNt331p+fseG19QtbW0 hLAenfbNLivynA523s4fRjSgUtRCZxbl616Nk= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to; bh=gPj1O/jOW1qBAm9wItVCoQg+/JQBV9DNAyjrAa3CJ1s=; b=q/rAmU/2TRMV2QLgJFMglByzJrQevA7i9GPt79Drv4i3QUENyorBrPv3Nfdv17NL3t L3UubJcwnscsL0IUTj2TtGD/1sDyjgE1XB9adpd6nD3pwztyiF5bAlMRxUEPg0j/2f6k wOC9kctrkfu4wGZGoyyNIJJ+rUaZLC9rbExIxJQz7bJR9HUBtBZdG833znM5WRxVl3YB Z3JRhu5Qe6u/UD+EgLO6P9DRMvbxSfF4XHkssKsBDftOc78Tc3rrkStYjb0r4IsZMjR3 QD68ItOc5BOpAHg/+T8fPj8Vwt0XuVueUGwxwaJs4bOFyhklCngAGh5V4qk0CJcpVmbU qF5g== X-Gm-Message-State: AGi0PubXnhQjNs0J2IvkFYtb5YSiACwxVGGWT6S214Whmk84LeOA2SGJ 7yU/JYQzYq0TrHHUvfk3di/Ueg== X-Received: by 2002:adf:e986:: with SMTP id h6mr33315188wrm.256.1588086852682; Tue, 28 Apr 2020 08:14:12 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id q8sm3611203wmg.22.2020.04.28.08.14.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 28 Apr 2020 08:14:11 -0700 (PDT) Date: Tue, 28 Apr 2020 17:14:10 +0200 From: Daniel Vetter To: Kenny Levinsen Cc: intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, daniel@ffwll.ch, airlied@linux.ie, tzimmermann@suse.de, mripard@kernel.org, maarten.lankhorst@linux.intel.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2] drm: make drm_file use keyed wakeups Message-ID: <20200428151410.GU3456981@phenom.ffwll.local> Mail-Followup-To: Kenny Levinsen , intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, airlied@linux.ie, tzimmermann@suse.de, mripard@kernel.org, maarten.lankhorst@linux.intel.com, linux-kernel@vger.kernel.org References: <20200424162615.10461-1-kl@kl.wtf> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200424162615.10461-1-kl@kl.wtf> X-Operating-System: Linux phenom 5.3.0-3-amd64 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Apr 24, 2020 at 06:26:15PM +0200, Kenny Levinsen wrote: > Some processes, such as systemd, are only polling for EPOLLERR|EPOLLHUP. > As drm_file uses unkeyed wakeups, such a poll can receive many spurious > wakeups from uninteresting events if, for example, the file description > is subscribed to vblank events. This is the case with systemd, as it > polls a file description from logind that is shared with the users' > compositor. > > Use keyed wakeups to allow the wakeup target to more efficiently discard > these uninteresting events. > > Signed-off-by: Kenny Levinsen Hm I applied v1 and I'm not spotting what's different here, and there's no changelog explaining what changed ... Please send a fixup if there's anything important missing. -Daniel > --- > drivers/gpu/drm/drm_file.c | 6 ++++-- > 1 file changed, 4 insertions(+), 2 deletions(-) > > diff --git a/drivers/gpu/drm/drm_file.c b/drivers/gpu/drm/drm_file.c > index c4c704e01961..ec25b3d979d9 100644 > --- a/drivers/gpu/drm/drm_file.c > +++ b/drivers/gpu/drm/drm_file.c > @@ -608,7 +608,8 @@ ssize_t drm_read(struct file *filp, char __user *buffer, > file_priv->event_space -= length; > list_add(&e->link, &file_priv->event_list); > spin_unlock_irq(&dev->event_lock); > - wake_up_interruptible(&file_priv->event_wait); > + wake_up_interruptible_poll(&file_priv->event_wait, > + EPOLLIN | EPOLLRDNORM); > break; > } > > @@ -804,7 +805,8 @@ void drm_send_event_locked(struct drm_device *dev, struct drm_pending_event *e) > list_del(&e->pending_link); > list_add_tail(&e->link, > &e->file_priv->event_list); > - wake_up_interruptible(&e->file_priv->event_wait); > + wake_up_interruptible_poll(&e->file_priv->event_wait, > + EPOLLIN | EPOLLRDNORM); > } > EXPORT_SYMBOL(drm_send_event_locked); > > -- > 2.26.1 > -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch