Commit ee1e3c46 authored by Ben Cheatham's avatar Ben Cheatham Committed by Ira Weiny

EINJ, CXL: Fix CXL device SBDF calculation

The SBDF of the target CXL 2.0 compliant root port is required to inject a CXL
protocol error as per ACPI 6.5. The SBDF given has to be in the
following format:

31     24 23    16 15    11 10      8  7        0
+-------------------------------------------------+
| segment |   bus  | device | function | reserved |
+-------------------------------------------------+

The SBDF calculated in cxl_dport_get_sbdf() doesn't account for
the reserved bits currently, causing the wrong SBDF to be used.
Fix said calculation to properly shift the SBDF.

Without this fix, error injection into CXL 2.0 root ports through the
CXL debugfs interface (<debugfs>/cxl) is broken. Injection
through the legacy interface (<debugfs>/apei/einj/) will still work
because the SBDF is manually provided by the user.

Fixes: 12fb28ea ("EINJ: Add CXL error type support")
Signed-off-by: default avatarBen Cheatham <Benjamin.Cheatham@amd.com>
Reviewed-by: default avatarDan Williams <dan.j.williams@intel.com>
Tested-by: default avatarSrinivasulu Thanneeru <sthanneeru.opensrc@micron.com>
Reviewed-by: default avatarSrinivasulu Thanneeru <sthanneeru.opensrc@micron.com>
Link: https://patch.msgid.link/20240927163428.366557-1-Benjamin.Cheatham@amd.comSigned-off-by: default avatarIra Weiny <ira.weiny@intel.com>
parent 9852d85e
...@@ -63,7 +63,7 @@ static int cxl_dport_get_sbdf(struct pci_dev *dport_dev, u64 *sbdf) ...@@ -63,7 +63,7 @@ static int cxl_dport_get_sbdf(struct pci_dev *dport_dev, u64 *sbdf)
seg = bridge->domain_nr; seg = bridge->domain_nr;
bus = pbus->number; bus = pbus->number;
*sbdf = (seg << 24) | (bus << 16) | dport_dev->devfn; *sbdf = (seg << 24) | (bus << 16) | (dport_dev->devfn << 8);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment