diff options
| author | Dave Jiang <[email protected]> | 2024-03-01 14:09:48 -0700 | 
|---|---|---|
| committer | Dan Williams <[email protected]> | 2024-03-12 23:41:59 -0700 | 
| commit | 99b52aac2d40203d0f6468325018f68e2c494c24 (patch) | |
| tree | 46df42c48b2c0073da15bc30297e918579df03a6 /drivers/platform/x86/intel/atomisp2/pm.c | |
| parent | d206a76d7d2726f3b096037f2079ce0bd3ba329b (diff) | |
cxl: Fix the incorrect assignment of SSLBIS entry pointer initial location
The 'entry' pointer in cdat_sslbis_handler() is set to header +
sizeof(common header). However, the math missed the addition of the SSLBIS
main header. It should be header + sizeof(common header) + sizeof(*sslbis).
Use a defined struct for all the SSLBIS parts in order to avoid pointer
math errors.
The bug causes incorrect parsing of the SSLBIS table and introduces incorrect
performance values to the access_coordinates during the CXL access_coordinate
calculation path if there are CXL switches present in the topology.
The issue was found during testing of new code being added to add additional
checks for invalid CDAT values during CXL access_coordinate calculation. The
testing was done on qemu with a CXL topology including a CXL switch.
Fixes: 80aa780dda20 ("cxl: Add callback to parse the SSLBIS subtable from CDAT")
Signed-off-by: Dave Jiang <[email protected]>
Reviewed-by: Jonathan Cameron <[email protected]>
Reviewed-by: Fan Ni <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Dan Williams <[email protected]>
Diffstat (limited to 'drivers/platform/x86/intel/atomisp2/pm.c')
0 files changed, 0 insertions, 0 deletions