diff options
| author | Jonathan Cameron <[email protected]> | 2022-08-18 17:42:10 +0100 | 
|---|---|---|
| committer | Dan Williams <[email protected]> | 2022-10-20 16:28:53 -0700 | 
| commit | 2816e24b0510e0c185c0c46acff1ce7aa4c4443f (patch) | |
| tree | a9778e38a4b69218064b1e9e7b5ec830e56e74a6 /scripts/gdb/linux/constants.py.in | |
| parent | cf00b33058b196b4db928419dde68993b15a975b (diff) | |
cxl/region: Fix null pointer dereference due to pass through decoder commit
Not all decoders have a commit callback.
The CXL specification allows a host bridge with a single root port to
have no explicit HDM decoders. Currently the region driver assumes there
are none.  As such the CXL core creates a special pass through decoder
instance without a commit callback.
Prior to this patch, the ->commit() callback was called unconditionally.
Thus a configuration with 1 Host Bridge, 1 Root Port, 1 switch with
multiple downstream ports below which there are multiple CXL type 3
devices results in a situation where committing the region causes a null
pointer dereference.
Reported-by: Bobo WL <[email protected]>
Fixes: 176baefb2eb5 ("cxl/hdm: Commit decoder state to hardware")
Signed-off-by: Jonathan Cameron <[email protected]>
Reviewed-by: Vishal Verma <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Dan Williams <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/constants.py.in')
0 files changed, 0 insertions, 0 deletions