From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-wm1-f48.google.com (mail-wm1-f48.google.com [209.85.128.48]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E017437EFFF for ; Wed, 29 Apr 2026 15:26:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.48 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777476387; cv=none; b=OGyIcf7T5PawvXbSgJcFIXqtPbRWLk+viObBv5BcXfjhKCnS7yDiUYyPQuPRPei4wo1+b7lZQqIqRjftZ6gg8BSe0iDrTrgCJqyD7LIvsZelz/brcEEN4RPQbl9FMCNS369iqJsDYdrv8vFf4JYU+9SydQopBkuEATO3Dou4dUM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777476387; c=relaxed/simple; bh=dwXXUn2/AXYocQMBrxdXlK4QY//00n+FpUG8ksJYzZ4=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=F/CgsZBXttdgqBRuFIGRvhXxvTZX+KSgGE6jDmJ9DIbBMpQIf2ZcB6jO37DS1dau7sfSnrXlmTy6GFR9ncoNvdiNukhRd3VuZ+NqLDvKqSP9xTzcppZg82xBfL6W7VsTxWsLV79COmZXvA3zNpuTREBcirQ+Wvec5KB7ceZ5OE4= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=Q//38A29; arc=none smtp.client-ip=209.85.128.48 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="Q//38A29" Received: by mail-wm1-f48.google.com with SMTP id 5b1f17b1804b1-488af96f6b2so167925865e9.0 for ; Wed, 29 Apr 2026 08:26:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1777476383; x=1778081183; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=Bz5U140iikgjy9qkhQv9ANNAasoYi2fY/CedhAQlGZc=; b=Q//38A29BIyAwvgVfxuarwdkkCIkYkoEgnlCZ1ZWTVC9bBGBlbwjWMLO+PCyW3pZb3 /pU/BZg1FEtUrImeH+eXGiGHqna2ZvIWgk+L6yR86y2B0VdaVlYkeMunR7khoFxE4S8J 0FNUd76MGFcBRZ5OxoP4ajvEzZZMXCSTkGLykLqyP0Ab+gFIXaGbWxh2fVbPdhx2Z9ZJ KEn1sba+9jRPPUOBVsvW0+1xOMEdWejyHJKwKElkTfsdDWcEYtTzEgQw3k+6VtHwcQUk tNSQwq6YhbSfLlBF0fbYnD0bGUK6JS4s8nem1hUMV56iM3cdlycEqDt4GJcUEtO5p6XO 1Mlg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1777476383; x=1778081183; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=Bz5U140iikgjy9qkhQv9ANNAasoYi2fY/CedhAQlGZc=; b=gBIKu1O77BZKLRGRK9XzYacp0tTe+a7ErKOT7RyGAJQ6sd5M7I3CshjLIfuDaV6xsQ ZIkmNYBajQ29RxldLPhbDVNKv+jYkdD3d8wG4RM/opgQofgHEqxwpoTm1ccprIvCdZqN ytw7qmIWx+TI6oIzp9nF50tnbC2jZ7qdCvbUuzvwGq0RxGYCPHlCN70/YbrWry8jeh2E SstjyQQcFChehudHZpoyqsB3/r4a5ejlEI0lTvTj7Go1tLPrQHoGXzFN6aKo65AymTZL k85aTbIRY1kT0GHsdNgedBO5aaaxaC6eNYaLUDyNHmBeZzGUT3ZoZdpAW8EV6R2sWVYj LoRg== X-Forwarded-Encrypted: i=1; AFNElJ9vCYYFE4QNW0+x9vPh1Y/sILjlZ/5kADWvi6ULeiOYs8j9DRf04P6YxOYBy6oNDx+T3diPGob5p274LQ==@vger.kernel.org X-Gm-Message-State: AOJu0YyBfFKZJOAzuvDJKaBKfeHQLsL7RdBZvy++QVqiDghHf6sX40KK vQHRUoMO0NokOvVqe8sW4MM5nzxcAEgocMj7ZOdRWqpxm+SDKu6ztnyO X-Gm-Gg: AeBDievDMh0oHJ+Ork1sxH1npqg5IT8pBZq8ry/iXqZzvHEpiDA39EZ5KIdOWOmAIzq IJP+4NNFS6pH6TzAlE132CqC7q5nOtTQb20Sslc12pGqiL8V3lDJScr/0ra4GE3CMacpVrFNFP4 uRsZ5zjHhuao2zjEsq1c2mc8po0k27iO+MQyMqlMe1RIfmyzA7DaGZD7moXKz8FpnfJ/n5SOpPt /KD2Wtm5yltCk3W2rZOdGkoLDjmJ8ucszUgP3X8gjmxcYUjjfMfULal+hf7gkb0P06HESrNwxel iX77x2geSMD2fr5vm+f+NYAqBBcgQ6zpzUpfbgxT02rgUXOAHbX2RmVnDjXjNy0vzpHXDm7mr4W JdZocmstz3GCTk+VHlv1dTcuvh+ir3oJ/+Mog0iwfF5sfndInNDK3gxmHDe405OggXrxrkuJkN8 f4lGTzXUZLLUGgKaTPlXCQhKzpImd07GjLXFN/QCdCRN6JHbsVKW3SoqGWM2nvteVX+hfuOJgPw dmYGGQGszKzD4N8HF4aqWzqZW3WP+4Gzh3OpOzh28gf X-Received: by 2002:a05:600c:3b13:b0:48a:52ee:5776 with SMTP id 5b1f17b1804b1-48a77ae049fmr129049305e9.11.1777476382406; Wed, 29 Apr 2026 08:26:22 -0700 (PDT) Received: from 127.0.0.1localhost ([82.132.184.31]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-447b76e5c22sm6382951f8f.28.2026.04.29.08.26.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 29 Apr 2026 08:26:21 -0700 (PDT) From: Pavel Begunkov To: Jens Axboe , Keith Busch , Christoph Hellwig , Sagi Grimberg , Alexander Viro , Christian Brauner , Andrew Morton , Sumit Semwal , =?UTF-8?q?Christian=20K=C3=B6nig?= , linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org, linux-fsdevel@vger.kernel.org, io-uring@vger.kernel.org, linux-media@vger.kernel.org, dri-devel@lists.freedesktop.org, linaro-mm-sig@lists.linaro.org Cc: asml.silence@gmail.com, Nitesh Shetty , Kanchan Joshi , Anuj Gupta , Tushar Gohad , William Power , Phil Cayton , Jason Gunthorpe Subject: [PATCH v3 01/10] file: add callback for creating long-term dmabuf maps Date: Wed, 29 Apr 2026 16:25:47 +0100 Message-ID: X-Mailer: git-send-email 2.53.0 In-Reply-To: References: Precedence: bulk X-Mailing-List: linux-media@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Introduce a new file callback that allows creating long-term dma mapping. All necessary information together with a dmabuf will be passed in the second argument of type struct io_dmabuf_token, which will be defined in following patches. Signed-off-by: Pavel Begunkov --- include/linux/fs.h | 2 ++ 1 file changed, 2 insertions(+) diff --git a/include/linux/fs.h b/include/linux/fs.h index b5b01bb22d12..c5558aab4628 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -1920,6 +1920,7 @@ struct dir_context { struct io_uring_cmd; struct offset_ctx; +struct io_dmabuf_token; typedef unsigned int __bitwise fop_flags_t; @@ -1967,6 +1968,7 @@ struct file_operations { int (*uring_cmd_iopoll)(struct io_uring_cmd *, struct io_comp_batch *, unsigned int poll_flags); int (*mmap_prepare)(struct vm_area_desc *); + int (*create_dmabuf_token)(struct file *, struct io_dmabuf_token *); } __randomize_layout; /* Supports async buffered reads */ -- 2.53.0