* [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages @ 2026-03-23 6:52 Lukas Wunner 2026-03-23 11:03 ` Mika Westerberg 2026-03-23 16:50 ` Bjorn Helgaas 0 siblings, 2 replies; 8+ messages in thread From: Lukas Wunner @ 2026-03-23 6:52 UTC (permalink / raw) To: Bjorn Helgaas Cc: Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Ilpo Jarvinen, Maciej Grochowski, Kai-Heng Feng The prefix/header of the TLP that caused an error is recorded by the Root Complex and emitted to the kernel log in raw hex format. Document the existence and usage of tlp-tool, which allows decoding the TLP Header into human-readable form. The TLP Header hints at the root cause of an error, yet is often ignored because of its seeming opaqueness. Instead, PCIe errors are frequently worked around by a change in the kernel without fully understanding the actual source of the problem. With more documentation on available tools we'll hopefully come up with better solutions. There are also wireshark dissectors for TLPs, but it seems they expect a complete TLP, not just the header, and they cannot grok the hex format emitted by the kernel directly. tlp-tool appears to be the most cut and dried solution out there. Signed-off-by: Lukas Wunner <lukas@wunner.de> Cc: Maciej Grochowski <mx2pg@pm.me> --- We could also go one step further and point users to this tool in a printk_once() message when the first error occurs. For now, just amending the documentation is probably sufficient. Documentation/PCI/pcieaer-howto.rst | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/Documentation/PCI/pcieaer-howto.rst b/Documentation/PCI/pcieaer-howto.rst index 3210c47..90fdfdd 100644 --- a/Documentation/PCI/pcieaer-howto.rst +++ b/Documentation/PCI/pcieaer-howto.rst @@ -85,6 +85,16 @@ In the example, 'Requester ID' means the ID of the device that sent the error message to the Root Port. Please refer to PCIe specs for other fields. +The 'TLP Header' is the prefix/header of the TLP that caused the error +in raw hex format. To decode the TLP Header into human-readable form +one may use tlp-tool: + +https://github.com/mmpg-x86/tlp-tool + +Example usage:: + + curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer + AER Ratelimits -------------- -- 2.51.0 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-23 6:52 [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages Lukas Wunner @ 2026-03-23 11:03 ` Mika Westerberg 2026-03-23 16:50 ` Bjorn Helgaas 1 sibling, 0 replies; 8+ messages in thread From: Mika Westerberg @ 2026-03-23 11:03 UTC (permalink / raw) To: Lukas Wunner Cc: Bjorn Helgaas, Jonathan Corbet, linux-pci, linux-doc, Ilpo Jarvinen, Maciej Grochowski, Kai-Heng Feng On Mon, Mar 23, 2026 at 07:52:39AM +0100, Lukas Wunner wrote: > The prefix/header of the TLP that caused an error is recorded by the Root > Complex and emitted to the kernel log in raw hex format. Document the > existence and usage of tlp-tool, which allows decoding the TLP Header > into human-readable form. > > The TLP Header hints at the root cause of an error, yet is often ignored > because of its seeming opaqueness. Instead, PCIe errors are frequently > worked around by a change in the kernel without fully understanding the > actual source of the problem. With more documentation on available tools > we'll hopefully come up with better solutions. > > There are also wireshark dissectors for TLPs, but it seems they expect a > complete TLP, not just the header, and they cannot grok the hex format > emitted by the kernel directly. tlp-tool appears to be the most cut and > dried solution out there. > > Signed-off-by: Lukas Wunner <lukas@wunner.de> > Cc: Maciej Grochowski <mx2pg@pm.me> Good idea, this is useful. Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com> ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-23 6:52 [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages Lukas Wunner 2026-03-23 11:03 ` Mika Westerberg @ 2026-03-23 16:50 ` Bjorn Helgaas 2026-03-24 5:53 ` mx2pg 1 sibling, 1 reply; 8+ messages in thread From: Bjorn Helgaas @ 2026-03-23 16:50 UTC (permalink / raw) To: Lukas Wunner Cc: Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Ilpo Jarvinen, Maciej Grochowski, Kai-Heng Feng On Mon, Mar 23, 2026 at 07:52:39AM +0100, Lukas Wunner wrote: > The prefix/header of the TLP that caused an error is recorded by the Root > Complex and emitted to the kernel log in raw hex format. Document the > existence and usage of tlp-tool, which allows decoding the TLP Header > into human-readable form. > > The TLP Header hints at the root cause of an error, yet is often ignored > because of its seeming opaqueness. Instead, PCIe errors are frequently > worked around by a change in the kernel without fully understanding the > actual source of the problem. With more documentation on available tools > we'll hopefully come up with better solutions. > > There are also wireshark dissectors for TLPs, but it seems they expect a > complete TLP, not just the header, and they cannot grok the hex format > emitted by the kernel directly. tlp-tool appears to be the most cut and > dried solution out there. > > Signed-off-by: Lukas Wunner <lukas@wunner.de> > Cc: Maciej Grochowski <mx2pg@pm.me> Applied to pci/for-linus for v7.0, thanks! I tweaked the commit log to note that the Header Log is in the AER Capability, which may be in any PCIe function. > --- > We could also go one step further and point users to this tool > in a printk_once() message when the first error occurs. > For now, just amending the documentation is probably sufficient. > > Documentation/PCI/pcieaer-howto.rst | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/Documentation/PCI/pcieaer-howto.rst b/Documentation/PCI/pcieaer-howto.rst > index 3210c47..90fdfdd 100644 > --- a/Documentation/PCI/pcieaer-howto.rst > +++ b/Documentation/PCI/pcieaer-howto.rst > @@ -85,6 +85,16 @@ In the example, 'Requester ID' means the ID of the device that sent > the error message to the Root Port. Please refer to PCIe specs for other > fields. > > +The 'TLP Header' is the prefix/header of the TLP that caused the error > +in raw hex format. To decode the TLP Header into human-readable form > +one may use tlp-tool: > + > +https://github.com/mmpg-x86/tlp-tool > + > +Example usage:: > + > + curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer > + > AER Ratelimits > -------------- > > -- > 2.51.0 > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-23 16:50 ` Bjorn Helgaas @ 2026-03-24 5:53 ` mx2pg 2026-03-24 10:09 ` Lukas Wunner 2026-03-24 11:18 ` Ilpo Järvinen 0 siblings, 2 replies; 8+ messages in thread From: mx2pg @ 2026-03-24 5:53 UTC (permalink / raw) To: Bjorn Helgaas Cc: Lukas Wunner, Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Ilpo Jarvinen, Kai-Heng Feng One thing worth calling out: starting with PCIe 6.0, Flit Mode is mandatory at 64.0 GT/s and supported at all PCIe link speeds, so a Flit-capable PCIe 6.x link may operate below 64.0 GT/s and still be in Flit Mode. The raw TLP Header bytes do not encode the framing — the same four bytes decode to entirely different packet types in non-Flit vs Flit framing. The negotiated mode can be read from the Flit Mode Status bit in Link Status 2, or via lspci -vv on a recent pciutils build. tlp-tool defaults to non-Flit, which is correct for the vast majority of hardware deployed today. That will change: as PCIe 6.x adoption grows, a significant share of TLP debugging will involve Flit Mode links, and this is already a concern among switch and device vendors working through the transition. Users on Flit Mode links must pass --flit: # non-Flit link (default, most common today) curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer # Flit Mode link curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer --flit It may be worth a one-liner in the Documentation patch: For PCIe 6.x links with Flit Mode negotiated (check Flit Mode Status in Link Status 2, or lspci -vv), pass --flit to rtlp-tool. Maciej On Monday, March 23rd, 2026 at 9:50 AM, Bjorn Helgaas <helgaas@kernel.org> wrote: > On Mon, Mar 23, 2026 at 07:52:39AM +0100, Lukas Wunner wrote: > > The prefix/header of the TLP that caused an error is recorded by the Root > > Complex and emitted to the kernel log in raw hex format. Document the > > existence and usage of tlp-tool, which allows decoding the TLP Header > > into human-readable form. > > > > The TLP Header hints at the root cause of an error, yet is often ignored > > because of its seeming opaqueness. Instead, PCIe errors are frequently > > worked around by a change in the kernel without fully understanding the > > actual source of the problem. With more documentation on available tools > > we'll hopefully come up with better solutions. > > > > There are also wireshark dissectors for TLPs, but it seems they expect a > > complete TLP, not just the header, and they cannot grok the hex format > > emitted by the kernel directly. tlp-tool appears to be the most cut and > > dried solution out there. > > > > Signed-off-by: Lukas Wunner <lukas@wunner.de> > > Cc: Maciej Grochowski <mx2pg@pm.me> > > Applied to pci/for-linus for v7.0, thanks! > > I tweaked the commit log to note that the Header Log is in the AER > Capability, which may be in any PCIe function. > > > --- > > We could also go one step further and point users to this tool > > in a printk_once() message when the first error occurs. > > For now, just amending the documentation is probably sufficient. > > > > Documentation/PCI/pcieaer-howto.rst | 10 ++++++++++ > > 1 file changed, 10 insertions(+) > > > > diff --git a/Documentation/PCI/pcieaer-howto.rst b/Documentation/PCI/pcieaer-howto.rst > > index 3210c47..90fdfdd 100644 > > --- a/Documentation/PCI/pcieaer-howto.rst > > +++ b/Documentation/PCI/pcieaer-howto.rst > > @@ -85,6 +85,16 @@ In the example, 'Requester ID' means the ID of the device that sent > > the error message to the Root Port. Please refer to PCIe specs for other > > fields. > > > > +The 'TLP Header' is the prefix/header of the TLP that caused the error > > +in raw hex format. To decode the TLP Header into human-readable form > > +one may use tlp-tool: > > + > > +https://github.com/mmpg-x86/tlp-tool > > + > > +Example usage:: > > + > > + curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer > > + > > AER Ratelimits > > -------------- > > > > -- > > 2.51.0 > > > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-24 5:53 ` mx2pg @ 2026-03-24 10:09 ` Lukas Wunner 2026-03-24 10:22 ` Lukas Wunner 2026-03-24 11:18 ` Ilpo Järvinen 1 sibling, 1 reply; 8+ messages in thread From: Lukas Wunner @ 2026-03-24 10:09 UTC (permalink / raw) To: Maciej Grochowski Cc: Bjorn Helgaas, Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Ilpo Jarvinen, Kai-Heng Feng On Tue, Mar 24, 2026 at 05:53:30AM +0000, mx2pg@pm.me wrote: > One thing worth calling out: starting with PCIe 6.0, Flit Mode is > mandatory at 64.0 GT/s and supported at all PCIe link speeds, so a > Flit-capable PCIe 6.x link may operate below 64.0 GT/s and still be > in Flit Mode. The raw TLP Header bytes do not encode the framing — > the same four bytes decode to entirely different packet types in > non-Flit vs Flit framing. The negotiated mode can be read from the > Flit Mode Status bit in Link Status 2, or via lspci -vv on a recent > pciutils build. Thanks Maciej for chiming in. Ilpo (who is cc'ed) amended the kernel last year with commit 7e077e6707b3 ("PCI/ERR: Handle TLP Log in Flit mode") to suffix the hexdump with " (Flit)" in Flit Mode: https://git.kernel.org/linus/7e077e6707b3 Any chance you could amend tlp-tool to auto-detect Flit Mode if the suffix is present? As an aside: Prior to that, commit f68ea779d98a ("PCI: Add pcie_print_tlp_log() to print TLP Header and Prefix Log") changed the log message to prefix each dword with "0x". But I tested it and it seems that tlp-tool groks both the old and the new format without any code change: https://git.kernel.org/linus/f68ea779d98a But we need to be careful going forward not to break user space tooling that might rely on the syntax. Thanks, Lukas ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-24 10:09 ` Lukas Wunner @ 2026-03-24 10:22 ` Lukas Wunner 0 siblings, 0 replies; 8+ messages in thread From: Lukas Wunner @ 2026-03-24 10:22 UTC (permalink / raw) To: Maciej Grochowski Cc: Bjorn Helgaas, Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Ilpo Jarvinen, Kai-Heng Feng On Tue, Mar 24, 2026 at 11:09:35AM +0100, Lukas Wunner wrote: > Ilpo (who is cc'ed) amended the kernel last year with commit > 7e077e6707b3 ("PCI/ERR: Handle TLP Log in Flit mode") to suffix > the hexdump with " (Flit)" in Flit Mode: > > https://git.kernel.org/linus/7e077e6707b3 Sorry, I should have mentioned that this commit first appeared in v6.15, so auto-detection of Flit mode logs in user space tools should be possible from that kernel version onward. > As an aside: Prior to that, commit f68ea779d98a ("PCI: Add > pcie_print_tlp_log() to print TLP Header and Prefix Log") > changed the log message to prefix each dword with "0x". > But I tested it and it seems that tlp-tool groks both the > old and the new format without any code change: > > https://git.kernel.org/linus/f68ea779d98a This landed in v6.14. Thanks, Lukas ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-24 5:53 ` mx2pg 2026-03-24 10:09 ` Lukas Wunner @ 2026-03-24 11:18 ` Ilpo Järvinen 2026-03-25 5:18 ` mx2pg 1 sibling, 1 reply; 8+ messages in thread From: Ilpo Järvinen @ 2026-03-24 11:18 UTC (permalink / raw) To: mx2pg Cc: Bjorn Helgaas, Lukas Wunner, Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Kai-Heng Feng [-- Attachment #1: Type: text/plain, Size: 7508 bytes --] On Tue, 24 Mar 2026, mx2pg@pm.me wrote: > One thing worth calling out: starting with PCIe 6.0, Flit Mode is > mandatory at 64.0 GT/s and supported at all PCIe link speeds, so a > Flit-capable PCIe 6.x link may operate below 64.0 GT/s and still be > in Flit Mode. The raw TLP Header bytes do not encode the framing — > the same four bytes decode to entirely different packet types in > non-Flit vs Flit framing. The negotiated mode can be read from the > Flit Mode Status bit in Link Status 2, or via lspci -vv on a recent > pciutils build. There's one caveat in using Link Status 2 Flit Mode Status bit, it can only be used as the indicator when the Link is Up, which may come into picture in troubleshooting scenarios. The kernel code tries to hide that by indicating the Flit mode explicitly in the log message it prints out. Sadly, TLP Logging on DPC side was botched in the PCIe spec so it doesn't indicate the Flit/non-Flit mode information explicitly (in contrast to AER that has a flag that tells in which mode the TLP Log was captured). To workaround that limitation, kernel has to save of the Link Status 2 contents and hope the information is not stale when DPC has brought the Link Down (it seems relatively likely to remain valid but it's still fundamentally racy way to get the Flit/non-Flit information). -- i. > tlp-tool defaults to non-Flit, which is correct for the vast majority > of hardware deployed today. That will change: as PCIe 6.x adoption > grows, a significant share of TLP debugging will involve Flit Mode > links, and this is already a concern among switch and device vendors > working through the transition. Users on Flit Mode links must pass > --flit: > > # non-Flit link (default, most common today) > curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer > > # Flit Mode link > curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer --flit > > It may be worth a one-liner in the Documentation patch: > > For PCIe 6.x links with Flit Mode negotiated (check Flit Mode Status > in Link Status 2, or lspci -vv), pass --flit to rtlp-tool. > > Maciej > > > > On Monday, March 23rd, 2026 at 9:50 AM, Bjorn Helgaas <helgaas@kernel.org> wrote: > > > On Mon, Mar 23, 2026 at 07:52:39AM +0100, Lukas Wunner wrote: > > > The prefix/header of the TLP that caused an error is recorded by the Root > > > Complex and emitted to the kernel log in raw hex format. Document the > > > existence and usage of tlp-tool, which allows decoding the TLP Header > > > into human-readable form. > > > > > > The TLP Header hints at the root cause of an error, yet is often ignored > > > because of its seeming opaqueness. Instead, PCIe errors are frequently > > > worked around by a change in the kernel without fully understanding the > > > actual source of the problem. With more documentation on available tools > > > we'll hopefully come up with better solutions. > > > > > > There are also wireshark dissectors for TLPs, but it seems they expect a > > > complete TLP, not just the header, and they cannot grok the hex format > > > emitted by the kernel directly. tlp-tool appears to be the most cut and > > > dried solution out there. > > > > > > Signed-off-by: Lukas Wunner <lukas@wunner.de> > > > Cc: Maciej Grochowski <mx2pg@pm.me> > > > > Applied to pci/for-linus for v7.0, thanks! > > > > I tweaked the commit log to note that the Header Log is in the AER > > Capability, which may be in any PCIe function. > > > > > --- > > > We could also go one step further and point users to this tool > > > in a printk_once() message when the first error occurs. > > > For now, just amending the documentation is probably sufficient. > > > > > > Documentation/PCI/pcieaer-howto.rst | 10 ++++++++++ > > > 1 file changed, 10 insertions(+) > > > > > > diff --git a/Documentation/PCI/pcieaer-howto.rst b/Documentation/PCI/pcieaer-howto.rst > > > index 3210c47..90fdfdd 100644 > > > --- a/Documentation/PCI/pcieaer-howto.rst > > > +++ b/Documentation/PCI/pcieaer-howto.rst > > > @@ -85,6 +85,16 @@ In the example, 'Requester ID' means the ID of the device that sent > > > the error message to the Root Port. Please refer to PCIe specs for other > > > fields. > > > > > > +The 'TLP Header' is the prefix/header of the TLP that caused the error > > > +in raw hex format. To decode the TLP Header into human-readable form > > > +one may use tlp-tool: > > > + > > > +https://github.com/mmpg-x86/tlp-tool > > > + > > > +Example usage:: > > > + > > > + curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer > > > + > > > AER Ratelimits > > > -------------- > > > > > > -- > > > 2.51.0 > > > > > > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages 2026-03-24 11:18 ` Ilpo Järvinen @ 2026-03-25 5:18 ` mx2pg 0 siblings, 0 replies; 8+ messages in thread From: mx2pg @ 2026-03-25 5:18 UTC (permalink / raw) To: Ilpo Järvinen Cc: Bjorn Helgaas, Lukas Wunner, Jonathan Corbet, linux-pci, linux-doc, Mika Westerberg, Kai-Heng Feng Thanks Lukas for the suggestion and Ilpo for the caveat on Link Status 2. I'll add auto-detection of the (Flit) suffix (7e077e6707b3, v6.15+) to --aer mode so mixed flit / non-flit TLPs in the same log are each parsed with the correct framing -- no --flit needed. For --lspci I'll also pick up Flit+ from LnkSta2: per device. The --flit flag stays as a global override for inputs without auto-detection markers. This will be a patch release (v0.5.1) -- fully backward compatible. Maciej On Tuesday, March 24th, 2026 at 4:18 AM, Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> wrote: > On Tue, 24 Mar 2026, mx2pg@pm.me wrote: > > > One thing worth calling out: starting with PCIe 6.0, Flit Mode is > > mandatory at 64.0 GT/s and supported at all PCIe link speeds, so a > > Flit-capable PCIe 6.x link may operate below 64.0 GT/s and still be > > in Flit Mode. The raw TLP Header bytes do not encode the framing — > > the same four bytes decode to entirely different packet types in > > non-Flit vs Flit framing. The negotiated mode can be read from the > > Flit Mode Status bit in Link Status 2, or via lspci -vv on a recent > > pciutils build. > > There's one caveat in using Link Status 2 Flit Mode Status bit, it can > only be used as the indicator when the Link is Up, which may come into > picture in troubleshooting scenarios. > > The kernel code tries to hide that by indicating the Flit mode explicitly > in the log message it prints out. > > Sadly, TLP Logging on DPC side was botched in the PCIe spec so it doesn't > indicate the Flit/non-Flit mode information explicitly (in contrast to AER > that has a flag that tells in which mode the TLP Log was captured). To > workaround that limitation, kernel has to save of the Link Status 2 > contents and hope the information is not stale when DPC has brought the > Link Down (it seems relatively likely to remain valid but it's still > fundamentally racy way to get the Flit/non-Flit information). > > -- > i. > > > tlp-tool defaults to non-Flit, which is correct for the vast majority > > of hardware deployed today. That will change: as PCIe 6.x adoption > > grows, a significant share of TLP debugging will involve Flit Mode > > links, and this is already a concern among switch and device vendors > > working through the transition. Users on Flit Mode links must pass > > --flit: > > > > # non-Flit link (default, most common today) > > curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer > > > > # Flit Mode link > > curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer --flit > > > > It may be worth a one-liner in the Documentation patch: > > > > For PCIe 6.x links with Flit Mode negotiated (check Flit Mode Status > > in Link Status 2, or lspci -vv), pass --flit to rtlp-tool. > > > > Maciej > > > > > > > > On Monday, March 23rd, 2026 at 9:50 AM, Bjorn Helgaas <helgaas@kernel.org> wrote: > > > > > On Mon, Mar 23, 2026 at 07:52:39AM +0100, Lukas Wunner wrote: > > > > The prefix/header of the TLP that caused an error is recorded by the Root > > > > Complex and emitted to the kernel log in raw hex format. Document the > > > > existence and usage of tlp-tool, which allows decoding the TLP Header > > > > into human-readable form. > > > > > > > > The TLP Header hints at the root cause of an error, yet is often ignored > > > > because of its seeming opaqueness. Instead, PCIe errors are frequently > > > > worked around by a change in the kernel without fully understanding the > > > > actual source of the problem. With more documentation on available tools > > > > we'll hopefully come up with better solutions. > > > > > > > > There are also wireshark dissectors for TLPs, but it seems they expect a > > > > complete TLP, not just the header, and they cannot grok the hex format > > > > emitted by the kernel directly. tlp-tool appears to be the most cut and > > > > dried solution out there. > > > > > > > > Signed-off-by: Lukas Wunner <lukas@wunner.de> > > > > Cc: Maciej Grochowski <mx2pg@pm.me> > > > > > > Applied to pci/for-linus for v7.0, thanks! > > > > > > I tweaked the commit log to note that the Header Log is in the AER > > > Capability, which may be in any PCIe function. > > > > > > > --- > > > > We could also go one step further and point users to this tool > > > > in a printk_once() message when the first error occurs. > > > > For now, just amending the documentation is probably sufficient. > > > > > > > > Documentation/PCI/pcieaer-howto.rst | 10 ++++++++++ > > > > 1 file changed, 10 insertions(+) > > > > > > > > diff --git a/Documentation/PCI/pcieaer-howto.rst b/Documentation/PCI/pcieaer-howto.rst > > > > index 3210c47..90fdfdd 100644 > > > > --- a/Documentation/PCI/pcieaer-howto.rst > > > > +++ b/Documentation/PCI/pcieaer-howto.rst > > > > @@ -85,6 +85,16 @@ In the example, 'Requester ID' means the ID of the device that sent > > > > the error message to the Root Port. Please refer to PCIe specs for other > > > > fields. > > > > > > > > +The 'TLP Header' is the prefix/header of the TLP that caused the error > > > > +in raw hex format. To decode the TLP Header into human-readable form > > > > +one may use tlp-tool: > > > > + > > > > +https://github.com/mmpg-x86/tlp-tool > > > > + > > > > +Example usage:: > > > > + > > > > + curl -L https://git.kernel.org/linus/2ca1c94ce0b6 | rtlp-tool --aer > > > > + > > > > AER Ratelimits > > > > -------------- > > > > > > > > -- > > > > 2.51.0 > > > > > > > > > ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2026-03-25 5:18 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2026-03-23 6:52 [PATCH] Documentation: PCI: Document decoding of TLP Header in AER messages Lukas Wunner 2026-03-23 11:03 ` Mika Westerberg 2026-03-23 16:50 ` Bjorn Helgaas 2026-03-24 5:53 ` mx2pg 2026-03-24 10:09 ` Lukas Wunner 2026-03-24 10:22 ` Lukas Wunner 2026-03-24 11:18 ` Ilpo Järvinen 2026-03-25 5:18 ` mx2pg
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox