Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4107028imu; Fri, 30 Nov 2018 11:05:53 -0800 (PST) X-Google-Smtp-Source: AFSGD/VVRfOW43NyV5jVb8ktM/iyQy/svqJKxNBh47HkkjRu8bKU0vWoaxavQJo5E3y3LB7F2kgZ X-Received: by 2002:a17:902:3383:: with SMTP id b3mr6682022plc.170.1543604753073; Fri, 30 Nov 2018 11:05:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543604753; cv=none; d=google.com; s=arc-20160816; b=UXURBWOQ23D9MgPljmOA7U5m2xTEblWmVHsS6Er/DsRvcR0ALm2HfyLLCCnkqUkB00 lfxdgNZQlLlqkd4X8MwzEQcZZrdSH1oRqDtRcO0lDDTNvNSidDBb//7CtRiTu6P3eo/8 Bxfq+BskSVQGnk+QAb8pCap45E+9RpwNjDt3eXxqTmGcvIiYuOdD7cVCfr6M8ZxbbZx/ 5y/vbmOVzH5A6AOvPXtVnB3ermUPAvZJm3AgAJknPYH6QzqRFP9guSAm0hGBU4rjpQXs KXvIFYAotPqN9LT+oWzafxdVK1Yaag9Z6FmsNmvwaX56PYHpacnWP0/ybUVGDTwlcj16 Rrug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=qOxmxFqkMuFKTGCKDh/cTtO9maQaMf5ykH2oYe1uh9w=; b=njh49ioJlzN6nenGPIfnSljwraZlJi93r5Mfzte7oh5ML/TpsofC6uRMdmgBtYffg9 OkW2foDJXyDK/tb8Ll9RlMBh1VSHT7fDIGbKoE8eoA5jI6QesYHqq/RigFIJv6No5298 95vPa5/r38sc+F9Ab4RjIXysn/thjaw/ZzPZwUlhqoJSJAchW33MrcYtoXurvX8WspXW LYwRlw1vKB+SJdlMzBHWLVr0iEMYBqAEEe0mq8JHo+kTwRls0N9pSC1/O54ROV1vKONE hHUgU7GxcDkp122NUJD9U3/27t63WuyBktjbKaZabPT6IjkYmYsPVKZsPclKlRXUUfBK 8Tow== ARC-Authentication-Results: i=1; mx.google.com; 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 bh5si5637551plb.42.2018.11.30.11.05.37; Fri, 30 Nov 2018 11:05:53 -0800 (PST) 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; 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 S1726901AbeLAGPK (ORCPT + 99 others); Sat, 1 Dec 2018 01:15:10 -0500 Received: from foss.arm.com ([217.140.101.70]:35082 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726028AbeLAGPK (ORCPT ); Sat, 1 Dec 2018 01:15:10 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 925231682; Fri, 30 Nov 2018 11:04:54 -0800 (PST) Received: from [10.1.196.75] (e110467-lin.cambridge.arm.com [10.1.196.75]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 33D683F575; Fri, 30 Nov 2018 11:04:52 -0800 (PST) Subject: Re: [PATCH 2/9] dma-direct: reject highmem pages from dma_alloc_from_contiguous To: Christoph Hellwig , iommu@lists.linux-foundation.org Cc: Catalin Marinas , Will Deacon , Guo Ren , Laura Abbott , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <20181105121931.13481-1-hch@lst.de> <20181105121931.13481-3-hch@lst.de> From: Robin Murphy Message-ID: Date: Fri, 30 Nov 2018 19:04:51 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <20181105121931.13481-3-hch@lst.de> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/11/2018 12:19, Christoph Hellwig wrote: > dma_alloc_from_contiguous can return highmem pages depending on the > setup, which a plain non-remapping DMA allocator can't handle. Detect > this case and try the normal page allocator instead. ...except the actual implementation is "Detect this case and fail the entire allocation if so". Again, the diff itself makes sense, so given an accurate commit message, Reviewed-by: Robin Murphy > > Signed-off-by: Christoph Hellwig > --- > kernel/dma/direct.c | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/kernel/dma/direct.c b/kernel/dma/direct.c > index 680287779b0a..c49849bcced6 100644 > --- a/kernel/dma/direct.c > +++ b/kernel/dma/direct.c > @@ -162,6 +162,18 @@ void *dma_direct_alloc_pages(struct device *dev, size_t size, > if (!page) > return NULL; > > + if (PageHighMem(page)) { > + /* > + * Depending on the cma= arguments and per-arch setup > + * dma_alloc_from_contiguous could return highmem pages. > + * Without remapping there is no way to return them here, > + * so log an error and fail. > + */ > + dev_info(dev, "Rejecting highmem page from CMA.\n"); > + __dma_direct_free_pages(dev, size, page); > + return NULL; > + } > + > ret = page_address(page); > if (force_dma_unencrypted()) { > set_memory_decrypted((unsigned long)ret, 1 << get_order(size)); >