re: PCI: Add TLP Prefix reading to pcie_read_tlp_log()
From: Ilpo Järvinen
Date: Thu Jan 16 2025 - 11:19:02 EST
On Thu, 16 Jan 2025, Colin King (gmail) wrote:
> Hi,
>
> Static analysis shows there is a potential issue in the following commit:
>
> commit 00048c2d5f113bb4e82a0a30dfc4ee12590b81f5
> Author: Ilpo Järvinen <ilpo.jarvinen@xxxxxxxxxxxxxxx>
> Date: Tue Jan 14 19:08:39 2025 +0200
>
> PCI: Add TLP Prefix reading to pcie_read_tlp_log()
>
>
> The issue is described as follows:
>
> unsigned int aer_tlp_log_len(struct pci_dev *dev, u32 aercc)
> {
> return PCIE_STD_NUM_TLP_HEADERLOG +
> (aercc & PCI_ERR_CAP_PREFIX_LOG_PRESENT) ?
> dev->eetlp_prefix_max : 0;
> }
>
>
> static analysis is warning that the left hand size of the ? operator is always
> true and so dev->eetlp_prefix_max is always being returned and the 0 is never
> returned (dead code).
>
> I suspect the expected behaviour is as follows:
>
> return PCIE_STD_NUM_TLP_HEADERLOG +
> ((aercc & PCI_ERR_CAP_PREFIX_LOG_PRESENT) ?
> dev->eetlp_prefix_max : 0);
>
> ..I'm reluctant to send a fix in case this is not the original intention.
Your fix looks correct, it should have the parenthesis due to operator
precedence rules. The intention is to calculate 4 DWs + optionally n E-E
TLP prefixes.
--
i.