From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-wr1-f41.google.com (mail-wr1-f41.google.com [209.85.221.41]) (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 9F8B63815E4 for ; Wed, 29 Apr 2026 15:26:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.41 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777476416; cv=none; b=e4lU5FQskGK8tczyPobyEpKPnLEgllrH3D5GIj1By2KoPJ1xg12lhGGQ02F8DSVvt6lxKEobYGbwI8V51ZjR1bss5+eRlr20uyEzCiFmNzRvErUNe3dhWFzXlhyvvzHMdeNscOBQ1TwaMO7sGByyQNw6jcOp4398SXC8xus8Mbs= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777476416; c=relaxed/simple; bh=DL12ZWqeJwgmWM4073U0nNO7Rud8B90RO8c36PxK6lA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=J4QpblFNddbcusYIMOvdiQAR6+Ma+ZSLRQJ0HDQwH5lRtPcSTGUVtChnqaSnY6DpfMNrK33RZhuy2DNqi0sg40al6HlfRIYWR+Pe3jDfW0rxtjzErocCb49frtihkTq8kECNsDnCvLz5AgJsJxf2KDk7SFVEtgJGbTL5aCeC0eo= 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=EevxMA7L; arc=none smtp.client-ip=209.85.221.41 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="EevxMA7L" Received: by mail-wr1-f41.google.com with SMTP id ffacd0b85a97d-43fde5b81a1so9453292f8f.0 for ; Wed, 29 Apr 2026 08:26:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1777476409; x=1778081209; 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=Pdajlfqb0Mkqw7FfTkWcBSlkNtUxKMEiU4sOjeajLqA=; b=EevxMA7LPtKpXQoHdd237w6Vc8pJbzdxm6cjW6PNSoDJlLosPzx0qIFsRDgPYNbdG7 mexMEQ4B7y3zWxfct269nOC9bu4er8Y6GvfmyrrJRneIVajWkRzJhh1B0Y8Rak9y6l8U JBBZfSuG7lH+3EHCHD3CbnDANBUEW90SUEboSu1+/E8aF9lElvHqUuTUTUWwSCv0jTek eB4W4U2CzXvdYQJ0yK9hi/Fd/NnwU9NR9zcOpQpDQbD7Ksp9i/dB9dfdeVbtLEAivF1p rPNP2fBYkQWVm+FyjgRqQaI8WlJvCVhPpVCW/tZ0pIGGuC7zB+WQvEfLOHlCqhvGkBt3 yoHw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1777476409; x=1778081209; 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=Pdajlfqb0Mkqw7FfTkWcBSlkNtUxKMEiU4sOjeajLqA=; b=JV65FV0sRZKVNcYP8LW9fRatMgDzNSmM+XrzWPY1PkhrgrezW1krF9lPKFmbu0m886 VLtBdC4qpAC6L3xwzgM9YHmT4dZLuvLuhqPA3IYuvaxpEP+lWcY0PoaDWElMG9rt1/81 WUkF7uDl9wJlyLJLrPrfYXoJnR+fNGVi0D5A7k8pwoAk/XVXIQXyTXZItM/Rriy60GB9 sFETI38NgwWlyx2bVDC/BYGL4S1KsBonNLotruD7xmDmwFONGb4EenBRNlGhWuuDOkEa bqaLBUwk4vpzQi3adDHcgyIvSfI52qoX2wUs5SYnJ0fbDnt6y4AeUqJzxFB9wYDwmon5 GYmw== X-Forwarded-Encrypted: i=1; AFNElJ/4HEHmc6KIlLrqfqoLDaTlYipCw/ejy89lwUvNhcCmOsLlWmmP/k3DGVT6oaOZ0UMOGTcrZrR1cBDSCwcj@vger.kernel.org X-Gm-Message-State: AOJu0YyZFCC8nMBgmdHFlVh0ErdsxLyvk4AK3j+VfW9cUQ/lXSc0iZT1 5jKaT1tvrJVz4/exksYB2Y3Osnizs1oCm1xuwmJ8/CZghnYTcLgZTcP+ X-Gm-Gg: AeBDiesaHA9ZPkMD/NEdv1c6ngLhvnIaMeJdIYpBqzVfBEwMwngXPVQH+PDOY12McSK /mgTu0n+blxZZtVrKDbm4d2esTn/SO6+6VtHUsEyVzrvd0jJcZnuLgqOd+RitbIjXm5sNL+H9N2 mqhKpIErniLrodAbZj1GTdJKNU4FI2UhB95j7dTVF/VLbXuwNuzF2xtdXrTPyMzS7WzuhfD4nj1 ZaoZ01B83tMqhDzBrcfNcrcsuAqyupv/1rTzN2/vtDnVtEF9ms7ZJbM1lsDTLuz0KKgtC8D6Z5z O3XapJTTfF8hxV7jlVyBxFIraPlNuHi6xMX/L/esfOnTZVwtIV7VvJL3EDESyDybz4a3Rd1gAhx BD1qkDunyBQ1Zcs6Ca8gMLAMq37BDotw+Jkf/I5/x54rHAwKWmq71uEf0QR1FXbF6U6dmYwhZEU iAGEJgKXzpu2Hyavq+H9a3TLwkqgt/9mm/1CYUkkkRU2s0b91pSpi1CUBA7yL8fXn7Lf6qQuEIc Ptfy2+d6LLwlkiGX05PsrqqD1xepg3wSfJtOvG/6K56 X-Received: by 2002:a05:6000:2002:b0:43f:e9ee:5610 with SMTP id ffacd0b85a97d-44790d12be0mr7198547f8f.43.1777476408973; Wed, 29 Apr 2026 08:26:48 -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.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 29 Apr 2026 08:26:48 -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 06/10] block: forward create_dmabuf_token to drivers Date: Wed, 29 Apr 2026 16:25:52 +0100 Message-ID: <559756c5e22dcfa183080a979de039910d1b896d.1777475843.git.asml.silence@gmail.com> X-Mailer: git-send-email 2.53.0 In-Reply-To: References: Precedence: bulk X-Mailing-List: linux-fsdevel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Add a trivial implementation of the create_dmabuf_token call for block devices that forwards the call to a new blk-mq callback if it's available. Signed-off-by: Pavel Begunkov --- block/fops.c | 14 ++++++++++++++ include/linux/blk-mq.h | 9 +++++++++ 2 files changed, 23 insertions(+) diff --git a/block/fops.c b/block/fops.c index 713a3ba3f457..3d8a48a7d645 100644 --- a/block/fops.c +++ b/block/fops.c @@ -951,6 +951,19 @@ static int blkdev_mmap_prepare(struct vm_area_desc *desc) return generic_file_mmap_prepare(desc); } +static int blkdev_create_dmabuf_token(struct file *file, + struct io_dmabuf_token *token) +{ + struct request_queue *q = bdev_get_queue(file_bdev(file)); + + if (!(file->f_flags & O_DIRECT)) + return -EINVAL; + if (!q->mq_ops || !q->mq_ops->create_dmabuf_token) + return -EINVAL; + + return q->mq_ops->create_dmabuf_token(q, token); +} + const struct file_operations def_blk_fops = { .open = blkdev_open, .release = blkdev_release, @@ -969,6 +982,7 @@ const struct file_operations def_blk_fops = { .fallocate = blkdev_fallocate, .uring_cmd = blkdev_uring_cmd, .fop_flags = FOP_BUFFER_RASYNC, + .create_dmabuf_token = blkdev_create_dmabuf_token, }; static __init int blkdev_init(void) diff --git a/include/linux/blk-mq.h b/include/linux/blk-mq.h index 18a2388ba581..ee31fb3ada10 100644 --- a/include/linux/blk-mq.h +++ b/include/linux/blk-mq.h @@ -15,6 +15,8 @@ struct blk_mq_tags; struct blk_flush_queue; struct io_comp_batch; +struct io_dmabuf_token; + #define BLKDEV_MIN_RQ 4 #define BLKDEV_DEFAULT_RQ 128 @@ -684,6 +686,13 @@ struct blk_mq_ops { */ void (*show_rq)(struct seq_file *m, struct request *rq); #endif + + /** + * @create_dma_token: Create a dma token, which will be using to map + * a dmabuf for IO requests. + */ + int (*create_dmabuf_token)(struct request_queue *, + struct io_dmabuf_token *token); }; /* Keep hctx_flag_name[] in sync with the definitions below */ -- 2.53.0