Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp657812ybt; Wed, 8 Jul 2020 08:37:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwUDY6VtXDkL2Dln47gBYNzT2SixwVmCQF3ch/f5HR7rdoRPlhVc9zRqBnvdUfrJPtcqNCx X-Received: by 2002:a05:6402:359:: with SMTP id r25mr42826515edw.177.1594222637269; Wed, 08 Jul 2020 08:37:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594222637; cv=none; d=google.com; s=arc-20160816; b=pmumy/8PR8MxXVV6g4HkQtsiVjX1C70joZ2QbYHx8iJ3ASrBpgS2+aaTiOADRaRTIU qzzz3E11QyyfZY73SiiLdkxFCGT6GkpHtYKBddW6yfgG9S8+sb1h01ubJ06Rmk3gX2TU Nwgethu9HpmkoB3lJQ2GEE0XvyuY32v44gTV4NFzC+6DNuqkaSmsRKChB0goukaGoDmO 93JEMvaAauTRgXtMTI/+2KPTE7XI+bOQIHedJDXYIOKDZ+YDydwckaTpx/ssqymPVOz1 nf0HZ+aaWhngsFy0tIaJ56ecg1sU2s97SaAh3ByOq0XHOuOZAcwOlHjaw9iEaIWb2TnU UnHA== 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; bh=WtxV41EcadZ2N57DeqYepCEscPUhTKw6kB4IAgWpGuM=; b=whCMSTKzYXvgxMavArt6pJAf4iYJqO52S0MCdtoesaSTYQC0+QmoN/4aDlXGn3+ydS K1OGk7JwTDcGmm2DmK21R3QRstRCVEyhgpXfTOz9mPm/BGprEK9/XYpgG0A26vzGKast h6bfUG6ehoEgQmAAz0USyF+1Xuhm1/AJX5qi7g1deayyCZUburDLN+D3bJ0fFZayaPtZ qsACP3Y3A37lBnnYkEcn/k3+YaVZYa4b2R8E01YBbbWuPI3eqOGdQbMwxYb1wQMpJEVG gp8dOr1KJP/fn9sEeCLCSI+xqodLx8hP9H2zsxmcHRHugEt0tLIrFzf4lvamlil2AMpK 53sg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-ext4-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 j8si132085ejs.237.2020.07.08.08.36.44; Wed, 08 Jul 2020 08:37:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730028AbgGHPfW (ORCPT + 99 others); Wed, 8 Jul 2020 11:35:22 -0400 Received: from mx2.suse.de ([195.135.220.15]:54670 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730237AbgGHPfW (ORCPT ); Wed, 8 Jul 2020 11:35:22 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 6526EABE2; Wed, 8 Jul 2020 15:35:21 +0000 (UTC) Received: by quack2.suse.cz (Postfix, from userid 1000) id C0D951E12BF; Wed, 8 Jul 2020 17:35:20 +0200 (CEST) From: Jan Kara To: Ted Tso Cc: , Jan Kara Subject: [PATCH] ext4: Do not block RWF_NOWAIT dio write on unallocated space Date: Wed, 8 Jul 2020 17:35:16 +0200 Message-Id: <20200708153516.9507-1-jack@suse.cz> X-Mailer: git-send-email 2.16.4 Sender: linux-ext4-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org Since commit 378f32bab371 ("ext4: introduce direct I/O write using iomap infrastructure") we don't properly bail out of RWF_NOWAIT direct IO write if underlying blocks are not allocated. Also ext4_dio_write_checks() does not honor RWF_NOWAIT when re-acquiring i_rwsem. Fix both issues. Fixes: 378f32bab371 ("ext4: introduce direct I/O write using iomap infrastructure") Reported-by: Filipe Manana Signed-off-by: Jan Kara --- fs/ext4/file.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/fs/ext4/file.c b/fs/ext4/file.c index 2a01e31a032c..8f742b53f1d4 100644 --- a/fs/ext4/file.c +++ b/fs/ext4/file.c @@ -428,6 +428,10 @@ static ssize_t ext4_dio_write_checks(struct kiocb *iocb, struct iov_iter *from, */ if (*ilock_shared && (!IS_NOSEC(inode) || *extend || !ext4_overwrite_io(inode, offset, count))) { + if (iocb->ki_flags & IOCB_NOWAIT) { + ret = -EAGAIN; + goto out; + } inode_unlock_shared(inode); *ilock_shared = false; inode_lock(inode); -- 2.16.4