From patchwork Mon Mar 10 12:06:11 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Maxime Ripard X-Patchwork-Id: 14009724 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8EEFEC282DE for ; Mon, 10 Mar 2025 12:08:08 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id AA769280009; Mon, 10 Mar 2025 08:08:07 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id A8011280002; Mon, 10 Mar 2025 08:08:07 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 94970280009; Mon, 10 Mar 2025 08:08:07 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id 78942280002 for ; Mon, 10 Mar 2025 08:08:07 -0400 (EDT) Received: from smtpin04.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay03.hostedemail.com (Postfix) with ESMTP id 9175DA967B for ; Mon, 10 Mar 2025 12:08:07 +0000 (UTC) X-FDA: 83205518214.04.65EEF2C Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by imf25.hostedemail.com (Postfix) with ESMTP id 658D4A0019 for ; Mon, 10 Mar 2025 12:06:34 +0000 (UTC) Authentication-Results: imf25.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=D51WTw1v; spf=pass (imf25.hostedemail.com: domain of mripard@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=mripard@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741608394; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=fbiwa3u3rPCsuxWBneJfWNrjnNlIq4MdSt8x0UFdkas=; b=0oHDfGDBHqvJEiT7gjU2lCxeoYr0CwyXmwWFEKAIiEqEn0lUCQaECiu9/yKdi4T5n0uALC 749jf5H1U9W9wyjMYEQoRK5FLZQZjY1VZFWMfY+UmbsxCO3SzleHu0BifAvNrZg55IKqhG VYpvubkT/xGPdFSU/MW90wajcK6Uz3E= ARC-Authentication-Results: i=1; imf25.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=D51WTw1v; spf=pass (imf25.hostedemail.com: domain of mripard@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=mripard@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741608394; a=rsa-sha256; cv=none; b=pNac2EudS/hetbWHf/p5w7yIwd5U1AOZ0Ntz0QSopK3QN28Ans0qG2gtwxeptMgNqD9WgR +KyHdz5rgYswP8WTcDH5zwu9jQB9WLoFY1Bhvu17NGEfz4HKX9HT/v+YYuNdTYJbwcmtrC RMrZmpKsQz5pQCr2eJmFne1cpha5Lmw= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by dfw.source.kernel.org (Postfix) with ESMTP id 2F23F5C5FD8; Mon, 10 Mar 2025 12:04:16 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 1D876C4CEF2; Mon, 10 Mar 2025 12:06:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741608392; bh=Qro4bxDwIqe16ab1F2sB7BE0N7tDo7mzmoJ4I8TRdJo=; h=From:Date:Subject:References:In-Reply-To:To:Cc:From; b=D51WTw1vtvstBl3vA6JvF9mJlq8j1sR8WR9qqmKOGz+7DJOVHwT2Kyu8P57f2urTP CcYglBYtnuHm740POtZsbS+c/avUeR+UJF6Dm89rG4q/w96U7nc3KllbLk3dYYAbcm 7aVwrst/8lH5sL1VUq7gavKQxdqv4Mk/P5S/KKkTbQ2XeEY6Cf7iqmRIp8G7/jsn1G e2aM8hRmquBs3cACUrGaYZkeX0oqiLvQqGDvMp5TTuJpMfP1ECtFpniPlTgDzMm9da 30WiRVu14OryQa/TWUpQxatBX+kELTV279o/nPrT/8j5qdqoMbFDSDO8ckXUVJZGDO LopwJfsypVydw== From: Maxime Ripard Date: Mon, 10 Mar 2025 13:06:11 +0100 Subject: [PATCH RFC 05/12] dma: contiguous: Provide accessor to dmem region MIME-Version: 1.0 Message-Id: <20250310-dmem-cgroups-v1-5-2984c1bc9312@kernel.org> References: <20250310-dmem-cgroups-v1-0-2984c1bc9312@kernel.org> In-Reply-To: <20250310-dmem-cgroups-v1-0-2984c1bc9312@kernel.org> To: Andrew Morton , Marek Szyprowski , Robin Murphy , Sumit Semwal , =?utf-8?q?Christian_K=C3=B6nig?= , Benjamin Gaignard , Brian Starkey , John Stultz , "T.J. Mercier" , Maarten Lankhorst , Thomas Zimmermann , David Airlie , Simona Vetter , Tomasz Figa , Mauro Carvalho Chehab Cc: Hans Verkuil , Laurent Pinchart , linux-mm@kvack.org, linux-kernel@vger.kernel.org, iommu@lists.linux.dev, linux-media@vger.kernel.org, dri-devel@lists.freedesktop.org, linaro-mm-sig@lists.linaro.org, Maxime Ripard X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=1928; i=mripard@kernel.org; h=from:subject:message-id; bh=Qro4bxDwIqe16ab1F2sB7BE0N7tDo7mzmoJ4I8TRdJo=; b=owGbwMvMwCX2+D1vfrpE4FHG02pJDOnnrm6qvuS1X/e7kHRZT3uA1u0ltrJ7v62s3zidrfnc4 uvXokTKO0pZGMS4GGTFFFlihM2XxJ2a9bqTjW8ezBxWJpAhDFycAjCR1EhGht8NTNPURafMNOm7 kfjSL08gJ6V+/YO0W5df7s09yXj3x1SG/xXZzw7vC5rw1We/aXFph+FWnjcK3376mE4Ly39l8N1 SlhkA X-Developer-Key: i=mripard@kernel.org; a=openpgp; fpr=BE5675C37E818C8B5764241C254BCFC56BF6CE8D X-Rspamd-Server: rspam06 X-Rspamd-Queue-Id: 658D4A0019 X-Stat-Signature: c5ab9h8uu6qkpoabtq5q5w7nx4tzh5e8 X-Rspam-User: X-HE-Tag: 1741608394-612605 X-HE-Meta: U2FsdGVkX18jMz31896IRbcEVw7EvcWLVlKg2jLmarugZJA9V3H2S3vqjbIsT/ZC+0DbFO2PcwflUbMQSAPsSV0e87L0af5y/95eLMVIwhK20eXKbG0COaKBycPg6MyPGS6Fsx2er7k1QLgQgrsfJba5rbHu5iWdZ+QVYWTPGdnLWR9OAKzAdFG0Cpb8BO7CojTx2tUtmAoe15FIIg9oIely2tw/nRi6QPK4gXoGSw8pcvU/Abwx0gzBTsmCZdNzEx/cApF+Xog++lFjNJFB/7Vz2r2LYG2pR+zyJ1sWqYB0fFrYAfAfECJapVclldoa280HRj6Eh2ynzHApPJYTqVZgdu2iS6WuuDA3d5aLlYiFEvokMhrmqiT04vwlo+IRhOOF7K/Rl3ZeK/zouxurhseHslfyVKGrm2Bm8cMNGfdgxQpd0jHOKZADoPzQO5uMyM2HDXeiaccnzFRyaI2yaitE61oc3PfyM9STjH5uWAmozzy45HB7KnYhHS+EWEYkWsJCppcoA2GCXOlvW/nFvK75QajFigYu3Mz2Q+21UlLezHjywld/yI1QYDnoQQq2IJkovn32nB1Q9ZXnbOecstTuFdt8fsnQT1xXHcLVCtU9R+PyEn3KiOEZLwfeY2QZMSJ7lQDkQg/z1Du0qXhTp9liFP/yYzETiFDmIhWAyzjbSigrZJfW5t1fobW13IA3AbK3W7lx75cKmKbyM7aNFC2am7H85E4Vbt/IH5f/+sLuxK9cv94AZyPzrQzttt6ZmYR9g2L21LPUvH9k9wNr+Vfuj4Mb0j/KRP/ikdckd3Z4sMHdlC0p6jDBTQuS4/e41hU7iT1I0aahmk/IIAwvjwiEsnkS5+NrZk69RCfvM22wCXRoP4EraXC1gZeBD6MnXxr+oLEpqa/PvDwvC+R6TnJlFf+LGAt+AH75nKWa8dB2+1K3GldHUS9QgySO70Vaxkz7zePzNfzMnwa/RsF ZS3gpMuU sE1kcwl/HiUd9sncRtHLYDKFEK9jSh6HMz2wFM/ekD8Z8xkWIB2tbpa+cXsIxUfTB6O/iTt8NYcKiqaD5SyuLA4v9Ckl9mA9RC0G7NSVvHXYaoWPj5wC/q6+FRffNkx2pYai7GBq5BA4wC30bZ5otWv77YQ54fW/CrZVLzxAX6gCILgWvDi8W/Gj9UhZG8aA0Q4u/9Yy9bz19w/qdBTrCI7S1WE6EeiiWPz5Hw1G8Lj7mJBK51rfiUBxi/HHn2Zez5PQ64D9ZY51mwc7v4uxjqSjMbZ6S+nmvsvWqpEXC4njeZimoFDR+DtOaujoBn6zpV38fkRk/2ZiFuaD1NTlcyr2wo1jVq1eGHeafqLSNDoGyU9k= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Consumers of the DMA contiguous API will have to know which region their device allocates from in order for them to charge the memory allocation in the right one. Let's provide an accessor for that region. Signed-off-by: Maxime Ripard --- include/linux/dma-map-ops.h | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/include/linux/dma-map-ops.h b/include/linux/dma-map-ops.h index a2c10ed186efb6e08f64df0954b4d389589b6e35..bfc928d3bac37f3eece93d152abd57da513a1cc8 100644 --- a/include/linux/dma-map-ops.h +++ b/include/linux/dma-map-ops.h @@ -4,10 +4,11 @@ * It should not be included in drivers just using the DMA API. */ #ifndef _LINUX_DMA_MAP_OPS_H #define _LINUX_DMA_MAP_OPS_H +#include #include #include #include struct cma; @@ -153,10 +154,30 @@ static inline void dma_free_contiguous(struct device *dev, struct page *page, { __free_pages(page, get_order(size)); } #endif /* CONFIG_DMA_CMA*/ +#if IS_ENABLED(CONFIG_DMA_CMA) && IS_ENABLED(CONFIG_CGROUP_DMEM) + +static inline struct dmem_cgroup_region * +dma_contiguous_get_dmem_cgroup_region(struct device *dev) +{ + struct cma *cma = dev_get_cma_area(dev); + + return cma_get_dmem_cgroup_region(cma); +} + +#else /* IS_ENABLED(CONFIG_DMA_CMA) && IS_ENABLED(CONFIG_CGROUP_DMEM) */ + +static inline struct dmem_cgroup_region * +dma_contiguous_get_dmem_cgroup_region(struct device *dev) +{ + return NULL; +} + +#endif /* IS_ENABLED(CONFIG_DMA_CMA) && IS_ENABLED(CONFIG_CGROUP_DMEM) */ + #ifdef CONFIG_DMA_DECLARE_COHERENT int dma_declare_coherent_memory(struct device *dev, phys_addr_t phys_addr, dma_addr_t device_addr, size_t size); void dma_release_coherent_memory(struct device *dev); int dma_alloc_from_dev_coherent(struct device *dev, ssize_t size,