From mboxrd@z Thu Jan 1 00:00:00 1970 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 bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 7F8591049523 for ; Wed, 11 Mar 2026 09:50:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:Message-ID:Date:Subject:Cc:To:From:Reply-To:Content-Type: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:List-Owner; bh=3c+qlxblsTBEXvZcg0JlOjOHrwtZ50FEnfrmL02pXEs=; b=NdT6mcUYS2E5WjF5lJlILn/0vx UPP6k2HZSH3XrokP86/u+cMNF5Wn0lgOOBjz/NndfyF47HYQuHNU6t78wSQC01PFQmtMT5wam1yY7 JLAEnZ2eOsExL5DuoR5N2M+Dtb9Dzf8yuKtQdJIOS+b8btkzz5bMeaHPmusTPT9sBLlMW43BbqAv1 /OpYqKUQVCcxoJFmxmpTnnScGFa+5ucXlLtSSBOYIsIoaueuToac+0Y0i6Kg9uo/ROZRbRvyEcRTP QKY7cupso+WGcoRgiTJWJZTsab2gYIg364rk3UDEem7uJTwZIUumswMxwN7WfyCyZ/+bg7XhfSu2c LL7eGgjA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux)) id 1w0GCW-0000000BJhI-05rX; Wed, 11 Mar 2026 09:50:00 +0000 Received: from desiato.infradead.org ([2001:8b0:10b:1:d65d:64ff:fe57:4e05]) by bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux)) id 1w0GCV-0000000BJgp-0qhP for linux-mediatek@bombadil.infradead.org; Wed, 11 Mar 2026 09:49:59 +0000 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=desiato.20200630; h=Content-Transfer-Encoding:MIME-Version :Message-ID:Date:Subject:Cc:To:From:Sender:Reply-To:Content-Type:Content-ID: Content-Description:In-Reply-To:References; bh=3c+qlxblsTBEXvZcg0JlOjOHrwtZ50FEnfrmL02pXEs=; b=ATCWUik+RUNuKyjBG95+Fi+CCY +7JpbK4DXDTQlHPaY6EC4Una+i05ud/SOakq2b4jgpHarXGfoRP5DM/Jg6exYXtxHn6mlOmosRKWX XNRkv5GKpDRVtQ01J2I3cv4s82ZDglSo5f5ORw3PV+UacBGZO+blaPNr1RhXktIBpnmZVQKfjwpsf Q5iLldb2N2hxEnc6XhjeGFEcB+3iEly07ykwvxpIhMWuM/UcGJZQYFZF4MUeyCUDIpiFe37DtnuhL 58NkjsOUr9YYKny2zMucOvAFA8gL/xom9IffeqVn2/hXta+nb+1O4iWFPW+r15fB32SGIfkOAXusE UxLPJvsA==; Received: from mail-pf1-x436.google.com ([2607:f8b0:4864:20::436]) by desiato.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux)) id 1w0GCR-0000000Gbe1-2GJI for linux-mediatek@lists.infradead.org; Wed, 11 Mar 2026 09:49:58 +0000 Received: by mail-pf1-x436.google.com with SMTP id d2e1a72fcca58-82984c077b2so3213768b3a.1 for ; Wed, 11 Mar 2026 02:49:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; t=1773222593; x=1773827393; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=3c+qlxblsTBEXvZcg0JlOjOHrwtZ50FEnfrmL02pXEs=; b=PEmnW+xqLdGD02mB3EJcUa5cyJwfbHhkjlQ0OfzajYKWZmY1EWf8og1RWWnrVOHuuK X8kepyg3SkJr0spQ6AYas242eDlRnvRjvfwWOzRP7fkzRkqj2HXaIYyX9+FdZPj7/bF4 YVI1oVVZkYUyQm1Nqr8os8fAifOhoXvVv5LN8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1773222593; x=1773827393; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=3c+qlxblsTBEXvZcg0JlOjOHrwtZ50FEnfrmL02pXEs=; b=aZ3hiQaBoNeeNmGs9ZDYzlJjDGdSaxrGdlmWnsuZgQYi6vvM0ZOcy7tcg8Rzmb5bh+ Z3/+IROwxCB5CPG7hJAJHnrC99jBB62uoIh3Gh+byVHaGP3999y4hBxFO5DqfS85VGCd oHFxB3+kJNt4KKBsBL6J1YdFJ+8Rb33XPp06aHYL6VExb70y7OXfem3WSCbk8PMu4fe/ 0cJEMEcR3oJ211Gn6sZjmZAr9OK+aCCDpfQSNTTT2fqqtB63+ddyLjwjn9Fx9B0svYsM m3zO4m6TT3jbct5j/ASZ53+GZscczlac2WDwc2alDOpnh7gJ2dCS2IXh5TCW0tQ6f6+k DYiQ== X-Forwarded-Encrypted: i=1; AJvYcCV5GLWUCITxtDCRXN/1ZIGKpaVHeLglOjuwC8pejMLRqq5GJ60KeBv7yo2csby0mvz/8XG7sveHS6aV5ytAnw==@lists.infradead.org X-Gm-Message-State: AOJu0Yz53D3QRuAJjWSCkP66+cgWpAMSCOwqHl/JlhYwWnI5Zowue8hu TTA3TIWPSaSaiX3FZeQngRMKmXZSCvKSvyjfVqHkH10Z9hL7Nl8LHhUgnzY+Wj/38w== X-Gm-Gg: ATEYQzznqcWsYiBdTtaCyjp+crHwKr6bqB7qtUs1rwY9HyJARHP3Mz4ziEujF11zYpq DrWuARw5ojE0MKiSEqmwDb3i+rFJTViUEZOgC6/roH0qrLEA3YXghetk5eeIkHBcFHprfyKnkrI X6yRvrQrTm+Z5zMjo5fMWWAVH5KuwfO8oQ9Y9NtXr5PB0nsxFQMmLXYBnqS9H3e0Ktc9Sb2zonC WYmDN5/4Z3ilBTsYsIat92CMsHOpjfBCpd5jWiahSZJKV4VXGCMWRF7I78wqHWdX0eqj+JlqC0z SiEFn4INTXbNH+MxsTwx4MA1SI87YvzOjeo0Zxaq8szBwoR7o+YpSRHhadclrgLZt/6mNkzMDFt R4IpaB0Dughbo+PO4gbv0hA5+pQwe4ojeMH+e/oLzcu7sBst6fCnIYighFMy5gerwcgFTU3UtrY tgs4yfYLYFottHhzfjcQLkPm3B46bdRG6APiUSUk9U+trKqBEjtGyQ1d9LIctiYHpnFhwp+iBNx ZjAJVOn X-Received: by 2002:a05:6a00:7095:b0:81e:7496:f826 with SMTP id d2e1a72fcca58-829f706cc42mr1683975b3a.31.1773222593454; Wed, 11 Mar 2026 02:49:53 -0700 (PDT) Received: from wenstp920.tpe.corp.google.com ([2a00:79e0:201d:8:805b:14e9:f783:bcae]) by smtp.gmail.com with ESMTPSA id d2e1a72fcca58-829f6e22f85sm1887598b3a.27.2026.03.11.02.49.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 11 Mar 2026 02:49:52 -0700 (PDT) From: Chen-Yu Tsai To: Matthias Brugger , AngeloGioacchino Del Regno , Chun-Kuang Hu , Philipp Zabel , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , Chen-Yu Tsai , Jernej Skrabec , Samuel Holland , David Airlie , Simona Vetter Cc: Chen-Yu Tsai , linux-sunxi@lists.linux.dev, Paul Kocialkowski , linux-mediatek@lists.infradead.org, dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 0/4] drm/gem-dma: Support dedicated DMA device for allocation Date: Wed, 11 Mar 2026 17:49:24 +0800 Message-ID: <20260311094929.3393338-1-wenst@chromium.org> X-Mailer: git-send-email 2.53.0.473.g4a7958ca14-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20260311_094956_243486_5FB79073 X-CRM114-Status: GOOD ( 19.47 ) X-BeenThere: linux-mediatek@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "Linux-mediatek" Errors-To: linux-mediatek-bounces+linux-mediatek=archiver.kernel.org@lists.infradead.org Hi folks, This is v2 of my "support dedicated DMA device for allocation and mmap in GEM DMA helpers" series. Changes since v1: - Link to v1: https://lore.kernel.org/all/20260310032511.2545500-1-wenst@chromium.org/ - Collected tags - Removed reference to mtk_gem.c from the Makefile This series expands the "dedicated DMA device" support in DRM to the GEM DMA helpers, and converts the MediaTek DRM driver to setting the DMA device and dropping the custom GEM helpers that implemented this function. Various display drivers implement the "dedicated DMA device" support with custom GEM helpers. These include Exynos, MediaTek, and Rockchip to name a few. Allwinner does something entirely different, calling of_dma_configure() on the virtual display device using the OF node of the actual DMA device. Recently this causes a warning if IOMMUs are involved. The dedicated DMA device is set by calling drm_dev_set_dma_dev(). Any code that does DMA related actions should use drm_dev_dma_dev() to get the DMA device. If a dedicated device was not set, then it shall fall back to the DRM device's underlying device. This series intends to allow the core helpers to deal with it, and not have every driver implement it in slightly different ways, duplicating code. Patch 1 adds dedicated DMA device support to drm_prime_pages_to_sg(). I believe this was missing from the original change that added dedicated DMA devices for PRIME. Patch 2 adds support for dedicated DMA device to the GEM DMA helpers for GEM buffer allocation and mmap. Patch 3 converts the MediaTek DRM driver to use the dedicated DMA device support, and drop all the remaining custom GEM callbacks that deal with it. Patch 4 converts the Allwinner sun4i DRM driver to use the dedicated DMA device support, instead of the of_dma_configure() hack it currently has. The series should be merged through drm-misc-next so that other drivers can take advantage of the change. I also intend to try to convert the Exynos and Rockchip drivers, however both also have options to set DMA_ATTR_NO_KERNEL_MAPPING when using dma_alloc_attrs() to allocate memory for the buffers. I intend to resurrect the DRM_MODE_DUMB_KERNEL_MAP work from Rob Herring [1] to handle this. The Rockchip driver also has custom IOMMU attachment that I'm still trying to understand. Thanks ChenYu Chen-Yu Tsai (4): drm/prime: Limit scatter list size with dedicated DMA device drm/gem-dma: Support dedicated DMA device for allocation and mapping drm/mediatek: Set dedicated DMA device and drop custom GEM callbacks drm/sun4i: Use backend/mixer as dedicated DMA device drivers/gpu/drm/drm_gem_dma_helper.c | 21 ++- drivers/gpu/drm/drm_prime.c | 2 +- drivers/gpu/drm/mediatek/Makefile | 1 - drivers/gpu/drm/mediatek/mtk_crtc.c | 1 - drivers/gpu/drm/mediatek/mtk_drm_drv.c | 21 +-- drivers/gpu/drm/mediatek/mtk_drm_drv.h | 1 - drivers/gpu/drm/mediatek/mtk_gem.c | 231 ------------------------- drivers/gpu/drm/mediatek/mtk_gem.h | 17 -- drivers/gpu/drm/sun4i/sun4i_backend.c | 27 +-- drivers/gpu/drm/sun4i/sun8i_mixer.c | 27 +-- 10 files changed, 46 insertions(+), 303 deletions(-) delete mode 100644 drivers/gpu/drm/mediatek/mtk_gem.c delete mode 100644 drivers/gpu/drm/mediatek/mtk_gem.h -- 2.53.0.473.g4a7958ca14-goog