From: sashiko-bot@kernel.org
To: "Krzysztof Wilczyński" <kwilczynski@kernel.org>
Cc: linux-pci@vger.kernel.org
Subject: Re: [PATCH v7 06/24] PCI/sysfs: Add static PCI resource attribute macros
Date: Fri, 08 May 2026 05:23:12 +0000 [thread overview]
Message-ID: <20260508052312.E8516C2BCB0@smtp.kernel.org> (raw)
In-Reply-To: <20260508043543.217179-7-kwilczynski@kernel.org>
Thank you for your contribution! Sashiko AI review found 2 potential issue(s) to consider:
- [Critical] The `pci_dev_resource_io_attr` macro leaves the `.size` field of the binary attribute uninitialized (0), disabling VFS bounds checking. This allows arbitrary offsets that truncate on 32-bit architectures, enabling read/write access to arbitrary I/O ports.
- [High] The `pci_dev_resource_io_attr` macro conditionally omits the `.llseek` callback on architectures without I/O mmap support (like x86 and arm64), causing `lseek(SEEK_END)` to incorrectly return 0 for I/O BAR sysfs files.
--
commit 2bb0cfc5ea48584962711dffb2f762f594fd8374
Author: Krzysztof Wilczyński <kwilczynski@kernel.org>
PCI/sysfs: Add static PCI resource attribute macros
This patch adds macros for declaring static binary attributes for PCI
resource files, setting specific callbacks based on the resource type.
It conditionally includes mmap support for I/O BAR resources based on
arch_can_pci_mmap_io().
> diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c
> --- a/drivers/pci/pci-sysfs.c
> +++ b/drivers/pci/pci-sysfs.c
[ ... ]
> @@ -1197,6 +1197,47 @@ static ssize_t pci_write_resource_io(struct file *filp, struct kobject *kobj,
> return pci_resource_io(filp, kobj, attr, buf, off, count, true);
> }
>
> +/*
> + * generic_file_llseek() consults f_mapping->host to determine
> + * the file size. As iomem_inode knows nothing about the
> + * attribute, it's not going to work, so override it as well.
> + */
> +#if arch_can_pci_mmap_io()
> +# define __PCI_RESOURCE_IO_MMAP_ATTRS \
> + .f_mapping = iomem_get_mapping, \
> + .llseek = pci_llseek_resource, \
> + .mmap = pci_mmap_resource_uc,
> +#else
> +# define __PCI_RESOURCE_IO_MMAP_ATTRS
> +#endif
On architectures where arch_can_pci_mmap_io() is false (such as x86 and arm64),
__PCI_RESOURCE_IO_MMAP_ATTRS evaluates to empty, meaning .llseek is left as
NULL.
Since these are static attributes, their .size field defaults to 0. When
.llseek is NULL, sysfs_kf_bin_llseek() falls back to generic_file_llseek().
Because the inode size is 0, will lseek(fd, 0, SEEK_END) incorrectly return
0 instead of the actual resource length, potentially breaking userspace tools
like pciutils?
Should .llseek = pci_llseek_resource be defined unconditionally to ensure
the correct dynamic resource length is computed?
> +
> +#define pci_dev_resource_io_attr(_bar) \
> +static const struct bin_attribute dev_resource##_bar##_io_attr = { \
> + .attr = { .name = "resource" __stringify(_bar), .mode = 0600 }, \
> + .private = (void *)(unsigned long)(_bar), \
> + .read = pci_read_resource_io, \
> + .write = pci_write_resource_io, \
> + __PCI_RESOURCE_IO_MMAP_ATTRS \
> +}
Because the .size field of this static bin_attribute is uninitialized (0),
VFS bounds checks in sysfs_kf_bin_read() and sysfs_kf_bin_write() are
disabled.
If an arbitrarily large 64-bit positive file offset is passed via pread(),
does this offset truncate on 32-bit architectures?
Looking at pci_resource_io():
static ssize_t pci_resource_io(struct file *filp, struct kobject *kobj,
const struct bin_attribute *attr, char *buf,
loff_t off, size_t count, bool write)
{
#ifdef CONFIG_HAS_IOPORT
...
unsigned long port = off;
...
port += pci_resource_start(pdev, bar);
if (port > pci_resource_end(pdev, bar))
return 0;
...
}
Could a 64-bit offset be crafted such that when truncated to 32 bits, it
becomes a negative value that exactly offsets pci_resource_start(pdev, bar)?
This would cause port to wrap around to a targeted port value.
Since the upper-bound check against pci_resource_end() would then pass,
and there is no lower-bound check, does this allow reading or writing any
physical I/O port between 0 and pci_resource_end?
--
Sashiko AI review · https://sashiko.dev/#/patchset/20260508043543.217179-1-kwilczynski@kernel.org?part=6
next prev parent reply other threads:[~2026-05-08 5:23 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-08 4:35 [PATCH v7 00/24] PCI: Convert all dynamic sysfs attributes to static Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 01/24] PCI/sysfs: Use PCI resource accessor macros Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 02/24] PCI: Add pci_resource_is_io() and pci_resource_is_mem() helpers Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 03/24] PCI/sysfs: Only allow supported resource types in I/O and MMIO helpers Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 04/24] PCI/sysfs: Split pci_llseek_resource() for device and legacy attributes Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 05/24] PCI/sysfs: Add CAP_SYS_ADMIN check to __resource_resize_store() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 06/24] PCI/sysfs: Add static PCI resource attribute macros Krzysztof Wilczyński
2026-05-08 5:23 ` sashiko-bot [this message]
2026-05-08 4:35 ` [PATCH v7 07/24] PCI/sysfs: Convert PCI resource files to static attributes Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 08/24] PCI/sysfs: Warn about BAR resize failure in __resource_resize_store() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 09/24] PCI/sysfs: Add stubs for pci_{create,remove}_sysfs_dev_files() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 10/24] PCI/sysfs: Limit pci_sysfs_init() late_initcall compile scope Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 11/24] alpha/PCI: Add security_locked_down() check to pci_mmap_resource() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 12/24] alpha/PCI: Use BAR index in sysfs attr->private instead of resource pointer Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 13/24] alpha/PCI: Use PCI resource accessor macros Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 14/24] alpha/PCI: Fix __pci_mmap_fits() overflow for zero-length BARs Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 15/24] alpha/PCI: Remove WARN from __pci_mmap_fits() and __legacy_mmap_fits() Krzysztof Wilczyński
2026-05-08 4:54 ` sashiko-bot
2026-05-08 5:04 ` Krzysztof Wilczyński
2026-05-08 23:07 ` Bjorn Helgaas
2026-05-11 7:14 ` Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 16/24] alpha/PCI: Add static PCI resource attribute macros Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 17/24] alpha/PCI: Convert resource files to static attributes Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 18/24] PCI/sysfs: Remove pci_{create,remove}_sysfs_dev_files() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 19/24] PCI: Add macros for legacy I/O and memory address space sizes Krzysztof Wilczyński
2026-05-08 5:09 ` sashiko-bot
2026-05-08 4:35 ` [PATCH v7 20/24] alpha/PCI: Compute legacy size in pci_mmap_legacy_page_range() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 21/24] PCI/sysfs: Add __weak pci_legacy_has_sparse() helper Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 22/24] PCI/sysfs: Convert legacy I/O and memory attributes to static definitions Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 23/24] PCI/sysfs: Remove pci_create_legacy_files() and pci_sysfs_init() Krzysztof Wilczyński
2026-05-08 4:35 ` [PATCH v7 24/24] PCI/sysfs: Limit BAR resize attribute scope to platforms with PCI mmap Krzysztof Wilczyński
2026-05-08 23:00 ` [PATCH v7 00/24] PCI: Convert all dynamic sysfs attributes to static Bjorn Helgaas
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=20260508052312.E8516C2BCB0@smtp.kernel.org \
--to=sashiko-bot@kernel.org \
--cc=kwilczynski@kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=sashiko@lists.linux.dev \
/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