Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp1229398imm; Fri, 8 Jun 2018 12:13:17 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLP32QFyVmL+UHIv4nGz8YSaYOXff83JQxg75FUBtbieVP8FCbDD+mhovX0VZiqHwyP5suz X-Received: by 2002:a65:6346:: with SMTP id p6-v6mr6272737pgv.281.1528485197364; Fri, 08 Jun 2018 12:13:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528485197; cv=none; d=google.com; s=arc-20160816; b=ZBZzUdig9Cx7fNQEkyAzzKA7JCGVhU5tvgsWyQXLDIxEZiUV5zhfVqSPX7XUdaGl5+ kzcHMdvOgrjv5iZKP8XAUBMIyCbOGM03gCmU+jwVI6Mk4kxh2eDRtP7F+IRbd8tDaALk OKhF1MQRdwreALoV1ZPZutWrrfNPM3mx0ztqUTENaUYPSF5/lTZgPl+a/M8h4fXyehgG vlwTnmNq/IOEbcL6abzaumkg9gPESTYi9T1zKU166IN1+IwsF8bH/YWBZlBQdrFjNZg9 DRhMhEmjyC+Zc8icLJaGRsvqmXSzatDr5v1crMlSb0U0pNRhJl834je1wbC3axlhdCo8 TKJA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=3VOUFDRzVTPPkHKgia+ybV0nS68P2ApEyakeGkhWYfk=; b=IKfMT720iCfQXuCRiy1jxMxvNWUcHUwfUH1XWSKnCfqtQYvdZ+K1bNncgokanmX+Xc I28IisTHrlIe+QXhwEcbG+68y+bi5wSg27ZB0qoLj2awrraTewTKsfKqv8G3gEREkj22 iGlJKCmXGlyL4TLzdnN1OucRiLbwbaOcu6j0/vIwhUZJNvQ5mvFnk/cBz8sSKSFbM3BM orY0sIxGK171gF9Nw6yjxgC4CDqmTx/mgTWVTSwXvrgSe48NIDKmJQUKXNwqyu+2lq/h GUX6qvj99Un9Dv02XJt9uvSYU6TmYijSbckGpe7CvNqthRV6XFCqy6Hg7k/x/gzJkVcX KMgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@scylladb-com.20150623.gappssmtp.com header.s=20150623 header.b=DyH8beMd; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h16-v6si1587150pfi.84.2018.06.08.12.13.02; Fri, 08 Jun 2018 12:13:17 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@scylladb-com.20150623.gappssmtp.com header.s=20150623 header.b=DyH8beMd; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752730AbeFHTMj (ORCPT + 99 others); Fri, 8 Jun 2018 15:12:39 -0400 Received: from mail-wr0-f195.google.com ([209.85.128.195]:44524 "EHLO mail-wr0-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751719AbeFHTMh (ORCPT ); Fri, 8 Jun 2018 15:12:37 -0400 Received: by mail-wr0-f195.google.com with SMTP id x4-v6so6235730wro.11 for ; Fri, 08 Jun 2018 12:12:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=scylladb-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id; bh=3VOUFDRzVTPPkHKgia+ybV0nS68P2ApEyakeGkhWYfk=; b=DyH8beMd3s8qQ6mvX8lQQ9yTjTuHwxrUih2H/601ljuPYk1lInoAVyzdlpnUpzSMIr ysMKADvI003spMgGuAPrADxSKZhgXMz3D/caeSC5P8nztRsTHNHfuTGO2EAUapwIakDo 4OJ69vH6Z5GYdjRwbRdRkiCR8kGtB44oPzLPRjtDgT89fJ8OBWb1K9oTMEmE10YicUPJ fe2u6FXlDclmJfSs6UYGYhDooMeEUShudncESnrZVt2t8sZDmmINzYVemyeA7JxuLSc9 Y/VlTPIZ0Xh56ut5eDAfdbyNXNo99GIub5PXbHMfMRYuw8uYf0gRu5HCDbopSvItp18B jRLQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=3VOUFDRzVTPPkHKgia+ybV0nS68P2ApEyakeGkhWYfk=; b=k2d3/sHSSXAAHf/+aiNGiyhMkTPLuacrCB3zkAPk56z0SI3bolYRvdB9MDFKARnZSk eYG4JfPE48BDqiWurRSzMhMPWvAleKHqAj45bYepEhNWsbOyzHFBbLPNml80AXBCfDiT p3ABPkxSQcKQp3HZPgF7kwrI2kygfAg+P/Jt+9S40qojZ55FBfY05lcV14FuJtMntecV 6x81YqD2AhCAtWFJDnbbLXKEc80pGXIUaxTLivdD5G8dQ0RMuik7XeIg9iCuOMFV2Vwi 96P28bh2ZKqHFfS5WAEAPUkdDV7P0HQlrHq4BYHI+4knphhU8j5QAcxTtI5NCa0Vghpn saYw== X-Gm-Message-State: APt69E0CjTYUmJu4+QUJtBT9mMU3VJFJ6Jk7I4PzpAZ5xecIZ89PNGcq wZmh9GWXduDEZWteu9H9MINdNw== X-Received: by 2002:adf:9aa5:: with SMTP id a34-v6mr6366777wrc.50.1528485156481; Fri, 08 Jun 2018 12:12:36 -0700 (PDT) Received: from avi.cloudius-systems.com (system.cloudius-systems.com. [199.203.229.89]) by smtp.gmail.com with ESMTPSA id u7-v6sm40715117wrp.44.2018.06.08.12.12.34 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 08 Jun 2018 12:12:35 -0700 (PDT) From: Avi Kivity To: Alexander Viro Cc: hch@lst.de, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org Subject: [PATCH v1] eventfd: only return events requested in poll_mask() Date: Fri, 8 Jun 2018 22:12:32 +0300 Message-Id: <20180608191232.4758-1-avi@scylladb.com> X-Mailer: git-send-email 2.14.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The ->poll_mask() operation has a mask of events that the caller is interested in, but we're returning all events regardless. Change to return only the events the caller is interested in. This fixes aio IO_CMD_POLL returning immediately when called with POLLIN on an eventfd, since an eventfd is almost always ready for a write. Signed-off-by: Avi Kivity --- fs/eventfd.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fs/eventfd.c b/fs/eventfd.c index 61c9514da5e9..ceb1031f1cac 100644 --- a/fs/eventfd.c +++ b/fs/eventfd.c @@ -154,15 +154,15 @@ static __poll_t eventfd_poll_mask(struct file *file, __poll_t eventmask) * eventfd_poll returns 0 */ count = READ_ONCE(ctx->count); if (count > 0) - events |= EPOLLIN; + events |= (EPOLLIN & eventmask); if (count == ULLONG_MAX) events |= EPOLLERR; if (ULLONG_MAX - 1 > count) - events |= EPOLLOUT; + events |= (EPOLLOUT & eventmask); return events; } static void eventfd_ctx_do_read(struct eventfd_ctx *ctx, __u64 *cnt) -- 2.14.4