From patchwork Tue Nov 3 20:35:47 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Greg Kroah-Hartman X-Patchwork-Id: 316821 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-9.8 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED, DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 36887C388F9 for ; Tue, 3 Nov 2020 21:50:24 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id DC665223AB for ; Tue, 3 Nov 2020 21:50:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604440223; bh=HxP24GZ8BhdPLAtEVsQZBRTDboxnusE+HL1PwTy/hrk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:List-ID:From; b=Px2Y/z4i7kyLIFwpC2iCqb3yLS5rTy63T05AOi4bdq4dT8tT6nf1hD2N4AFo+ar6u xYwG2UqFihDEg3bX5CCr5iwA+cbkXmKtDJQiAHp12Cp8dh+RroA9dWpQojJ6M8GRXC L4Q3hEFLIF4dsB8kgsJCfGRc6DQ5bRvRtD8aOzO8= Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729518AbgKCVuX (ORCPT ); Tue, 3 Nov 2020 16:50:23 -0500 Received: from mail.kernel.org ([198.145.29.99]:41674 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731435AbgKCUtH (ORCPT ); Tue, 3 Nov 2020 15:49:07 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5D8D522404; Tue, 3 Nov 2020 20:49:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604436546; bh=HxP24GZ8BhdPLAtEVsQZBRTDboxnusE+HL1PwTy/hrk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=j4G5quIuXqEBZVaBHej586lnVa5eITOr5s/6CpndV/qsgQj3VdStjgX7dokmY6Ufv cxst9+BgiJ4HNPmISIKujuBpXidxhJGXVl8mwfnSCZJqqHcGAGV2gat4wFXco2+xxS 4amYA1N8GIyeh4CuIYBMfjkHJ3aEXE1IJeXMN/Hw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Pavel Begunkov , Jens Axboe Subject: [PATCH 5.9 296/391] io_uring: use type appropriate io_kiocb handler for double poll Date: Tue, 3 Nov 2020 21:35:47 +0100 Message-Id: <20201103203407.049715487@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201103203348.153465465@linuxfoundation.org> References: <20201103203348.153465465@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org From: Jens Axboe commit c8b5e2600a2cfa1cdfbecf151afd67aee227381d upstream. io_poll_double_wake() is called for both request types - both pure poll requests, and internal polls. This means that we should be using the right handler based on the request type. Use the one that the original caller already assigned for the waitqueue handling, that will always match the correct type. Cc: stable@vger.kernel.org # v5.8+ Reported-by: Pavel Begunkov Signed-off-by: Jens Axboe Signed-off-by: Greg Kroah-Hartman --- fs/io_uring.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) --- a/fs/io_uring.c +++ b/fs/io_uring.c @@ -4786,8 +4786,10 @@ static int io_poll_double_wake(struct wa /* make sure double remove sees this as being gone */ wait->private = NULL; spin_unlock(&poll->head->lock); - if (!done) - __io_async_wake(req, poll, mask, io_poll_task_func); + if (!done) { + /* use wait func handler, so it matches the rq type */ + poll->wait.func(&poll->wait, mode, sync, key); + } } refcount_dec(&req->refs); return 1;