Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp4979726yba; Tue, 30 Apr 2019 07:20:52 -0700 (PDT) X-Google-Smtp-Source: APXvYqxb+a/FuEQeyINCG+3rwWbot4F+/fDWyc1vU6DN67HKPQgpSowW1noMx/5jpA5nO6tuQN1Z X-Received: by 2002:a17:902:7588:: with SMTP id j8mr6491163pll.332.1556634052542; Tue, 30 Apr 2019 07:20:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556634052; cv=none; d=google.com; s=arc-20160816; b=phh4oPoZ+L4ZM8xzd0ip0iakgsM15LZugYNcF18sszqOHmuQ+zAgHM3UdoM89ybx8Y 5NJSnoR9KtdVra2vjjYAw1ZgwLF362eP7Mk+UW3wXFedFxCDqOwTBiniJ4mOdxW5L5p0 gysfgWBfnnfTvEgnk0emMtzJl0u4KIGgJJBxTNgWpe7pNiRPyfhRezZN/BXr6oWUCMej IVQFXn0YKjKQGGglZAbxDMHs3ryka9F3YxStYaVrL9rUZRCdwRn3C2PBHolFuCydgMkG uB/CPx+CRw33fqQZbnWaI5TS3fllQpqPglIG9+bfRBp7e/teUo+vY1oHorm51QGl8uJV IPKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=CqsMVVyOES0C4odcCbtz73DyIJWx76MxEFym4dDPzfc=; b=c6pKP+7+9ko4FsajD5dsB3jPA7+MFbpaUayT6SwZmz2o6bf7hcB5ytDgRSg2kCmqwt 81it0rXnQnqC+/+XiZ69oKSi1gDTinvFgKc7IkQnOJxb4RISXovMmpBuVxHhdfn0QNig 5wjr/Fj5BQFeckCxD9BtpKJqFAQKYISb4z6yDJVCddWYmV5ygC8Gq+fY15wZ8ULpd0B7 6024UQLAvmIjxh5f2jaf28cB4BpEBR9TShajfvQtktg06rfvYLmUVDcVrb4Q+Tb6JGm1 4zRTEL7lFAs+2+UuwbO9q2QDzNYrN2it9BYG6dMYoFA87aBN6LGniRBWZdLCxIJPoa6a nx0w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=CNMgBQRU; 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 be4si21202678plb.131.2019.04.30.07.20.33; Tue, 30 Apr 2019 07:20:52 -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=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=CNMgBQRU; 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 S1727202AbfD3OSN (ORCPT + 99 others); Tue, 30 Apr 2019 10:18:13 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:60538 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726053AbfD3OSM (ORCPT ); Tue, 30 Apr 2019 10:18:12 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=CqsMVVyOES0C4odcCbtz73DyIJWx76MxEFym4dDPzfc=; b=CNMgBQRU/iVW37e8/PFU8IM1b LgC+BEq9Qi1DHL6NkXZcPW1wazFINWWQr+V/Dt/e9lc8nJxlYUoOzjd3YeQm/dApuvaa5Hjgl0jDV +Z/32RruzQKUeppiPYiF7wo5pFGGOif+hJTM17xq/Z0DUWlTdiJkkX89Hc1LY6Kzxk7G29BCQOn1q hXqgXhNF1XCmpID0+5MmhNVlupkFNa4anBX2yCTcyDvM8awLC42rwzTuxZwehxqAVmsmQVk8gHeD9 +18TEXoY3qMZ/Av+TKHWaglGwCeTtxNX/nNfgz+jr1d8ePptWgpwBDPTeRehSUf8anLZMSZDOFstB K/p49i2DQ==; Received: from willy by bombadil.infradead.org with local (Exim 4.90_1 #2 (Red Hat Linux)) id 1hLTaF-0004Jn-3h; Tue, 30 Apr 2019 14:18:11 +0000 Date: Tue, 30 Apr 2019 07:18:10 -0700 From: Matthew Wilcox To: Mark Rutland Cc: Jens Axboe , linux-kernel@vger.kernel.org, Alexander Viro , linux-fsdevel@vger.kernel.org, linux-block@vger.kernel.org Subject: Re: [PATCH] io_uring: avoid page allocation warnings Message-ID: <20190430141810.GF13796@bombadil.infradead.org> References: <20190430132405.8268-1-mark.rutland@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190430132405.8268-1-mark.rutland@arm.com> User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Apr 30, 2019 at 02:24:05PM +0100, Mark Rutland wrote: > In io_sqe_buffer_register() we allocate a number of arrays based on the > iov_len from the user-provided iov. While we limit iov_len to SZ_1G, > we can still attempt to allocate arrays exceeding MAX_ORDER. > > On a 64-bit system with 4KiB pages, for an iov where iov_base = 0x10 and > iov_len = SZ_1G, we'll calculate that nr_pages = 262145. When we try to > allocate a corresponding array of (16-byte) bio_vecs, requiring 4194320 > bytes, which is greater than 4MiB. This results in SLUB warning that > we're trying to allocate greater than MAX_ORDER, and failing the > allocation. > > Avoid this by passing __GFP_NOWARN when allocating arrays for the > user-provided iov_len. We'll gracefully handle the failed allocation, > returning -ENOMEM to userspace. > > We should probably consider lowering the limit below SZ_1G, or reworking > the array allocations. I'd suggest that kvmalloc is probably our friend here ... we don't really want to return -ENOMEM to userspace for this case, I don't think.