diff options
| author | John Hubbard <jhubbard@nvidia.com> | 2025-09-24 18:33:58 -0700 | 
|---|---|---|
| committer | Danilo Krummrich <dakr@kernel.org> | 2025-09-25 15:51:16 +0200 | 
| commit | d53ea977adf913a6e5024323e6b7e02326d4453c (patch) | |
| tree | 18edfdeebfe4d8cd8735784f0245cb8ffb538ae9 /rust/kernel | |
| parent | 855318e7c0c4a3e3014c0469dd5bc93a1c0df30c (diff) | |
rust: pci: display symbolic PCI class names
The Display implementation for Class was forwarding directly to Debug
printing, resulting in raw hex values instead of PCI Class strings.
Improve things by doing a stringify!() call for each PCI Class item.
This now prints symbolic names such as "DISPLAY_VGA", instead of
"Class(0x030000)". It still falls back to Debug formatting for unknown
class values.
Suggested-by: Danilo Krummrich <dakr@kernel.org>
Signed-off-by: John Hubbard <jhubbard@nvidia.com>
Reviewed-by: Alexandre Courbot <acourbot@nvidia.com>
Signed-off-by: Danilo Krummrich <dakr@kernel.org>
Diffstat (limited to 'rust/kernel')
| -rw-r--r-- | rust/kernel/pci/id.rs | 17 | 
1 files changed, 11 insertions, 6 deletions
| diff --git a/rust/kernel/pci/id.rs b/rust/kernel/pci/id.rs index 8ee1dc5c3057..6e081de30faf 100644 --- a/rust/kernel/pci/id.rs +++ b/rust/kernel/pci/id.rs @@ -50,6 +50,17 @@ macro_rules! define_all_pci_classes {                  pub const $variant: Self = Self(Self::to_24bit_class($binding));              )+          } + +        impl fmt::Display for Class { +            fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { +                match self { +                    $( +                        &Self::$variant => write!(f, stringify!($variant)), +                    )+ +                    _ => <Self as fmt::Debug>::fmt(self, f), +                } +            } +        }      };  } @@ -87,12 +98,6 @@ impl fmt::Debug for Class {      }  } -impl fmt::Display for Class { -    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { -        <Self as fmt::Debug>::fmt(self, f) -    } -} -  impl ClassMask {      /// Get the raw mask value.      #[inline] | 
