diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2025-10-01 18:39:23 +0300 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2025-10-01 18:39:23 +0300 | 
| commit | eb3289fc474f74105e0627bf508e3f9742fd3b63 (patch) | |
| tree | 4ddfef8ea4474f6677d020c3efc66cc77eb82724 /rust/helpers/pci.c | |
| parent | 50c19e20ed2ef359cf155a39c8462b0a6351b9fa (diff) | |
| parent | 6d97171ac6585de698df019b0bfea3f123fd8385 (diff) | |
| download | linux-eb3289fc474f74105e0627bf508e3f9742fd3b63.tar.xz | |
Merge tag 'driver-core-6.18-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/driver-core/driver-core
Pull driver core updates from Danilo Krummrich:
 "Auxiliary:
   - Drop call to dev_pm_domain_detach() in auxiliary_bus_probe()
   - Optimize logic of auxiliary_match_id()
  Rust:
   - Auxiliary:
      - Use primitive C types from prelude
   - DebugFs:
      - Add debugfs support for simple read/write files and custom
        callbacks through a File-type-based and directory-scope-based
        API
      - Sample driver code for the File-type-based API
      - Sample module code for the directory-scope-based API
   - I/O:
      - Add io::poll module and implement Rust specific
        read_poll_timeout() helper
   - IRQ:
      - Implement support for threaded and non-threaded device IRQs
        based on (&Device<Bound>, IRQ number) tuples (IrqRequest)
      - Provide &Device<Bound> cookie in IRQ handlers
   - PCI:
      - Support IRQ requests from IRQ vectors for a specific
        pci::Device<Bound>
      - Implement accessors for subsystem IDs, revision, devid and
        resource start
      - Provide dedicated pci::Vendor and pci::Class types for vendor
        and class ID numbers
      - Implement Display to print actual vendor and class names; Debug
        to print the raw ID numbers
      - Add pci::DeviceId::from_class_and_vendor() helper
      - Use primitive C types from prelude
      - Various minor inline and (safety) comment improvements
   - Platform:
      - Support IRQ requests from IRQ vectors for a specific
        platform::Device<Bound>
   - Nova:
      - Use pci::DeviceId::from_class_and_vendor() to avoid probing
        non-display/compute PCI functions
   - Misc:
      - Add helper for cpu_relax()
      - Update ARef import from sync::aref
  sysfs:
   - Remove bin_attrs_new field from struct attribute_group
   - Remove read_new() and write_new() from struct bin_attribute
  Misc:
   - Document potential race condition in get_dev_from_fwnode()
   - Constify node_group argument in software node registration
     functions
   - Fix order of kernel-doc parameters in various functions
   - Set power.no_pm flag for faux devices
   - Set power.no_callbacks flag along with the power.no_pm flag
   - Constify the pmu_bus bus type
   - Minor spelling fixes"
* tag 'driver-core-6.18-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/driver-core/driver-core: (43 commits)
  rust: pci: display symbolic PCI vendor names
  rust: pci: display symbolic PCI class names
  rust: pci: fix incorrect platform reference in PCI driver probe doc comment
  rust: pci: fix incorrect platform reference in PCI driver unbind doc comment
  perf: make pmu_bus const
  samples: rust: Add scoped debugfs sample driver
  rust: debugfs: Add support for scoped directories
  samples: rust: Add debugfs sample driver
  rust: debugfs: Add support for callback-based files
  rust: debugfs: Add support for writable files
  rust: debugfs: Add support for read-only files
  rust: debugfs: Add initial support for directories
  driver core: auxiliary bus: Optimize logic of auxiliary_match_id()
  driver core: auxiliary bus: Drop dev_pm_domain_detach() call
  driver core: Fix order of the kernel-doc parameters
  driver core: get_dev_from_fwnode(): document potential race
  drivers: base: fix "publically"->"publicly"
  driver core/PM: Set power.no_callbacks along with power.no_pm
  driver core: faux: Set power.no_pm for faux devices
  rust: pci: inline several tiny functions
  ...
Diffstat (limited to 'rust/helpers/pci.c')
| -rw-r--r-- | rust/helpers/pci.c | 18 | 
1 files changed, 18 insertions, 0 deletions
| diff --git a/rust/helpers/pci.c b/rust/helpers/pci.c index ef9cb38c81a6..fb814572b236 100644 --- a/rust/helpers/pci.c +++ b/rust/helpers/pci.c @@ -2,6 +2,16 @@  #include <linux/pci.h> +u16 rust_helper_pci_dev_id(struct pci_dev *dev) +{ +	return PCI_DEVID(dev->bus->number, dev->devfn); +} + +resource_size_t rust_helper_pci_resource_start(struct pci_dev *pdev, int bar) +{ +	return pci_resource_start(pdev, bar); +} +  resource_size_t rust_helper_pci_resource_len(struct pci_dev *pdev, int bar)  {  	return pci_resource_len(pdev, bar); @@ -11,3 +21,11 @@ bool rust_helper_dev_is_pci(const struct device *dev)  {  	return dev_is_pci(dev);  } + +#ifndef CONFIG_PCI_MSI +int rust_helper_pci_irq_vector(struct pci_dev *pdev, unsigned int nvec) +{ +	return pci_irq_vector(pdev, nvec); +} + +#endif | 
