public inbox for drm-ai-reviews@public-inbox.freedesktop.org
 help / color / mirror / Atom feed
From: Claude Code Review Bot <claude-review@example.com>
To: dri-devel-reviews@example.com
Subject: Claude review: nvme-pci: implement dma_token backed requests
Date: Tue, 05 May 2026 11:26:01 +1000	[thread overview]
Message-ID: <review-patch7-5cecb1157ab784f9f303a91449fdf11b03aa6002.1777475843.git.asml.silence@gmail.com> (raw)
In-Reply-To: <5cecb1157ab784f9f303a91449fdf11b03aa6002.1777475843.git.asml.silence@gmail.com>

Patch Review

The largest patch, implementing the NVMe PCI backend for dmabuf-backed I/O.

**Bug: Wrong `sizeof` in `nvme_create_dmabuf_token`**

```c
data = kzalloc(sizeof(data), GFP_KERNEL);
```

This allocates `sizeof(struct nvme_dmabuf_token *)` (a pointer, 8 bytes) instead of `sizeof(struct nvme_dmabuf_token)` (the struct itself). Should be:
```c
data = kzalloc(sizeof(*data), GFP_KERNEL);
```

`struct nvme_dmabuf_token` contains a `struct dma_buf_attachment *`, which is also 8 bytes, so on 64-bit this happens to allocate just enough memory by coincidence, but it's still wrong and fragile.

**Resource leak: `nvme_create_dmabuf_token` error path**

```c
data = kzalloc(sizeof(data), GFP_KERNEL);
if (!data)
    return -ENOMEM;

token->dev_priv = data;
token->dev_ops = &nvme_dma_token_ops;

attach = dma_buf_dynamic_attach(dmabuf, dev->dev,
                &nvme_dmabuf_importer_ops, token);
if (IS_ERR(attach))
    return PTR_ERR(attach);
```

If `dma_buf_dynamic_attach` fails, `data` is leaked (it was `kzalloc`'d but never freed). The caller (`io_dmabuf_token_create`) does `memset(token, 0, sizeof(*token))` and `dma_buf_put(dmabuf)` on failure, but `data` is orphaned. This should `kfree(data)` before returning.

**Potential out-of-bounds in `nvme_dmabuf_token_map`**

```c
nr_entries = token->dmabuf->size / NVME_CTRL_PAGE_SIZE;
dma_list = kmalloc_array(nr_entries, sizeof(dma_list[0]), GFP_KERNEL);
...
while (sg_len) {
    dma_list[i++] = dma_addr;
```

If the scatter-gather entries don't align perfectly with the pre-computed `nr_entries`, `i` could exceed `nr_entries`. The `sg_len % NVME_CTRL_PAGE_SIZE` check prevents this for individual entries, but there's no check that the total SG length matches `dmabuf->size`. If the DMA mapping coalesces or splits pages differently, this could overflow.

**DMA sync granularity**

```c
while (length > 0) {
    u64 dma_addr = dma_list[map_idx++];
    ...
    length -= NVME_CTRL_PAGE_SIZE;
}
```

The sync loop always syncs full `NVME_CTRL_PAGE_SIZE` chunks, even for the last partial page. This is fine for correctness (syncing extra doesn't hurt) but the loop doesn't account for a negative `length` at the start (from a partial first page), which is handled by the `length += offset & (NVME_CTRL_PAGE_SIZE - 1)` adjustment.

---

---
Generated by Claude Code Patch Reviewer

  parent reply	other threads:[~2026-05-05  1:26 UTC|newest]

Thread overview: 28+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-04-29 15:25 [PATCH v3 00/10] Add dmabuf read/write via io_uring Pavel Begunkov
2026-04-29 15:25 ` [PATCH v3 01/10] file: add callback for creating long-term dmabuf maps Pavel Begunkov
2026-04-30  6:03   ` Christian König
2026-04-30 18:33     ` Pavel Begunkov
2026-05-04  7:14       ` Christian König
2026-05-05  1:25   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 02/10] iov_iter: add iterator type for " Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 03/10] block: move bvec init into __bio_clone Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 04/10] block: introduce dma map backed bio type Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 05/10] lib: add dmabuf token infrastructure Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 06/10] block: forward create_dmabuf_token to drivers Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 07/10] nvme-pci: implement dma_token backed requests Pavel Begunkov
2026-04-29 15:29   ` Pavel Begunkov
2026-04-29 16:07   ` Maurizio Lombardi
2026-04-30 18:18     ` Pavel Begunkov
2026-05-05  1:26   ` Claude Code Review Bot [this message]
2026-04-29 15:25 ` [PATCH v3 08/10] io_uring/rsrc: introduce buf registration structure Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 09/10] io_uring/rsrc: extend buffer update Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-04-29 15:25 ` [PATCH v3 10/10] io_uring/rsrc: add dmabuf backed registered buffers Pavel Begunkov
2026-05-05  1:26   ` Claude review: " Claude Code Review Bot
2026-05-05  1:25 ` Claude review: Add dmabuf read/write via io_uring Claude Code Review Bot

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=review-patch7-5cecb1157ab784f9f303a91449fdf11b03aa6002.1777475843.git.asml.silence@gmail.com \
    --to=claude-review@example.com \
    --cc=dri-devel-reviews@example.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox