From patchwork Mon Apr 30 16:57:40 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Adam Manzanares X-Patchwork-Id: 10372131 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 10B646038F for ; Mon, 30 Apr 2018 16:58:27 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 01473223C7 for ; Mon, 30 Apr 2018 16:58:27 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id E70812853C; Mon, 30 Apr 2018 16:58:26 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-7.8 required=2.0 tests=BAYES_00,DKIM_SIGNED, MAILING_LIST_MULTI, RCVD_IN_DNSWL_HI, T_DKIM_INVALID autolearn=unavailable version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 76888223C7 for ; Mon, 30 Apr 2018 16:58:26 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755108AbeD3Q6A (ORCPT ); Mon, 30 Apr 2018 12:58:00 -0400 Received: from esa2.hgst.iphmx.com ([68.232.143.124]:20729 "EHLO esa2.hgst.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755107AbeD3Q56 (ORCPT ); Mon, 30 Apr 2018 12:57:58 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=wdc.com; i=@wdc.com; q=dns/txt; s=dkim.wdc.com; t=1525107683; x=1556643683; h=from:to:cc:subject:date:message-id:in-reply-to: references; bh=OiKVJK7yMH87rfYVbFa8QHZ9Fzaf6dmfVlokFKIwPdk=; b=IMoONvMcbjQ85pavKLokfsxyzUTfDYnOta/ytzC100Gisaj5YRNW9naz pZCjgtyCzP0SxwQDrljI186HYsrxH33OiE0CCeLYF/xs2hbzMvfiPCdIy LUs7s9nxAILju0G3GO1effRDOOO/gu1HL+s7zq+QKxy6aa6z25jTEfFFA xBUx8MkBSMz+QtmTlkbJ4Gu0wYSIOxRX2FXaNzAyX5PAU3YX3kUmfLSXw S0WilMGGO9XBLLE6+dMgoPRDxfeav4kNafYKW/J7x+fWoz+50ASB7CsU/ UIVUmaQWpyhCd0oAaZrhM7VE98Kba5oOdu+9ONCLO9SVqJgE173RD+yO4 g==; X-IronPort-AV: E=Sophos;i="5.49,346,1520870400"; d="scan'208";a="173714670" Received: from h199-255-45-15.hgst.com (HELO uls-op-cesaep02.wdc.com) ([199.255.45.15]) by ob1.hgst.iphmx.com with ESMTP; 01 May 2018 01:01:22 +0800 Received: from uls-op-cesaip02.wdc.com ([10.248.3.37]) by uls-op-cesaep02.wdc.com with ESMTP; 30 Apr 2018 09:49:18 -0700 Received: from penguito-adamm.sdcorp.global.sandisk.com ([10.11.47.13]) by uls-op-cesaip02.wdc.com with ESMTP; 30 Apr 2018 09:57:58 -0700 From: adam.manzanares@wdc.com To: viro@zeniv.linux.org.uk, bcrl@kvack.org Cc: linux-fsdevel@vger.kernel.org, linux-aio@kvack.org, linux-abi-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org, Adam Manzanares Subject: [PATCH 2/2] fs: Add aio priority support for block_dev Date: Mon, 30 Apr 2018 09:57:40 -0700 Message-Id: <20180430165740.2842-3-adam.manzanares@wdc.com> X-Mailer: git-send-email 2.15.1 In-Reply-To: <20180430165740.2842-1-adam.manzanares@wdc.com> References: <20180430165740.2842-1-adam.manzanares@wdc.com> Sender: linux-fsdevel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-fsdevel@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: Adam Manzanares When the IOCB_IOPRIO flag is set because the user supplied iocb has the RWF_IOPRIO flag is set then we set the priority value of the kiocb from the iocb. When a bio is created for an aio request by the block dev we set the priority value of the bio to the user supplied value. Signed-off-by: Adam Manzanares --- fs/aio.c | 9 +++++++++ fs/block_dev.c | 1 + 2 files changed, 10 insertions(+) diff --git a/fs/aio.c b/fs/aio.c index 88d7927ffbc6..47591f9e7ba3 100644 --- a/fs/aio.c +++ b/fs/aio.c @@ -1603,6 +1603,15 @@ static int io_submit_one(struct kioctx *ctx, struct iocb __user *user_iocb, goto out_put_req; } + if (req->common.ki_flags & IOCB_IOPRIO) + /* + * The IOCB_IOPRIO flag is set when the user supplied iocb + * aio_rw_flag field has the RWF_IOPRIO flag set. If so, + * aio_reqprio is interpreted as a I/O scheduling class and + * priority. + */ + req->common.ki_ioprio = iocb->aio_reqprio; + ret = put_user(KIOCB_KEY, &user_iocb->aio_key); if (unlikely(ret)) { pr_debug("EFAULT: aio_key\n"); diff --git a/fs/block_dev.c b/fs/block_dev.c index 7ec920e27065..da1e94d2bb75 100644 --- a/fs/block_dev.c +++ b/fs/block_dev.c @@ -355,6 +355,7 @@ __blkdev_direct_IO(struct kiocb *iocb, struct iov_iter *iter, int nr_pages) bio->bi_write_hint = iocb->ki_hint; bio->bi_private = dio; bio->bi_end_io = blkdev_bio_end_io; + bio->bi_ioprio = iocb->ki_ioprio; ret = bio_iov_iter_get_pages(bio, iter); if (unlikely(ret)) {